Make WordPress Core

Changeset 50088


Ignore:
Timestamp:
01/30/2021 11:29:34 AM (4 years ago)
Author:
SergeyBiryukov
Message:

Tests: Use skipTestOnTimeout() in more HTTP tests.

Adjust it to handle more types of timeouts, e.g. "Resolving timed out", "Connection timed out".

Merges [43511], [43512], [46682], [46996] to the 4.7 branch.
See #51669.

Location:
branches/4.7
Files:
5 edited

Legend:

Unmodified
Added
Removed
  • branches/4.7

  • branches/4.7/tests/phpunit/includes/testcase.php

    r41305 r50088  
    178178
    179179    /**
    180      * Allow tests to be skipped on some automated runs
     180     * Allow tests to be skipped on some automated runs.
    181181     *
    182182     * For test runs on Travis for something other than trunk/master
     
    233233            _unregister_post_status( $post_status );
    234234        }
     235    }
     236
     237    /**
     238     * Allow tests to be skipped if the HTTP request times out.
     239     *
     240     * @param array|WP_Error $response HTTP response.
     241     */
     242    public function skipTestOnTimeout( $response ) {
     243        if ( ! is_wp_error( $response ) ) {
     244            return;
     245        }
     246        if ( 'connect() timed out!' === $response->get_error_message() ) {
     247            $this->markTestSkipped( 'HTTP timeout' );
     248        }
     249
     250        if ( false !== strpos( $response->get_error_message(), 'timed out after' ) ) {
     251            $this->markTestSkipped( 'HTTP timeout' );
     252        }
     253
     254        if ( 0 === strpos( $response->get_error_message(), 'stream_socket_client(): unable to connect to tcp://s.w.org:80' ) ) {
     255            $this->markTestSkipped( 'HTTP timeout' );
     256        }
     257
    235258    }
    236259
  • branches/4.7/tests/phpunit/tests/external-http/basic.php

    r42100 r50088  
    1010
    1111        $readme = file_get_contents( ABSPATH . 'readme.html' );
     12
    1213        preg_match( '#Recommendations.*PHP</a> version <strong>([0-9.]*)#s', $readme, $matches );
    1314
    1415        $response = wp_remote_get( 'https://secure.php.net/supported-versions.php' );
    15         if ( 200 != wp_remote_retrieve_response_code( $response ) ) {
    16             $this->markTestSkipped( 'Could not contact PHP.net to check versions.' );
     16
     17        $this->skipTestOnTimeout( $response );
     18
     19        $response_code = wp_remote_retrieve_response_code( $response );
     20        if ( 200 !== $response_code ) {
     21            $this->fail( sprintf( 'Could not contact PHP.net to check versions. Response code: %s', $response_code ) );
    1722        }
     23
    1824        $php = wp_remote_retrieve_body( $response );
    1925
     
    2531
    2632        $response = wp_remote_get( "https://dev.mysql.com/doc/relnotes/mysql/{$matches[1]}/en/" );
    27         if ( 200 != wp_remote_retrieve_response_code( $response ) ) {
    28             $this->markTestSkipped( 'Could not contact dev.MySQL.com to check versions.' );
     33
     34        $this->skipTestOnTimeout( $response );
     35
     36        $response_code = wp_remote_retrieve_response_code( $response );
     37        if ( 200 !== $response_code ) {
     38            $this->fail( sprintf( 'Could not contact dev.MySQL.com to check versions. Response code: %s', $response_code ) );
    2939        }
     40
    3041        $mysql = wp_remote_retrieve_body( $response );
    3142
  • branches/4.7/tests/phpunit/tests/http/base.php

    r39174 r50088  
    1818    protected $http_request_args;
    1919
    20     /**
    21      * Mark test as skipped if the HTTP request times out
    22      */
    23     function skipTestOnTimeout( $response ) {
    24         if( ! is_wp_error( $response ) ){
    25             return;
    26         }
    27         if ( 'connect() timed out!' === $response->get_error_message() ){
    28             $this->markTestSkipped( 'HTTP timeout' );
    29         }
    30 
    31         if ( 0 === strpos( $response->get_error_message(), 'Operation timed out after' ) ){
    32             $this->markTestSkipped( 'HTTP timeout' );
    33         }
    34 
    35         if ( 0 === strpos( $response->get_error_message(), 'stream_socket_client(): unable to connect to tcp://s.w.org:80' ) ) {
    36             $this->markTestSkipped( 'HTTP timeout' );
    37         }
    38 
    39     }
    40 
    4120    function setUp() {
    4221
     
    7453        // 5 : 5 & 301
    7554        $res = wp_remote_request($this->redirection_script . '?code=301&rt=' . 5, array('redirection' => 5) );
     55
     56        $this->skipTestOnTimeout( $res );
    7657        $this->assertNotWPError( $res );
    7758        $this->assertEquals(200, (int)$res['response']['code'] );
     
    8162        // 5 : 5 & 302
    8263        $res = wp_remote_request($this->redirection_script . '?code=302&rt=' . 5, array('redirection' => 5) );
     64
     65        $this->skipTestOnTimeout( $res );
    8366        $this->assertNotWPError( $res );
    8467        $this->assertEquals(200, (int)$res['response']['code'] );
     
    9174        // 5 > 0 & 301
    9275        $res = wp_remote_request($this->redirection_script . '?code=301&rt=' . 5, array('redirection' => 0) );
     76
     77        $this->skipTestOnTimeout( $res );
    9378        $this->assertNotWPError( $res );
    9479        $this->assertEquals(301, (int)$res['response']['code'] );
     
    10186        // 5 > 0 & 302
    10287        $res = wp_remote_request($this->redirection_script . '?code=302&rt=' . 5, array('redirection' => 0) );
     88
     89        $this->skipTestOnTimeout( $res );
    10390        $this->assertNotWPError( $res );
    10491        $this->assertEquals(302, (int)$res['response']['code'] );
     
    10895        // 5 - 5
    10996        $res = wp_remote_request($this->redirection_script . '?rt=' . 5, array('redirection' => 5) );
     97
     98        $this->skipTestOnTimeout( $res );
    11099        $this->assertNotWPError( $res );
    111100        $this->assertEquals(200, (int)$res['response']['code'] );
     
    115104        // No redirections on HEAD request:
    116105        $res = wp_remote_request($this->redirection_script . '?code=302&rt=' . 1, array('method' => 'HEAD') );
     106
     107        $this->skipTestOnTimeout( $res );
    117108        $this->assertNotWPError( $res );
    118109        $this->assertEquals( 302, (int)$res['response']['code'] );
     
    125116        // Redirections on HEAD request when Requested
    126117        $res = wp_remote_request($this->redirection_script . '?rt=' . 5, array('redirection' => 5, 'method' => 'HEAD') );
     118
     119        $this->skipTestOnTimeout( $res );
    127120        $this->assertNotWPError( $res );
    128121        $this->assertEquals( 200, (int)$res['response']['code'] );
     
    132125        // 10 > 5
    133126        $res = wp_remote_request($this->redirection_script . '?rt=' . 10, array('redirection' => 5) );
     127
     128        $this->skipTestOnTimeout( $res );
    134129        $this->assertWPError( $res );
    135130    }
     
    138133        // 6 > 5 (close edgecase)
    139134        $res = wp_remote_request($this->redirection_script . '?rt=' . 6, array('redirection' => 5) );
     135
     136        $this->skipTestOnTimeout( $res );
    140137        $this->assertWPError( $res );
    141138    }
     
    144141        // 4 < 5 (close edgecase)
    145142        $res = wp_remote_request($this->redirection_script . '?rt=' . 4, array('redirection' => 5) );
     143
     144        $this->skipTestOnTimeout( $res );
    146145        $this->assertNotWPError( $res );
    147146    }
     
    153152        // 0 redirections asked for, Should return the document?
    154153        $res = wp_remote_request($this->redirection_script . '?code=302&rt=' . 5, array('redirection' => 0) );
     154
     155        $this->skipTestOnTimeout( $res );
    155156        $this->assertNotWPError( $res );
    156157        $this->assertEquals( 302, (int)$res['response']['code'] );
     
    165166        // Prints PASS on initial load, FAIL if the client follows the specified redirection
    166167        $res = wp_remote_request( $this->redirection_script . '?201-location=true' );
     168
     169        $this->skipTestOnTimeout( $res );
    167170        $this->assertNotWPError( $res );
    168171        $this->assertEquals( 'PASS', $res['body']);
     
    179182        // Test 301 - POST to POST
    180183        $res = wp_remote_request( $url, array( 'method' => 'PUT', 'timeout' => 30 ) );
     184
     185        $this->skipTestOnTimeout( $res );
    181186        $this->assertEquals( 'PASS', wp_remote_retrieve_body( $res ) );
    182187        $this->assertTrue( !empty( $res['headers']['location'] ) );
     
    191196        $res = wp_remote_request( $this->redirection_script . '?header-check', array('headers' => $headers) );
    192197
     198        $this->skipTestOnTimeout( $res );
    193199        $this->assertNotWPError( $res );
    194200
     
    221227
    222228        $this->skipTestOnTimeout( $res );
    223 
    224229        $this->assertNotWPError( $res );
    225230        $this->assertEquals( '', $res['body'] ); // The body should be empty.
     
    244249
    245250        $this->skipTestOnTimeout( $res );
    246 
    247251        $this->assertNotWPError( $res );
    248252        $this->assertEquals( $size, $filesize ); // Check that the file is written to disk correctly without any extra characters
     
    262266
    263267        $this->skipTestOnTimeout( $res );
    264 
    265268        $this->assertNotWPError( $res );
    266269        $this->assertEquals( $size, strlen( $res['body'] ) );
     
    278281
    279282        $res = wp_remote_post( add_query_arg( 'response_code', $response_code, $url ), array( 'timeout' => 30 ) );
     283
     284        $this->skipTestOnTimeout( $res );
    280285        $this->assertEquals( $method, wp_remote_retrieve_body( $res ) );
    281286    }
     
    323328
    324329        $res = wp_remote_get( $url, $args );
     330
     331        $this->skipTestOnTimeout( $res );
    325332        $this->assertEquals( 'PASS', wp_remote_retrieve_body( $res ) );
    326333
     
    344351        remove_filter( 'http_request_args', array( $this, 'filter_http_request_args' ) );
    345352
     353        $this->skipTestOnTimeout( $res );
    346354        $this->assertNotEmpty( $this->http_request_args['sslcertificates'] );
    347355        $this->assertNotWPError( $res );
     
    357365        $res = wp_remote_head( $url, array( 'timeout' => 30 ) );
    358366
     367        $this->skipTestOnTimeout( $res );
    359368        $this->assertInternalType( 'array', wp_remote_retrieve_header( $res, 'location' ) );
    360369        $this->assertCount( 2, wp_remote_retrieve_header( $res, 'location' ) );
    361370
    362371        $res = wp_remote_get( $url, array( 'timeout' => 30 ) );
     372
     373        $this->skipTestOnTimeout( $res );
    363374        $this->assertEquals( 'PASS', wp_remote_retrieve_body( $res ) );
    364375
     
    374385
    375386        $res = wp_remote_get( $url );
     387
     388        $this->skipTestOnTimeout( $res );
    376389        $this->assertEquals( 'PASS', wp_remote_retrieve_body( $res ) );
    377390    }
     
    388401
    389402        $res = wp_remote_get( 'https://wordpress.org/' );
     403
     404        $this->skipTestOnTimeout( $res );
    390405        $this->assertNotWPError( $res );
    391406    }
     
    401416
    402417        $res = wp_remote_request( $url );
     418
     419        $this->skipTestOnTimeout( $res );
    403420        $this->assertNotWPError( $res );
    404421    }
  • branches/4.7/tests/phpunit/tests/http/functions.php

    r38761 r50088  
    66 */
    77class Tests_HTTP_Functions extends WP_UnitTestCase {
     8
    89    public function setUp() {
    910        if ( ! extension_loaded( 'openssl' ) ) {
     
    1819        $url = 'https://asdftestblog1.files.wordpress.com/2007/09/2007-06-30-dsc_4700-1.jpg';
    1920        $response = wp_remote_head( $url );
     21
     22        $this->skipTestOnTimeout( $response );
     23
    2024        $headers = wp_remote_retrieve_headers( $response );
    2125
     
    3135        $url = 'https://asdftestblog1.wordpress.com/files/2007/09/2007-06-30-dsc_4700-1.jpg';
    3236        $response = wp_remote_head( $url );
     37
     38        $this->skipTestOnTimeout( $response );
    3339        $this->assertEquals( '301', wp_remote_retrieve_response_code( $response ) );
    3440    }
     
    3642    function test_head_404() {
    3743        $url = 'https://asdftestblog1.files.wordpress.com/2007/09/awefasdfawef.jpg';
    38         $headers = wp_remote_head( $url );
     44        $response = wp_remote_head( $url );
    3945
    40         $this->assertEquals( '404', wp_remote_retrieve_response_code( $headers ) );
     46        $this->skipTestOnTimeout( $response );
     47        $this->assertEquals( '404', wp_remote_retrieve_response_code( $response ) );
    4148    }
    4249
     
    4552
    4653        $response = wp_remote_get( $url );
     54
     55        $this->skipTestOnTimeout( $response );
     56
    4757        $headers = wp_remote_retrieve_headers( $response );
    4858
     
    6070
    6171        $response = wp_remote_get( $url );
     72
     73        $this->skipTestOnTimeout( $response );
     74
    6275        $headers = wp_remote_retrieve_headers( $response );
    6376
     
    7487        // pretend we've already redirected 5 times
    7588        $response = wp_remote_get( $url, array( 'redirection' => -1 ) );
     89
     90        $this->skipTestOnTimeout( $response );
    7691        $this->assertWPError( $response );
    7792    }
     
    8499
    85100        $response = wp_remote_head( $url );
    86         $cookies  = wp_remote_retrieve_cookies( $response );
     101
     102        $this->skipTestOnTimeout( $response );
     103
     104        $cookies = wp_remote_retrieve_cookies( $response );
    87105
    88106        $this->assertNotEmpty( $cookies );
     
    114132            ),
    115133        ) );
    116         $cookies  = wp_remote_retrieve_cookies( $response );
     134
     135        $this->skipTestOnTimeout( $response );
     136
     137        $cookies = wp_remote_retrieve_cookies( $response );
    117138
    118139        $this->assertNotEmpty( $cookies );
     
    135156            ),
    136157        ) );
    137         $cookies  = wp_remote_retrieve_cookies( $response );
     158
     159        $this->skipTestOnTimeout( $response );
     160
     161        $cookies = wp_remote_retrieve_cookies( $response );
    138162
    139163        $this->assertNotEmpty( $cookies );
Note: See TracChangeset for help on using the changeset viewer.