<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>[794] trunk/wp-testcase/test_user_capabilities.php: Port test_user_capabilities.php.</title>
</head>
<body>

<style type="text/css"><!--
#msg dl.meta { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dl.meta dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer, #logmsg { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt;  }
#msg dl a { font-weight: bold}
#msg dl a:link    { color:#fc3; }
#msg dl a:active  { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre { overflow: auto; background: #ffc; border: 1px #fa0 solid; padding: 6px; }
#logmsg { background: #ffc; border: 1px #fa0 solid; padding: 1em 1em 0 1em; }
#logmsg p, #logmsg pre, #logmsg blockquote { margin: 0 0 1em 0; }
#logmsg p, #logmsg li, #logmsg dt, #logmsg dd { line-height: 14pt; }
#logmsg h1, #logmsg h2, #logmsg h3, #logmsg h4, #logmsg h5, #logmsg h6 { margin: .5em 0; }
#logmsg h1:first-child, #logmsg h2:first-child, #logmsg h3:first-child, #logmsg h4:first-child, #logmsg h5:first-child, #logmsg h6:first-child { margin-top: 0; }
#logmsg ul, #logmsg ol { padding: 0; list-style-position: inside; margin: 0 0 0 1em; }
#logmsg > ul, #logmsg > ol { margin-left: 0; margin: 0 0 1em 0; }
#logmsg pre { background: #eee; padding: 1em; }
#logmsg blockquote { border: 1px solid #fa0; border-left-width: 10px; padding: 1em 1em 0 1em; background: white;}
#logmsg dl { margin: 0; }
#logmsg dt { font-weight: bold; }
#logmsg dd { margin: 0; padding: 0 0 0.5em 0; }
#logmsg dd:before { content:'\00bb';}
#logmsg table { border-spacing: 0px; border-collapse: collapse; border-top: 4px solid #fa0; border-bottom: 1px solid #fa0; background: #fff; }
#logmsg table th { text-align: left; font-weight: normal; padding: 0.2em 0.5em; border-top: 1px dotted #fa0; }
#logmsg table td { text-align: right; border-top: 1px dotted #fa0; padding: 0.2em 0.5em; }
#logmsg table thead th { text-align: center; border-bottom: 1px solid #fa0; }
#logmsg table th.Corner { text-align: left; }
#logmsg hr { border: none 0; border-top: 2px dashed #fa0; height: 1px; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff  {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<div id="msg">
<dl class="meta">
<dt>Revision</dt> <dd><a href="http://unit-tests.trac.wordpress.org/changeset/794">794</a></dd>
<dt>Author</dt> <dd>nacin</dd>
<dt>Date</dt> <dd>2012-06-30 19:38:48 +0000 (Sat, 30 Jun 2012)</dd>
</dl>

<h3>Log Message</h3>
<pre>Port test_user_capabilities.php. fixes <a href="http://unit-tests.trac.wordpress.org/ticket/68">#68</a>.</pre>

<h3>Modified Paths</h3>
<ul>
<li><a href="#trunkwptestcasetest_user_capabilitiesphp">trunk/wp-testcase/test_user_capabilities.php</a></li>
</ul>

