12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163 |
- <?php
- if ( is_multisite() ) :
- /**
- * A set of unit tests for WordPress Multisite
- *
- * @group multisite
- */
- class Tests_MS extends WP_UnitTestCase {
- protected $plugin_hook_count = 0;
- protected $suppress = false;
- function setUp() {
- global $wpdb;
- parent::setUp();
- $this->suppress = $wpdb->suppress_errors();
- $_SERVER['REMOTE_ADDR'] = '';
- }
- function tearDown() {
- global $wpdb;
- parent::tearDown();
- $wpdb->suppress_errors( $this->suppress );
- }
- /**
- * @ticket 22917
- */
- function test_enable_live_network_site_counts_filter() {
- $site_count_start = get_blog_count();
- // false for large networks by default
- add_filter( 'enable_live_network_counts', '__return_false' );
- $this->factory->blog->create_many( 4 );
- // count only updated when cron runs, so unchanged
- $this->assertEquals( $site_count_start, (int) get_blog_count() );
- add_filter( 'enable_live_network_counts', '__return_true' );
- $site_ids = $this->factory->blog->create_many( 4 );
- $this->assertEquals( $site_count_start + 9, (int) get_blog_count() );
- //clean up
- remove_filter( 'enable_live_network_counts', '__return_false' );
- remove_filter( 'enable_live_network_counts', '__return_true' );
- foreach ( $site_ids as $site_id ) {
- wpmu_delete_blog( $site_id, true );
- }
- }
- /**
- * @ticket 22917
- */
- function test_enable_live_network_user_counts_filter() {
- // false for large networks by default
- add_filter( 'enable_live_network_counts', '__return_false' );
- // Refresh the cache
- wp_update_network_counts();
- $start_count = get_user_count();
- wpmu_create_user( 'user', 'pass', 'email' );
- // No change, cache not refreshed
- $count = get_user_count();
- $this->assertEquals( $start_count, $count );
- wp_update_network_counts();
- $start_count = get_user_count();
- add_filter( 'enable_live_network_counts', '__return_true' );
- wpmu_create_user( 'user2', 'pass2', 'email2' );
- $count = get_user_count();
- $this->assertEquals( $start_count + 1, $count );
- remove_filter( 'enable_live_network_counts', '__return_false' );
- remove_filter( 'enable_live_network_counts', '__return_true' );
- }
- function test_create_and_delete_blog() {
- global $wpdb;
- $blog_ids = $this->factory->blog->create_many( 4 );
- foreach ( $blog_ids as $blog_id ) {
- $this->assertInternalType( 'int', $blog_id );
- $prefix = $wpdb->get_blog_prefix( $blog_id );
- // $get_all = false
- $details = get_blog_details( $blog_id, false );
- $this->assertEquals( $details, wp_cache_get( $blog_id . 'short', 'blog-details' ) );
- // get_id_from_blogname(), see #20950
- $this->assertEquals( $blog_id, get_id_from_blogname( $details->path ) );
- $this->assertEquals( $blog_id, wp_cache_get( 'get_id_from_blogname_' . trim( $details->path, '/' ), 'blog-details' ) );
- // get_blog_id_from_url()
- $this->assertEquals( $blog_id, get_blog_id_from_url( $details->domain, $details->path ) );
- $key = md5( $details->domain . $details->path );
- $this->assertEquals( $blog_id, wp_cache_get( $key, 'blog-id-cache' ) );
- // These are empty until get_blog_details() is called with $get_all = true
- $this->assertEquals( false, wp_cache_get( $blog_id, 'blog-details' ) );
- $key = md5( $details->domain . $details->path );
- $this->assertEquals( false, wp_cache_get( $key, 'blog-lookup' ) );
- // $get_all = true should propulate the full blog-details cache and the blog slug lookup cache
- $details = get_blog_details( $blog_id, true );
- $this->assertEquals( $details, wp_cache_get( $blog_id, 'blog-details' ) );
- $this->assertEquals( $details, wp_cache_get( $key, 'blog-lookup' ) );
- foreach ( $wpdb->tables( 'blog', false ) as $table ) {
- $suppress = $wpdb->suppress_errors();
- $table_fields = $wpdb->get_results( "DESCRIBE $prefix$table;" );
- $wpdb->suppress_errors( $suppress );
- $this->assertNotEmpty( $table_fields );
- $result = $wpdb->get_results( "SELECT * FROM $prefix$table LIMIT 1" );
- if ( 'commentmeta' == $table || 'links' == $table )
- $this->assertEmpty( $result );
- else
- $this->assertNotEmpty( $result );
- }
- }
- // update the blog count cache to use get_blog_count()
- wp_update_network_counts();
- $this->assertEquals( 4 + 1, (int) get_blog_count() );
- $drop_tables = false;
- // delete all blogs
- foreach ( $blog_ids as $blog_id ) {
- // drop tables for every second blog
- $drop_tables = ! $drop_tables;
- $details = get_blog_details( $blog_id, false );
- wpmu_delete_blog( $blog_id, $drop_tables );
- $this->assertEquals( false, wp_cache_get( 'get_id_from_blogname_' . trim( $details->path, '/' ), 'blog-details' ) );
- $this->assertEquals( false, wp_cache_get( $blog_id, 'blog-details' ) );
- $this->assertEquals( false, wp_cache_get( $blog_id . 'short', 'blog-details' ) );
- $key = md5( $details->domain . $details->path );
- $this->assertEquals( false, wp_cache_get( $key, 'blog-lookup' ) );
- $this->assertEquals( false, wp_cache_get( $key, 'blog-id-cache' ) );
- $prefix = $wpdb->get_blog_prefix( $blog_id );
- foreach ( $wpdb->tables( 'blog', false ) as $table ) {
- $suppress = $wpdb->suppress_errors();
- $table_fields = $wpdb->get_results( "DESCRIBE $prefix$table;" );
- $wpdb->suppress_errors( $suppress );
- if ( $drop_tables )
- $this->assertEmpty( $table_fields );
- else
- $this->assertNotEmpty( $table_fields, $prefix . $table );
- }
- }
- // update the blog count cache to use get_blog_count()
- wp_update_network_counts();
- $this->assertEquals( 1, get_blog_count() );
- }
- function test_get_blogs_of_user() {
- // Logged out users don't have blogs.
- $this->assertEquals( array(), get_blogs_of_user( 0 ) );
- $user1_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_ids = $this->factory->blog->create_many( 10, array( 'user_id' => $user1_id ) );
- foreach ( $blog_ids as $blog_id )
- $this->assertInternalType( 'int', $blog_id );
- $blogs_of_user = array_keys( get_blogs_of_user( $user1_id, false ) );
- sort( $blogs_of_user );
- $this->assertEquals ( array_merge( array( 1 ), $blog_ids), $blogs_of_user );
- $this->assertTrue( remove_user_from_blog( $user1_id, 1 ) );
- $blogs_of_user = array_keys( get_blogs_of_user( $user1_id, false ) );
- sort( $blogs_of_user );
- $this->assertEquals ( $blog_ids, $blogs_of_user );
- foreach ( get_blogs_of_user( $user1_id, false ) as $blog ) {
- $this->assertTrue( isset( $blog->userblog_id ) );
- $this->assertTrue( isset( $blog->blogname ) );
- $this->assertTrue( isset( $blog->domain ) );
- $this->assertTrue( isset( $blog->path ) );
- $this->assertTrue( isset( $blog->site_id ) );
- $this->assertTrue( isset( $blog->siteurl ) );
- $this->assertTrue( isset( $blog->archived ) );
- $this->assertTrue( isset( $blog->spam ) );
- $this->assertTrue( isset( $blog->deleted ) );
- }
- // Non-existent users don't have blogs.
- wpmu_delete_user( $user1_id );
- $user = new WP_User( $user1_id );
- $this->assertFalse( $user->exists(), 'WP_User->exists' );
- $this->assertEquals( array(), get_blogs_of_user( $user1_id ) );
- }
- /**
- * @expectedDeprecated is_blog_user
- */
- function test_is_blog_user() {
- global $wpdb;
- $user1_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $old_current = get_current_user_id();
- wp_set_current_user( $user1_id );
- $this->assertTrue( is_blog_user() );
- $this->assertTrue( is_blog_user( $wpdb->blogid ) );
- $blog_ids = array();
- $blog_ids = $this->factory->blog->create_many( 5 );
- foreach ( $blog_ids as $blog_id ) {
- $this->assertInternalType( 'int', $blog_id );
- $this->assertTrue( is_blog_user( $blog_id ) );
- $this->assertTrue( remove_user_from_blog( $user1_id, $blog_id ) );
- $this->assertFalse( is_blog_user( $blog_id ) );
- }
- wp_set_current_user( $old_current );
- }
- function test_is_user_member_of_blog() {
- global $wpdb;
- $user1_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $old_current = get_current_user_id();
- wp_set_current_user( $user1_id );
- $this->assertTrue( is_user_member_of_blog() );
- $this->assertTrue( is_user_member_of_blog( 0, 0 ) );
- $this->assertTrue( is_user_member_of_blog( 0, $wpdb->blogid ) );
- $this->assertTrue( is_user_member_of_blog( $user1_id ) );
- $this->assertTrue( is_user_member_of_blog( $user1_id, $wpdb->blogid ) );
- $blog_ids = $this->factory->blog->create_many( 5 );
- foreach ( $blog_ids as $blog_id ) {
- $this->assertInternalType( 'int', $blog_id );
- $this->assertTrue( is_user_member_of_blog( $user1_id, $blog_id ) );
- $this->assertTrue( remove_user_from_blog( $user1_id, $blog_id ) );
- $this->assertFalse( is_user_member_of_blog( $user1_id, $blog_id ) );
- }
- wpmu_delete_user( $user1_id );
- $user = new WP_User( $user1_id );
- $this->assertFalse( $user->exists(), 'WP_User->exists' );
- $this->assertFalse( is_user_member_of_blog( $user1_id ), 'is_user_member_of_blog' );
- wp_set_current_user( $old_current );
- }
- function test_active_network_plugins() {
- $path = "hello.php";
- // local activate, should be invisible for the network
- activate_plugin($path); // $network_wide = false
- $active_plugins = wp_get_active_network_plugins();
- $this->assertEquals( Array(), $active_plugins );
- add_action( 'deactivated_plugin', array( $this, '_helper_deactivate_hook' ) );
- // activate the plugin sitewide
- activate_plugin($path, '', $network_wide = true);
- $active_plugins = wp_get_active_network_plugins();
- $this->assertEquals( Array(WP_PLUGIN_DIR . '/hello.php'), $active_plugins );
- //deactivate the plugin
- deactivate_plugins($path);
- $active_plugins = wp_get_active_network_plugins();
- $this->assertEquals( Array(), $active_plugins );
- $this->assertEquals( 1, $this->plugin_hook_count ); // testing actions and silent mode
- activate_plugin($path, '', $network_wide = true);
- deactivate_plugins($path, true); // silent
- $this->assertEquals( 1, $this->plugin_hook_count ); // testing actions and silent mode
- }
- function _helper_deactivate_hook() {
- $this->plugin_hook_count++;
- }
- function test_get_user_count() {
- // Refresh the cache
- wp_update_network_counts();
- $start_count = get_user_count();
- // Only false for large networks as of 3.7
- add_filter( 'enable_live_network_counts', '__return_false' );
- $this->factory->user->create( array( 'role' => 'administrator' ) );
- $count = get_user_count(); // No change, cache not refreshed
- $this->assertEquals( $start_count, $count );
- wp_update_network_counts(); // Magic happens here
- $count = get_user_count();
- $this->assertEquals( $start_count + 1, $count );
- remove_filter( 'enable_live_network_counts', '__return_false' );
- }
- function test_wp_schedule_update_network_counts() {
- $this->assertFalse(wp_next_scheduled('update_network_counts'));
- // We can't use wp_schedule_update_network_counts() because WP_INSTALLING is set
- wp_schedule_event(time(), 'twicedaily', 'update_network_counts');
- $this->assertInternalType('int', wp_next_scheduled('update_network_counts'));
- }
- function test_users_can_register_signup_filter() {
- $registration = get_site_option('registration');
- $this->assertFalse( users_can_register_signup_filter() );
- update_site_option('registration', 'all');
- $this->assertTrue( users_can_register_signup_filter() );
- update_site_option('registration', 'user');
- $this->assertTrue( users_can_register_signup_filter() );
- update_site_option('registration', 'none');
- $this->assertFalse( users_can_register_signup_filter() );
- }
- /**
- * @expectedDeprecated get_dashboard_blog
- */
- function test_get_dashboard_blog() {
- // if there is no dashboard blog set, current blog is used
- $dashboard_blog = get_dashboard_blog();
- $this->assertEquals( 1, $dashboard_blog->blog_id );
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id ) );
- $this->assertInternalType( 'int', $blog_id );
- // set the dashboard blog to another one
- update_site_option( 'dashboard_blog', $blog_id );
- $dashboard_blog = get_dashboard_blog();
- $this->assertEquals( $blog_id, $dashboard_blog->blog_id );
- }
- function test_wpmu_log_new_registrations() {
- global $wpdb;
- $user = new WP_User( 1 );
- $ip = preg_replace( '/[^0-9., ]/', '',$_SERVER['REMOTE_ADDR'] );
- wpmu_log_new_registrations(1,1);
- // currently there is no wrapper function for the registration_log
- $reg_blog = $wpdb->get_col( "SELECT email FROM {$wpdb->registration_log} WHERE {$wpdb->registration_log}.blog_id = 1 AND IP LIKE '" . $ip . "'" );
- $this->assertEquals( $user->user_email, $reg_blog[ count( $reg_blog )-1 ] );
- }
- /**
- * @ticket 18119
- */
- function test_upload_is_user_over_quota() {
- $default_space_allowed = 100;
- $echo = false;
- $this->assertFalse( upload_is_user_over_quota( $echo ) );
- $this->assertTrue( is_upload_space_available() );
- update_site_option('upload_space_check_disabled', true);
- $this->assertFalse( upload_is_user_over_quota( $echo ) );
- $this->assertTrue( is_upload_space_available() );
- update_site_option( 'blog_upload_space', 0 );
- $this->assertFalse( upload_is_user_over_quota( $echo ) );
- $this->assertEquals( $default_space_allowed, get_space_allowed() );
- $this->assertTrue( is_upload_space_available() );
- update_site_option('upload_space_check_disabled', false);
- $this->assertFalse( upload_is_user_over_quota( $echo ) );
- $this->assertTrue( is_upload_space_available() );
- if ( defined( 'BLOGSUPLOADDIR' ) && ! file_exists( BLOGSUPLOADDIR ) )
- $this->markTestSkipped( 'This test is broken when blogs.dir does not exist. ');
- /*
- This is broken when blogs.dir does not exist, as get_upload_space_available()
- simply returns the value of blog_upload_space (converted to bytes), which would
- be negative but still not false. When blogs.dir does exist, < 0 is returned as 0.
- */
- update_site_option( 'blog_upload_space', -1 );
- $this->assertTrue( upload_is_user_over_quota( $echo ) );
- $this->assertEquals( -1, get_space_allowed() );
- $this->assertFalse( is_upload_space_available() );
- update_option( 'blog_upload_space', 0 );
- $this->assertFalse( upload_is_user_over_quota( $echo ) );
- $this->assertEquals( $default_space_allowed, get_space_allowed() );
- $this->assertTrue( is_upload_space_available() );
- update_option( 'blog_upload_space', -1 );
- $this->assertTrue( upload_is_user_over_quota( $echo ) );
- $this->assertEquals( -1, get_space_allowed() );
- $this->assertFalse( is_upload_space_available() );
- }
- function test_wpmu_update_blogs_date() {
- global $wpdb;
- wpmu_update_blogs_date();
- // compare the update time with the current time, allow delta < 2
- $blog = get_blog_details( $wpdb->blogid );
- $current_time = time();
- $time_difference = $current_time - strtotime( $blog->last_updated );
- $this->assertLessThan( 2, $time_difference );
- }
- function test_getters(){
- global $current_site;
- $blog_id = get_current_blog_id();
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( $blog_id, $blog->blog_id );
- $this->assertEquals( $current_site->domain, $blog->domain );
- $this->assertEquals( '/', $blog->path );
- // Test defaulting to current blog
- $this->assertEquals( $blog, get_blog_details() );
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id, 'path' => '/test_blogname', 'title' => 'Test Title' ) );
- $this->assertInternalType( 'int', $blog_id );
- $this->assertEquals( 'http://' . DOMAIN_CURRENT_SITE . PATH_CURRENT_SITE . 'test_blogname/', get_blogaddress_by_name('test_blogname') );
- $this->assertEquals( $blog_id, get_id_from_blogname('test_blogname') );
- }
- function _action_counter_cb( $blog_id ) {
- global $test_action_counter;
- $test_action_counter++;
- }
- function test_update_blog_details() {
- global $test_action_counter;
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id, 'path' => '/test_blogpath', 'title' => 'Test Title' ) );
- $this->assertInternalType( 'int', $blog_id );
- $result = update_blog_details( $blog_id, array('domain' => 'example.com', 'path' => 'my_path/') );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( 'example.com', $blog->domain );
- $this->assertEquals( 'my_path/', $blog->path );
- $this->assertEquals( '0', $blog->spam );
- $result = update_blog_details( $blog_id, array('domain' => 'example2.com','spam' => 1) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( 'example2.com', $blog->domain );
- $this->assertEquals( 'my_path/', $blog->path );
- $this->assertEquals( '1', $blog->spam );
- $result = update_blog_details( $blog_id );
- $this->assertFalse( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( 'example2.com', $blog->domain );
- $this->assertEquals( 'my_path/', $blog->path );
- $this->assertEquals( '1', $blog->spam );
- $test_action_counter = 0;
- add_action( 'make_ham_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_details( $blog_id, array( 'spam' => 0 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->spam );
- $this->assertEquals( 1, $test_action_counter );
- // Same again
- $result = update_blog_details( $blog_id, array( 'spam' => 0 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->spam );
- $this->assertEquals( 1, $test_action_counter );
- remove_action( 'make_ham_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'make_spam_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_details( $blog_id, array( 'spam' => 1 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->spam );
- $this->assertEquals( 2, $test_action_counter );
- // Same again
- $result = update_blog_details( $blog_id, array( 'spam' => 1 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->spam );
- $this->assertEquals( 2, $test_action_counter );
- remove_action( 'make_spam_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'archive_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_details( $blog_id, array( 'archived' => 1 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->archived );
- $this->assertEquals( 3, $test_action_counter );
- // Same again
- $result = update_blog_details( $blog_id, array( 'archived' => 1 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->archived );
- $this->assertEquals( 3, $test_action_counter );
- remove_action( 'archive_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'unarchive_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_details( $blog_id, array( 'archived' => 0 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->archived );
- $this->assertEquals( 4, $test_action_counter );
- // Same again
- $result = update_blog_details( $blog_id, array( 'archived' => 0 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->archived );
- $this->assertEquals( 4, $test_action_counter );
- remove_action( 'unarchive_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'make_delete_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_details( $blog_id, array( 'deleted' => 1 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->deleted );
- $this->assertEquals( 5, $test_action_counter );
- // Same again
- $result = update_blog_details( $blog_id, array( 'deleted' => 1 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->deleted );
- $this->assertEquals( 5, $test_action_counter );
- remove_action( 'make_delete_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'make_undelete_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_details( $blog_id, array( 'deleted' => 0 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->deleted );
- $this->assertEquals( 6, $test_action_counter );
- // Same again
- $result = update_blog_details( $blog_id, array( 'deleted' => 0 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->deleted );
- $this->assertEquals( 6, $test_action_counter );
- remove_action( 'make_undelete_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'mature_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_details( $blog_id, array( 'mature' => 1 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->mature );
- $this->assertEquals( 7, $test_action_counter );
- // Same again
- $result = update_blog_details( $blog_id, array( 'mature' => 1 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->mature );
- $this->assertEquals( 7, $test_action_counter );
- remove_action( 'mature_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'unmature_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_details( $blog_id, array( 'mature' => 0 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->mature );
- $this->assertEquals( 8, $test_action_counter );
- // Same again
- $result = update_blog_details( $blog_id, array( 'mature' => 0 ) );
- $this->assertTrue( $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->mature );
- $this->assertEquals( 8, $test_action_counter );
- remove_action( 'unmature_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- }
- /**
- * Test fetching a blog that doesn't exist and again after it exists.
- *
- * @ticket 23405
- */
- function test_get_blog_details_blog_does_not_exist() {
- global $wpdb;
- $blog_id = $wpdb->get_var( "SELECT MAX(blog_id) FROM $wpdb->blogs" );
- // An idosyncrancy of the unit tests is that the max blog_id gets reset
- // to 1 in between test cases but picks up where it previously left off
- // on the next insert. If 1 is reported, burn a blog create to get
- // the max counter back in sync.
- if ( 1 == $blog_id ) {
- $blog_id = $this->factory->blog->create();
- }
- $blog_id++;
- $this->assertFalse( wp_cache_get( $blog_id, 'blog-details' ) );
- $this->assertFalse( get_blog_details( $blog_id ) );
- $this->assertEquals( -1, wp_cache_get( $blog_id, 'blog-details' ) );
- $this->assertFalse( get_blog_details( $blog_id ) );
- $this->assertEquals( -1, wp_cache_get( $blog_id, 'blog-details' ) );
- $this->assertEquals( $blog_id, $this->factory->blog->create() );
- $this->assertFalse( wp_cache_get( $blog_id, 'blog-details' ) );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( $blog_id, $blog->blog_id );
- $this->assertEquals( $blog, wp_cache_get( $blog_id, 'blog-details' ) );
- wpmu_delete_blog( $blog_id );
- $this->assertFalse( wp_cache_get( $blog_id, 'blog-details' ) );
- $blog->deleted = '1';
- $this->assertEQuals( $blog, get_blog_details( $blog_id ) );
- $this->assertEquals( $blog, wp_cache_get( $blog_id, 'blog-details' ) );
- wpmu_delete_blog( $blog_id, true );
- $this->assertFalse( get_blog_details( $blog_id ) );
- $this->assertEquals( -1, wp_cache_get( $blog_id, 'blog-details' ) );
- }
- function test_update_blog_status() {
- global $test_action_counter;
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id, 'path' => '/test_blogpath', 'title' => 'Test Title' ) );
- $this->assertInternalType( 'int', $blog_id );
- $test_action_counter = 0;
- $count = 1;
- add_action( 'make_ham_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_status( $blog_id, 'spam', 0 );
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->spam );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $count++;
- $result = update_blog_status( $blog_id, 'spam', 0 );
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->spam );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'make_ham_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $count++;
- add_action( 'make_spam_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $result = update_blog_status( $blog_id, 'spam', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->spam );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $count++;
- $result = update_blog_status( $blog_id, 'spam', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->spam );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'make_spam_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'archive_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $count++;
- $result = update_blog_status( $blog_id, 'archived', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->archived );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $count++;
- $result = update_blog_status( $blog_id, 'archived', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->archived );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'archive_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'unarchive_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $count++;
- $result = update_blog_status( $blog_id, 'archived', 0 );
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->archived );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $result = update_blog_status( $blog_id, 'archived', 0 );
- $count++;
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->archived );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'unarchive_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'make_delete_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $count++;
- $result = update_blog_status( $blog_id, 'deleted', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->deleted );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $count++;
- $result = update_blog_status( $blog_id, 'deleted', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->deleted );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'make_delete_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'make_undelete_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $count++;
- $result = update_blog_status( $blog_id, 'deleted', 0 );
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->deleted );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $count++;
- $result = update_blog_status( $blog_id, 'deleted', 0 );
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->deleted );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'make_undelete_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'mature_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $count++;
- $result = update_blog_status( $blog_id, 'mature', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->mature );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $count++;
- $result = update_blog_status( $blog_id, 'mature', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->mature );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'mature_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'unmature_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- $count++;
- $result = update_blog_status( $blog_id, 'mature', 0 );
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->mature );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $count++;
- $result = update_blog_status( $blog_id, 'mature', 0 );
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->mature );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'unmature_blog', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'update_blog_public', array( $this, '_action_counter_cb' ), 10, 1 );
- $count++;
- $result = update_blog_status( $blog_id, 'public', 0 );
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->public );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $count++;
- $result = update_blog_status( $blog_id, 'public', 0 );
- $this->assertEquals( 0, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '0', $blog->public );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'update_blog_public', array( $this, '_action_counter_cb' ), 10, 1 );
- add_action( 'update_blog_public', array( $this, '_action_counter_cb' ), 10, 1 );
- $count++;
- $result = update_blog_status( $blog_id, 'public', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->public );
- $this->assertEquals( $count, $test_action_counter );
- // Same again
- $count++;
- $result = update_blog_status( $blog_id, 'public', 1 );
- $this->assertEquals( 1, $result );
- $blog = get_blog_details( $blog_id );
- $this->assertEquals( '1', $blog->public );
- $this->assertEquals( $count, $test_action_counter );
- remove_action( 'update_blog_public', array( $this, '_action_counter_cb' ), 10, 1 );
- // Updating a dummy field returns the value passed. Go fig.
- $result = update_blog_status( $blog_id, 'doesnotexist', 1 );
- $this->assertEquals( 1, $result );
- }
- function test_switch_restore_blog() {
- global $_wp_switched_stack, $wpdb;
- $this->assertEquals( array(), $_wp_switched_stack );
- $this->assertFalse( ms_is_switched() );
- $current_blog_id = get_current_blog_id();
- $this->assertInternalType( 'integer', $current_blog_id );
- wp_cache_set( 'switch-test', $current_blog_id, 'switch-test' );
- $this->assertEquals( $current_blog_id, wp_cache_get( 'switch-test', 'switch-test' ) );
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id, 'path' => '/test_blogpath', 'title' => 'Test Title' ) );
- $cap_key = wp_get_current_user()->cap_key;
- switch_to_blog( $blog_id );
- $this->assertNotEquals( $cap_key, wp_get_current_user()->cap_key );
- $this->assertEquals( array( $current_blog_id ), $_wp_switched_stack );
- $this->assertTrue( ms_is_switched() );
- $this->assertEquals( $blog_id, $wpdb->blogid );
- $this->assertFalse( wp_cache_get( 'switch-test', 'switch-test' ) );
- wp_cache_set( 'switch-test', $blog_id, 'switch-test' );
- $this->assertEquals( $blog_id, wp_cache_get( 'switch-test', 'switch-test' ) );
- switch_to_blog( $blog_id );
- $this->assertEquals( array( $current_blog_id, $blog_id ), $_wp_switched_stack );
- $this->assertTrue( ms_is_switched() );
- $this->assertEquals( $blog_id, $wpdb->blogid );
- $this->assertEquals( $blog_id, wp_cache_get( 'switch-test', 'switch-test' ) );
- restore_current_blog();
- $this->assertEquals( array( $current_blog_id ), $_wp_switched_stack );
- $this->assertTrue( ms_is_switched() );
- $this->assertEquals( $blog_id, $wpdb->blogid );
- $this->assertEquals( $blog_id, wp_cache_get( 'switch-test', 'switch-test' ) );
- restore_current_blog();
- $this->assertEquals( $cap_key, wp_get_current_user()->cap_key );
- $this->assertEquals( $current_blog_id, get_current_blog_id() );
- $this->assertEquals( array(), $_wp_switched_stack );
- $this->assertFalse( ms_is_switched() );
- $this->assertEquals( $current_blog_id, wp_cache_get( 'switch-test', 'switch-test' ) );
- $this->assertFalse( restore_current_blog() );
- }
- function test_get_blog_post() {
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id, 'path' => '/test_blogpath', 'title' => 'Test Title' ) );
- $current_blog_id = get_current_blog_id();
- $post_id = $this->factory->post->create();
- $this->assertInstanceOf( 'WP_Post', get_post( $post_id ) );
- switch_to_blog( $blog_id );
- $this->assertNull( get_post( $post_id ) );
- $post = get_blog_post( $current_blog_id, $post_id );
- $this->assertInstanceOf( 'WP_Post', $post );
- $this->assertEquals( $post_id, $post->ID );
- restore_current_blog();
- wp_update_post( array( 'ID' => $post_id, 'post_title' => 'A Different Title' ) );
- switch_to_blog( $blog_id );
- $post = get_blog_post( $current_blog_id, $post_id );
- // Make sure cache is good
- $this->assertEquals( 'A Different Title', $post->post_title );
- $post_id2 = $this->factory->post->create();
- // Test get_blog_post() with currently active blog ID.
- $post = get_blog_post( $blog_id, $post_id2 );
- $this->assertInstanceOf( 'WP_Post', $post );
- $this->assertEquals( $post_id2, $post->ID );
- restore_current_blog();
- }
- /**
- * @ticket 21570
- */
- function test_aggressiveness_of_is_email_address_unsafe() {
- update_site_option( 'banned_email_domains', array( 'bar.com', 'foo.co' ) );
- foreach ( array( 'test@bar.com', 'test@foo.bar.com', 'test@foo.co', 'test@subdomain.foo.co' ) as $email_address ) {
- $this->assertTrue( is_email_address_unsafe( $email_address ), "$email_address should be UNSAFE" );
- }
- foreach ( array( 'test@foobar.com', 'test@foo-bar.com', 'test@foo.com', 'test@subdomain.foo.com' ) as $email_address ) {
- $this->assertFalse( is_email_address_unsafe( $email_address ), "$email_address should be SAFE" );
- }
- }
- /**
- * @ticket 25046
- */
- function test_case_sensitivity_of_is_email_address_unsafe() {
- update_site_option( 'banned_email_domains', array( 'baR.com', 'Foo.co', 'barfoo.COM', 'BAZ.com' ) );
- foreach ( array( 'test@Bar.com', 'tEst@bar.com', 'test@barFoo.com', 'tEst@foo.bar.com', 'test@baz.Com' ) as $email_address ) {
- $this->assertTrue( is_email_address_unsafe( $email_address ), "$email_address should be UNSAFE" );
- }
- foreach ( array( 'test@Foobar.com', 'test@Foo-bar.com', 'tEst@foobar.com', 'test@Subdomain.Foo.com', 'test@fooBAz.com' ) as $email_address ) {
- $this->assertFalse( is_email_address_unsafe( $email_address ), "$email_address should be SAFE" );
- }
- }
- /**
- * @ticket 21552
- * @ticket 23418
- */
- function test_sanitize_ms_options() {
- update_site_option( 'illegal_names', array( '', 'Woo', '' ) );
- update_site_option( 'limited_email_domains', array( 'woo', '', 'boo.com', 'foo.net.biz..' ) );
- update_site_option( 'banned_email_domains', array( 'woo', '', 'boo.com', 'foo.net.biz..' ) );
- $this->assertEquals( array( 'Woo' ), get_site_option( 'illegal_names' ) );
- $this->assertEquals( array( 'woo', 'boo.com' ), get_site_option( 'limited_email_domains' ) );
- $this->assertEquals( array( 'woo', 'boo.com' ), get_site_option( 'banned_email_domains' ) );
- update_site_option( 'illegal_names', 'foo bar' );
- update_site_option( 'limited_email_domains', "foo\nbar" );
- update_site_option( 'banned_email_domains', "foo\nbar" );
- $this->assertEquals( array( 'foo', 'bar' ), get_site_option( 'illegal_names' ) );
- $this->assertEquals( array( 'foo', 'bar' ), get_site_option( 'limited_email_domains' ) );
- $this->assertEquals( array( 'foo', 'bar' ), get_site_option( 'banned_email_domains' ) );
- foreach ( array( 'illegal_names', 'limited_email_domains', 'banned_email_domains' ) as $option ) {
- update_site_option( $option, array() );
- $this->assertSame( '', get_site_option( $option ) );
- }
- }
- function _domain_exists_cb( $exists, $domain, $path, $site_id ) {
- if ( 'foo' == $domain && 'bar' == $path )
- return 1234;
- else
- return null;
- }
- function test_domain_exists() {
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id, 'path' => '/testdomainexists', 'title' => 'Test Title' ) );
- $details = get_blog_details( $blog_id, false );
- $this->assertEquals( $blog_id, domain_exists( $details->domain, $details->path ) );
- $this->assertEquals( $blog_id, domain_exists( $details->domain, $details->path, $details->site_id ) );
- $this->assertEquals( null, domain_exists( $details->domain, $details->path, 999 ) );
- $this->assertEquals( null, domain_exists( 'foo', 'bar' ) );
- add_filter( 'domain_exists', array( $this, '_domain_exists_cb' ), 10, 4 );
- $this->assertEquals( 1234, domain_exists( 'foo', 'bar' ) );
- $this->assertEquals( null, domain_exists( 'foo', 'baz' ) );
- $this->assertEquals( null, domain_exists( 'bar', 'foo' ) );
- remove_filter( 'domain_exists', array( $this, '_domain_exists_cb' ), 10, 4 );
- $this->assertEquals( null, domain_exists( 'foo', 'bar' ) );
- wpmu_delete_blog( $blog_id );
- $this->assertEquals( $blog_id, domain_exists( $details->domain, $details->path ) );
- wpmu_delete_blog( $blog_id, true );
- $this->assertEquals( null, domain_exists( $details->domain, $details->path ) );
- }
- function test_get_blog_id_from_url() {
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id, 'path' => '/testdomainexists', 'title' => 'Test Title' ) );
- $details = get_blog_details( $blog_id, false );
- $this->assertEquals( $blog_id, get_blog_id_from_url( $details->domain, $details->path ) );
- $key = md5( $details->domain . $details->path );
- $this->assertEquals( $blog_id, wp_cache_get( $key, 'blog-id-cache' ) );
- $this->assertEquals( 0, get_blog_id_from_url( $details->domain, 'foo' ) );
- wpmu_delete_blog( $blog_id );
- $this->assertEquals( $blog_id, get_blog_id_from_url( $details->domain, $details->path ) );
- wpmu_delete_blog( $blog_id, true );
- $this->assertEquals( false, wp_cache_get( $key, 'blog-id-cache' ) );
- $this->assertEquals( 0, get_blog_id_from_url( $details->domain, $details->path ) );
- }
- function test_is_main_site() {
- $this->assertTrue( is_main_site() );
- $this->assertTrue( is_main_site( get_current_blog_id() ) );
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id ) );
- switch_to_blog( $blog_id );
- $this->assertFalse( is_main_site( $blog_id ) );
- $this->assertFalse( is_main_site( get_current_blog_id() ) );
- $this->assertFalse( is_main_site() );
- restore_current_blog();
- }
- function test_switch_upload_dir() {
- $this->assertTrue( is_main_site() );
- $site = get_current_site();
- $info = wp_upload_dir();
- $this->assertEquals( 'http://' . $site->domain . '/wp-content/uploads/' . gmstrftime('%Y/%m'), $info['url'] );
- $this->assertEquals( ABSPATH . 'wp-content/uploads/' . gmstrftime('%Y/%m'), $info['path'] );
- $this->assertEquals( gmstrftime('/%Y/%m'), $info['subdir'] );
- $this->assertEquals( '', $info['error'] );
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id = $this->factory->blog->create( array( 'user_id' => $user_id ) );
- switch_to_blog( $blog_id );
- $info = wp_upload_dir();
- $this->assertEquals( 'http://' . $site->domain . '/wp-content/uploads/sites/' . get_current_blog_id() . '/' . gmstrftime('%Y/%m'), $info['url'] );
- $this->assertEquals( ABSPATH . 'wp-content/uploads/sites/' . get_current_blog_id() . '/' . gmstrftime('%Y/%m'), $info['path'] );
- $this->assertEquals( gmstrftime('/%Y/%m'), $info['subdir'] );
- $this->assertEquals( '', $info['error'] );
- restore_current_blog();
- $info = wp_upload_dir();
- $this->assertEquals( 'http://' . $site->domain . '/wp-content/uploads/' . gmstrftime('%Y/%m'), $info['url'] );
- $this->assertEquals( ABSPATH . 'wp-content/uploads/' . gmstrftime('%Y/%m'), $info['path'] );
- $this->assertEquals( gmstrftime('/%Y/%m'), $info['subdir'] );
- $this->assertEquals( '', $info['error'] );
- update_site_option( 'ms_files_rewriting', 1 );
- ms_upload_constants();
- $user_id = $this->factory->user->create( array( 'role' => 'administrator' ) );
- $blog_id2 = $this->factory->blog->create( array( 'user_id' => $user_id ) );
- $info = wp_upload_dir();
- $this->assertEquals( 'http://' . $site->domain . '/wp-content/uploads/' . gmstrftime('%Y/%m'), $info['url'] );
- $this->assertEquals( ABSPATH . 'wp-content/uploads/' . gmstrftime('%Y/%m'), $info['path'] );
- $this->assertEquals( gmstrftime('/%Y/%m'), $info['subdir'] );
- $this->assertEquals( '', $info['error'] );
- switch_to_blog( $blog_id2 );
- $info2 = wp_upload_dir();
- $this->assertNotEquals( $info, $info2 );
- $this->assertEquals( get_option( 'siteurl' ) . '/wp-content/blogs.dir/' . get_current_blog_id() . '/files/' . gmstrftime('%Y/%m'), $info2['url'] );
- $this->assertEquals( ABSPATH . 'wp-content/blogs.dir/' . get_current_blog_id() . '/files/' . gmstrftime('%Y/%m'), $info2['path'] );
- $this->assertEquals( gmstrftime('/%Y/%m'), $info2['subdir'] );
- $this->assertEquals( '', $info2['error'] );
- restore_current_blog();
- update_site_option( 'ms_files_rewriting', 0 );
- }
- /**
- * @ticket 23192
- */
- function test_is_user_spammy() {
- $user_id = $this->factory->user->create( array(
- 'role' => 'author',
- 'user_login' => 'testuser1',
- ) );
- $spam_username = (string) $user_id;
- $spam_user_id = $this->factory->user->create( array(
- 'role' => 'author',
- 'user_login' => $spam_username,
- ) );
- update_user_status( $spam_user_id, 'spam', '1' );
- $this->assertTrue( is_user_spammy( $spam_username ) );
- $this->assertFalse( is_user_spammy( 'testuser1' ) );
- }
- /**
- * @ticket 14511
- */
- function test_wp_get_sites() {
- $this->factory->blog->create_many( 2, array( 'site_id' => 2, 'meta' => array( 'public' => 1 ) ) );
- $this->factory->blog->create_many( 3, array( 'site_id' => 3, 'meta' => array( 'public' => 0 ) ) );
- // Expect no sites when passed an invalid network_id
- $this->assertCount( 0, wp_get_sites( array( 'network_id' => 0 ) ) );
- $this->assertCount( 0, wp_get_sites( array( 'network_id' => 4 ) ) );
- // Expect 1 site when no network_id is specified - defaults to current network.
- $this->assertCount( 1, wp_get_sites() );
- // Expect 6 sites when network_id = null.
- $this->assertCount( 6, wp_get_sites( array( 'network_id' => null ) ) );
- // Expect 1 site with a network_id of 1, 2 for network_id 2, 3 for 3
- $this->assertCount( 1, wp_get_sites( array( 'network_id' => 1 ) ) );
- $this->assertCount( 2, wp_get_sites( array( 'network_id' => 2 ) ) );
- $this->assertCount( 3, wp_get_sites( array( 'network_id' => 3 ) ) );
- // Expect 6 sites when public is null (across all networks)
- $this->assertCount( 6, wp_get_sites( array( 'public' => null, 'network_id' => null ) ) );
- // Expect 3 sites when public is 1
- $this->assertCount( 3, wp_get_sites( array( 'public' => 1, 'network_id' => null ) ) );
- // Expect 2 sites when public is 1 and network_id is 2
- $this->assertCount( 2, wp_get_sites( array( 'network_id' => 2, 'public' => 1 ) ) );
- // Expect no sites when public is set to 0 and network_id is not 3
- $this->assertCount( 0, wp_get_sites( array( 'network_id' => 1, 'public' => 0 ) ) );
- // Test public + network_id = 3
- $this->assertCount( 0, wp_get_sites( array( 'network_id' => 3, 'public' => 1 ) ) );
- $this->assertCount( 3, wp_get_sites( array( 'network_id' => 3, 'public' => 0 ) ) );
- }
- /**
- * @ticket 14511
- */
- function test_wp_get_sites_limit_offset() {
- // Create 4 more sites (in addition to the default one)
- $this->factory->blog->create_many( 4, array( 'meta' => array( 'public' => 1 ) ) );
- // Expect all 5 sites when no limit/offset is specified
- $this->assertCount( 5, wp_get_sites() );
- // Expect first 2 sites when using limit
- $this->assertCount( 2, wp_get_sites( array( 'limit' => 2 ) ) );
- // Expect only the last 3 sites when using offset of 2 (limit will default to 100)
- $this->assertCount( 3, wp_get_sites( array( 'offset' => 2 ) ) );
- // Expect only the last 1 site when using offset of 4 and limit of 2
- $this->assertCount( 1, wp_get_sites( array( 'limit' => 2, 'offset' => 4 ) ) );
- // Expect 0 sites when using an offset larger than the number of sites
- $this->assertCount( 0, wp_get_sites( array( 'offset' => 20 ) ) );
- }
- }
- endif;
|