forked from a64f7bb4-7358-4778-9fbe-3b882c34cc1d/v1
74 lines
2.2 KiB
PHP
74 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace Drupal\FunctionalTests;
|
|
|
|
use Drupal\Tests\BrowserTestBase;
|
|
|
|
/**
|
|
* Tests BrowserTestBase functionality.
|
|
*
|
|
* @group browsertestbase
|
|
*/
|
|
class BrowserTestBaseUserAgentTest extends BrowserTestBase {
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
protected $defaultTheme = 'stark';
|
|
|
|
/**
|
|
* The user agent string to use.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $agent;
|
|
|
|
/**
|
|
* Tests validation of the User-Agent header we use to perform test requests.
|
|
*/
|
|
public function testUserAgentValidation() {
|
|
$assert_session = $this->assertSession();
|
|
$system_path = $this->buildUrl(\Drupal::service('extension.list.module')->getPath('system'));
|
|
$http_path = $system_path . '/tests/http.php/user/login';
|
|
$https_path = $system_path . '/tests/https.php/user/login';
|
|
// Generate a valid test User-Agent to pass validation.
|
|
$this->assertNotFalse(preg_match('/test\d+/', $this->databasePrefix, $matches), 'Database prefix contains test prefix.');
|
|
$this->agent = drupal_generate_test_ua($matches[0]);
|
|
|
|
// Test pages only available for testing.
|
|
$this->drupalGet($http_path);
|
|
$assert_session->statusCodeEquals(200);
|
|
$this->drupalGet($https_path);
|
|
$assert_session->statusCodeEquals(200);
|
|
|
|
// Now slightly modify the HMAC on the header, which should not validate.
|
|
$this->agent = 'X';
|
|
$this->drupalGet($http_path);
|
|
$assert_session->statusCodeEquals(403);
|
|
$this->drupalGet($https_path);
|
|
$assert_session->statusCodeEquals(403);
|
|
|
|
// Use a real User-Agent and verify that the special files http.php and
|
|
// https.php can't be accessed.
|
|
$this->agent = 'Mozilla/5.0 (Macintosh; U; Intel Mac OS X 10.6; en-US; rv:1.9.2.12) Gecko/20101026 Firefox/3.6.12';
|
|
$this->drupalGet($http_path);
|
|
$assert_session->statusCodeEquals(403);
|
|
$this->drupalGet($https_path);
|
|
$assert_session->statusCodeEquals(403);
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
protected function prepareRequest() {
|
|
$session = $this->getSession();
|
|
if ($this->agent) {
|
|
$session->setCookie('SIMPLETEST_USER_AGENT', $this->agent);
|
|
}
|
|
else {
|
|
$session->setCookie('SIMPLETEST_USER_AGENT', drupal_generate_test_ua($this->databasePrefix));
|
|
}
|
|
}
|
|
|
|
}
|