Make WordPress Core

Ticket #20601: 20601.7.diff

File 20601.7.diff, 2.3 KB (added by wonderboymusic, 10 years ago)
  • src/wp-includes/class-wp.php

     
    568568                // We will 404 for paged queries, as no posts were found.
    569569                if ( ! is_paged() ) {
    570570
     571                        // Don't 404 for authors without posts as long as they matched an author on this site.
     572                        $author = get_query_var( 'author' );
     573                        if ( is_author() && is_numeric( $author ) && $author > 0 && is_user_member_of_blog( $author ) ) {
     574                                status_header( 200 );
     575                                return;
     576                        }
     577
    571578                        // Don't 404 for these queries if they matched an object.
    572                         if ( ( is_tag() || is_category() || is_tax() || is_author() || is_post_type_archive() ) && $wp_query->get_queried_object() ) {
     579                        if ( ( is_tag() || is_category() || is_tax() || is_post_type_archive() ) && get_queried_object() ) {
    573580                                status_header( 200 );
    574581                                return;
    575582                        }
  • tests/phpunit/tests/ms.php

     
    11721172                // Expect 0 sites when using an offset larger than the number of sites
    11731173                $this->assertCount( 0, wp_get_sites( array( 'offset' => 20 ) ) );
    11741174        }
     1175
     1176        /**
     1177         * @ticket 20601
     1178         */
     1179        function test_user_member_of_blog() {
     1180                $this->factory->blog->create();
     1181                $user_id = $this->factory->user->create();
     1182                $this->factory->blog->create( array( 'user_id' => $user_id ) );
     1183
     1184                $blogs = get_blogs_of_user( $user_id );
     1185                $this->assertCount( 2, $blogs );
     1186                $first = reset( $blogs )->userblog_id;
     1187                remove_user_from_blog( $user_id, $first );
     1188
     1189                $blogs = get_blogs_of_user( $user_id );
     1190                $second = reset( $blogs )->userblog_id;
     1191                $this->assertCount( 1, $blogs );
     1192
     1193                switch_to_blog( $first );
     1194
     1195                $this->go_to( get_author_posts_url( $user_id ) );
     1196                $this->assertQueryTrue( 'is_404' );
     1197
     1198                switch_to_blog( $second );
     1199
     1200                $this->go_to( get_author_posts_url( $user_id ) );
     1201                $this->assertQueryTrue( 'is_author', 'is_archive' );
     1202
     1203                add_user_to_blog( $first, $user_id, 'administrator' );
     1204                $blogs = get_blogs_of_user( $user_id );
     1205                $this->assertCount( 2, $blogs );
     1206
     1207                switch_to_blog( $first );
     1208
     1209                $this->go_to( get_author_posts_url( $user_id ) );
     1210                $this->assertQueryTrue( 'is_author', 'is_archive' );
     1211        }
    11751212}
    11761213
    11771214endif;