1 | Index: src/wp-includes/functions.php |
---|
2 | =================================================================== |
---|
3 | --- src/wp-includes/functions.php (revision 38147) |
---|
4 | +++ src/wp-includes/functions.php (working copy) |
---|
5 | @@ -4154,7 +4154,7 @@ |
---|
6 | |
---|
7 | // The request is for the admin |
---|
8 | if ( strpos( $_SERVER['REQUEST_URI'], 'wp-admin' ) !== false || strpos( $_SERVER['REQUEST_URI'], 'wp-login.php' ) !== false ) { |
---|
9 | - $path = preg_replace( '#/(wp-admin/.*|wp-login.php)#i', '', $_SERVER['REQUEST_URI'] ); |
---|
10 | + $path = preg_replace( '#/(wp-admin/?.*|wp-login\.php.*)#i', '', $_SERVER['REQUEST_URI'] ); |
---|
11 | |
---|
12 | // The request is for a file in ABSPATH |
---|
13 | } elseif ( $script_filename_dir . '/' == $abspath_fix ) { |
---|
14 | Index: tests/phpunit/tests/includes/helpers.php |
---|
15 | =================================================================== |
---|
16 | --- tests/phpunit/tests/includes/helpers.php (revision 38147) |
---|
17 | +++ tests/phpunit/tests/includes/helpers.php (working copy) |
---|
18 | @@ -212,4 +212,26 @@ |
---|
19 | public function test_die_handler_should_handle_wp_error() { |
---|
20 | wp_die( new WP_Error( 'test', 'test' ) ); |
---|
21 | } |
---|
22 | + |
---|
23 | + |
---|
24 | + function data_guessUrlTestCases() { |
---|
25 | + return array( |
---|
26 | + ['wp-admin'], |
---|
27 | + ['wp-admin/'], |
---|
28 | + ['wp-admin/?foo=bar'], |
---|
29 | + ['wp-login.php'], |
---|
30 | + ['wp-login.php?foo=bar'] |
---|
31 | + ); |
---|
32 | + } |
---|
33 | + |
---|
34 | + /** |
---|
35 | + * @dataProvider data_guessUrlTestCases |
---|
36 | + * @ticket 36827 |
---|
37 | + */ |
---|
38 | + public function test_guessUrlShouldHandleEdgecases( $url ) { |
---|
39 | + $siteurl = site_url(); |
---|
40 | + $this->go_to( site_url( $url ) ); |
---|
41 | + $this->assertEquals($siteurl, wp_guess_url()); |
---|
42 | + } |
---|
43 | + |
---|
44 | } |
---|