</div>
<div id="patch">
<h3>Diff</h3>
<a id="trunkwptestcasetest_user_capabilitiesphp"></a>
<div class="modfile"><h4>Modified: trunk/wp-testcase/test_user_capabilities.php (793 => 794)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/wp-testcase/test_user_capabilities.php        2012-06-30 19:21:43 UTC (rev 793)
+++ trunk/wp-testcase/test_user_capabilities.php        2012-06-30 19:38:48 UTC (rev 794)
</span><span class="lines">@@ -2,30 +2,28 @@
</span><span class="cx"> 
</span><span class="cx"> // Test roles and capabilities via the WP_User class
</span><span class="cx"> 
</span><del>-class WPTestUserCapabilities extends _WPEmptyBlog {
</del><ins>+/**
+ * @group user
+ * @group capabilities
+ */
+class WPTestUserCapabilities extends WP_UnitTestCase {
</ins><span class="cx">         var $user_ids = array();
</span><span class="cx"> 
</span><span class="cx">         function setUp() {
</span><span class="cx">                 parent::setUp();
</span><span class="cx">                 // keep track of users we create
</span><del>-                $this-&gt;user_ids = array();
</del><span class="cx">                 $this-&gt;_flush_roles();
</span><span class="cx"> 
</span><span class="cx">                 $this-&gt;orig_users = get_users_of_blog();
</span><span class="cx">         }
</span><span class="cx"> 
</span><del>-        function tearDown() {
-                parent::tearDown();
-                // delete any users that were created during tests
-                $this-&gt;_destroy_users();
-        }
-
</del><span class="cx">         function _flush_roles() {
</span><span class="cx">                 // we want to make sure we're testing against the db, not just in-memory data
</span><span class="cx">                 // this will flush everything and reload it from the db
</span><span class="cx">                 unset($GLOBALS['wp_user_roles']);
</span><span class="cx">                 global $wp_roles;
</span><del>-                $wp_roles-&gt;_init();
</del><ins>+                if ( is_object( $wp_roles ) )
+                        $wp_roles-&gt;_init();
</ins><span class="cx">         }
</span><span class="cx"> 
</span><span class="cx">         function _meta_yes_you_can( $can, $key, $post_id, $user_id, $cap, $caps ) {
</span><span class="lines">@@ -43,7 +41,7 @@
</span><span class="cx">         // test the default roles
</span><span class="cx"> 
</span><span class="cx">         function test_user_administrator() {
</span><del>-                $id = $this-&gt;_make_user('administrator');
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'administrator' ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx"> 
</span><span class="lines">@@ -58,7 +56,7 @@
</span><span class="cx">         }
</span><span class="cx"> 
</span><span class="cx">         function test_user_editor() {
</span><del>-                $id = $this-&gt;_make_user('editor');
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'editor' ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx"> 
</span><span class="lines">@@ -78,7 +76,7 @@
</span><span class="cx">         }
</span><span class="cx"> 
</span><span class="cx">         function test_user_author() {
</span><del>-                $id = $this-&gt;_make_user('author');
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'author' ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx"> 
</span><span class="lines">@@ -98,7 +96,7 @@
</span><span class="cx">         }
</span><span class="cx"> 
</span><span class="cx">         function test_user_contributor() {
</span><del>-                $id = $this-&gt;_make_user('contributor');
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'contributor' ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx"> 
</span><span class="lines">@@ -118,7 +116,7 @@
</span><span class="cx">         }
</span><span class="cx"> 
</span><span class="cx">         function test_user_subscriber() {
</span><del>-                $id = $this-&gt;_make_user('subscriber');
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'subscriber' ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx"> 
</span><span class="lines">@@ -138,7 +136,7 @@
</span><span class="cx">         // a role that doesn't exist
</span><span class="cx">         function test_bogus_role() {
</span><span class="cx">                 _disable_wp_die();
</span><del>-                $id = $this-&gt;_make_user(rand_str());
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; rand_str() ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx"> 
</span><span class="lines">@@ -150,7 +148,7 @@
</span><span class="cx"> 
</span><span class="cx">         // a user with multiple roles
</span><span class="cx">         function test_user_subscriber_contributor() {
</span><del>-                $id = $this-&gt;_make_user('subscriber');
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'subscriber' ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx">                 $user-&gt;add_role('contributor');
</span><span class="lines">@@ -184,7 +182,7 @@
</span><span class="cx">                 $this-&gt;_flush_roles();
</span><span class="cx">                 $this-&gt;assertTrue($wp_roles-&gt;is_role($role_name));
</span><span class="cx"> 
</span><del>-                $id = $this-&gt;_make_user($role_name);
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; $role_name ) );
</ins><span class="cx"> 
</span><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="lines">@@ -213,7 +211,7 @@
</span><span class="cx">                 $this-&gt;_flush_roles();
</span><span class="cx">                 $this-&gt;assertTrue($wp_roles-&gt;is_role($role_name));
</span><span class="cx"> 
</span><del>-                $id = $this-&gt;_make_user($role_name);
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; $role_name ) );
</ins><span class="cx"> 
</span><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="lines">@@ -250,7 +248,7 @@
</span><span class="cx">                 $this-&gt;assertTrue( $wp_roles-&gt;is_role($role_name) );
</span><span class="cx"> 
</span><span class="cx">                 // assign a user to that role
</span><del>-                $id = $this-&gt;_make_user($role_name);
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; $role_name ) );
</ins><span class="cx"> 
</span><span class="cx">                 // now add a cap to the role
</span><span class="cx">                 $wp_roles-&gt;add_cap($role_name, 'sweep_floor');
</span><span class="lines">@@ -288,7 +286,7 @@
</span><span class="cx">                 $this-&gt;assertTrue( $wp_roles-&gt;is_role($role_name) );
</span><span class="cx"> 
</span><span class="cx">                 // assign a user to that role
</span><del>-                $id = $this-&gt;_make_user($role_name);
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; $role_name ) );
</ins><span class="cx"> 
</span><span class="cx">                 // now remove a cap from the role
</span><span class="cx">                 $wp_roles-&gt;remove_cap($role_name, 'polish_doorknobs');
</span><span class="lines">@@ -317,8 +315,8 @@
</span><span class="cx">                 // add an extra capability to a user
</span><span class="cx"> 
</span><span class="cx">                 // there are two contributors
</span><del>-                $id_1 = $this-&gt;_make_user('contributor');
-                $id_2 = $this-&gt;_make_user('contributor');
</del><ins>+                $id_1 = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'contributor' ) );
+                $id_2 = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'contributor' ) );
</ins><span class="cx"> 
</span><span class="cx">                 // user 1 has an extra capability
</span><span class="cx">                 $user_1 = new WP_User($id_1);
</span><span class="lines">@@ -354,8 +352,8 @@
</span><span class="cx">                 // add an extra capability to a user then remove it
</span><span class="cx"> 
</span><span class="cx">                 // there are two contributors
</span><del>-                $id_1 = $this-&gt;_make_user('contributor');
-                $id_2 = $this-&gt;_make_user('contributor');
</del><ins>+                $id_1 = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'contributor' ) );
+                $id_2 = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'contributor' ) );
</ins><span class="cx"> 
</span><span class="cx">                 // user 1 has an extra capability
</span><span class="cx">                 $user_1 = new WP_User($id_1);
</span><span class="lines">@@ -385,7 +383,7 @@
</span><span class="cx">                 // make sure the user_level is correctly set and changed with the user's role
</span><span class="cx"> 
</span><span class="cx">                 // user starts as an author
</span><del>-                $id = $this-&gt;_make_user('author');
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'author' ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx"> 
</span><span class="lines">@@ -408,7 +406,7 @@
</span><span class="cx"> 
</span><span class="cx">         function test_user_remove_all_caps() {
</span><span class="cx">                 // user starts as an author
</span><del>-                $id = $this-&gt;_make_user('author');
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'author' ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx"> 
</span><span class="lines">@@ -450,20 +448,19 @@
</span><span class="cx">                 // simple tests for some common meta capabilities
</span><span class="cx"> 
</span><span class="cx">                 // Make our author
</span><del>-                $author = new WP_User($this-&gt;_make_user('author'));                
</del><ins>+                $author = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'author' ) ) );
</ins><span class="cx"> 
</span><del>-                // make a [pst
-                $this-&gt;_insert_quick_posts(1, 'post', array( 'post_author' =&gt; $author-&gt;ID ) );
-                $post = end($this-&gt;post_ids);
</del><ins>+                // make a post
+                $post = $this-&gt;factory-&gt;post-&gt;create( array( 'post_author' =&gt; $author-&gt;ID, 'post_type' =&gt; 'post' ) );
</ins><span class="cx"> 
</span><span class="cx">                 // the author of the post
</span><span class="cx">                 $this-&gt;assertTrue($author-&gt;exists(), &quot;Problem getting user $author-&gt;ID&quot;);
</span><span class="cx"> 
</span><span class="cx">                 // add some other users
</span><del>-                $admin = new WP_User($this-&gt;_make_user('administrator'));
-                $author_2 = new WP_User($this-&gt;_make_user('author'));
-                $editor = new WP_User($this-&gt;_make_user('editor'));
-                $contributor = new WP_User($this-&gt;_make_user('contributor'));
</del><ins>+                $admin = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'administrator' ) ) );
+                $author_2 = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'author' ) ) );
+                $editor = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'editor' ) ) );
+                $contributor = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'contributor' ) ) );
</ins><span class="cx"> 
</span><span class="cx">                 // administrators, editors and the post owner can edit it
</span><span class="cx">                 $this-&gt;assertTrue($admin-&gt;has_cap('edit_post', $post));
</span><span class="lines">@@ -511,20 +508,19 @@
</span><span class="cx">                 // simple tests for some common meta capabilities
</span><span class="cx"> 
</span><span class="cx">                 // Make our author
</span><del>-                $author = new WP_User($this-&gt;_make_user('author'));                
</del><ins>+                $author = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'author' ) ) );
</ins><span class="cx"> 
</span><span class="cx">                 // make a page
</span><del>-                $this-&gt;_insert_quick_pages(1, array( 'post_author' =&gt; $author-&gt;ID ) );
-                $page = end($this-&gt;post_ids);
</del><ins>+                $page = $this-&gt;factory-&gt;post-&gt;create( array( 'post_author' =&gt; $author-&gt;ID, 'post_type' =&gt; 'page' ) );
</ins><span class="cx"> 
</span><span class="cx">                 // the author of the page
</span><span class="cx">                 $this-&gt;assertTrue($author-&gt;exists(), &quot;Problem getting user &quot; . $author-&gt;ID);
</span><span class="cx"> 
</span><span class="cx">                 // add some other users
</span><del>-                $admin = new WP_User($this-&gt;_make_user('administrator'));
-                $author_2 = new WP_User($this-&gt;_make_user('author'));
-                $editor = new WP_User($this-&gt;_make_user('editor'));
-                $contributor = new WP_User($this-&gt;_make_user('contributor'));
</del><ins>+                $admin = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'administrator' ) ) );
+                $author_2 = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'author' ) ) );
+                $editor = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'editor' ) ) );
+                $contributor = new WP_User( $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'contributor' ) ) );
</ins><span class="cx"> 
</span><span class="cx">                 // administrators, editors and the post owner can edit it
</span><span class="cx">                 $this-&gt;assertTrue($admin-&gt;has_cap('edit_page', $page));
</span><span class="lines">@@ -549,7 +545,7 @@
</span><span class="cx"> 
</span><span class="cx">                 // make sure an old style usermeta capabilities entry is still recognized by the new code
</span><span class="cx"> 
</span><del>-                $id = $this-&gt;_make_user('author');
</del><ins>+                $id = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; 'author' ) );
</ins><span class="cx">                 $user = new WP_User($id);
</span><span class="cx">                 $this-&gt;assertTrue($user-&gt;exists(), &quot;Problem getting user $id&quot;);
</span><span class="cx"> 
</span><span class="lines">@@ -576,7 +572,6 @@
</span><span class="cx">         }
</span><span class="cx"> 
</span><span class="cx">         function test_upgrade() {
</span><del>-
</del><span class="cx">                 // only relevant with this patch
</span><span class="cx">                 $this-&gt;knownWPBug(5540);
</span><span class="cx"> 
</span><span class="lines">@@ -588,7 +583,7 @@
</span><span class="cx">                 // make some users with old style usermeta roles and caps
</span><span class="cx">                 $id = array();
</span><span class="cx">                 for ($i=0; $i&lt;5; $i++) {
</span><del>-                        $id[$i] = $this-&gt;_make_user('');
</del><ins>+                        $id[$i] = $this-&gt;factory-&gt;user-&gt;create( array( 'role' =&gt; '' ) );
</ins><span class="cx">                         $wpdb-&gt;query(&quot;DELETE FROM {$wpdb-&gt;user_role} WHERE user_id = {$id[$i]}&quot;);
</span><span class="cx">                 }
</span><span class="cx"> 
</span></span></pre>
</div>
</div>

</body>
</html>