public function CorsIntegrationTest::testCrossSiteRequest in Drupal 8        
                          
                  
                        Same name and namespace in other branches
- 9 core/tests/Drupal/FunctionalTests/HttpKernel/CorsIntegrationTest.php \Drupal\FunctionalTests\HttpKernel\CorsIntegrationTest::testCrossSiteRequest()
- 10 core/tests/Drupal/FunctionalTests/HttpKernel/CorsIntegrationTest.php \Drupal\FunctionalTests\HttpKernel\CorsIntegrationTest::testCrossSiteRequest()
File
 
   - core/tests/Drupal/FunctionalTests/HttpKernel/CorsIntegrationTest.php, line 29
Class
  
  - CorsIntegrationTest 
- Tests CORS provided by Drupal.
Namespace
  Drupal\FunctionalTests\HttpKernel
Code
public function testCrossSiteRequest() {
  
  $cors_config = $this->container
    ->getParameter('cors.config');
  $this
    ->assertSame(FALSE, $cors_config['enabled']);
  $this
    ->assertSame([], $cors_config['allowedHeaders']);
  $this
    ->assertSame([], $cors_config['allowedMethods']);
  $this
    ->assertSame([
    '*',
  ], $cors_config['allowedOrigins']);
  $this
    ->assertSame(FALSE, $cors_config['exposedHeaders']);
  $this
    ->assertSame(FALSE, $cors_config['maxAge']);
  $this
    ->assertSame(FALSE, $cors_config['supportsCredentials']);
  
  $cors_config['enabled'] = TRUE;
  $this
    ->setContainerParameter('cors.config', $cors_config);
  $this
    ->rebuildContainer();
  
  $this
    ->drupalGet('/test-page', [], [
    'Origin' => 'http://example.com',
  ]);
  $this
    ->assertSession()
    ->statusCodeEquals(200);
  $this
    ->assertSession()
    ->responseHeaderEquals('X-Drupal-Cache', 'MISS');
  $this
    ->assertSession()
    ->responseHeaderEquals('Access-Control-Allow-Origin', 'http://example.com');
  
  $this
    ->drupalGet('/test-page', [], [
    'Origin' => 'http://example.com',
  ]);
  $this
    ->assertSession()
    ->statusCodeEquals(200);
  $this
    ->assertSession()
    ->responseHeaderEquals('X-Drupal-Cache', 'HIT');
  $this
    ->assertSession()
    ->responseHeaderEquals('Access-Control-Allow-Origin', 'http://example.com');
  
  $this
    ->drupalGet('/test-page', [], [
    'Origin' => 'http://example.org',
  ]);
  $this
    ->assertSession()
    ->statusCodeEquals(200);
  $this
    ->assertSession()
    ->responseHeaderEquals('X-Drupal-Cache', 'HIT');
  $this
    ->assertSession()
    ->responseHeaderEquals('Access-Control-Allow-Origin', 'http://example.org');
  
  $cors_config['allowedOrigins'] = [
    'http://example.com',
  ];
  $this
    ->setContainerParameter('cors.config', $cors_config);
  $this
    ->rebuildContainer();
  
  
  $this
    ->drupalGet('/test-page', [], [
    'Origin' => 'http://non-valid.com',
  ]);
  $this
    ->assertSession()
    ->statusCodeEquals(403);
  $this
    ->assertSession()
    ->pageTextContains('Not allowed.');
  
  $this
    ->drupalGet('/test-page', [], [
    'Origin' => 'http://example.com',
  ]);
  $this
    ->assertSession()
    ->statusCodeEquals(200);
  $this
    ->assertSession()
    ->responseHeaderEquals('Access-Control-Allow-Origin', 'http://example.com');
  
  $origin = \Drupal::request()
    ->getSchemeAndHttpHost();
  
  $httpClient = $this
    ->getSession()
    ->getDriver()
    ->getClient()
    ->getClient();
  $url = Url::fromUri('base:/test-page');
  $response = $httpClient
    ->request('POST', $url
    ->setAbsolute()
    ->toString(), [
    'headers' => [
      'Origin' => $origin,
    ],
  ]);
  $this
    ->assertEquals(200, $response
    ->getStatusCode());
}