123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509 |
- <?php
- class BootstrapIPAddressTestCase extends DrupalWebTestCase {
- public static function getInfo() {
- return array(
- 'name' => 'IP address and HTTP_HOST test',
- 'description' => 'Get the IP address from the current visitor from the server variables, check hostname validation.',
- 'group' => 'Bootstrap'
- );
- }
- function setUp() {
- $this->oldserver = $_SERVER;
- $this->remote_ip = '127.0.0.1';
- $this->proxy_ip = '127.0.0.2';
- $this->proxy2_ip = '127.0.0.3';
- $this->forwarded_ip = '127.0.0.4';
- $this->cluster_ip = '127.0.0.5';
- $this->untrusted_ip = '0.0.0.0';
- drupal_static_reset('ip_address');
- $_SERVER['REMOTE_ADDR'] = $this->remote_ip;
- unset($_SERVER['HTTP_X_FORWARDED_FOR']);
- unset($_SERVER['HTTP_X_CLUSTER_CLIENT_IP']);
- parent::setUp();
- }
- function tearDown() {
- $_SERVER = $this->oldserver;
- drupal_static_reset('ip_address');
- parent::tearDown();
- }
- /**
- * test IP Address and hostname
- */
- function testIPAddressHost() {
- // Test the normal IP address.
- $this->assertTrue(
- ip_address() == $this->remote_ip,
- t('Got remote IP address.')
- );
- // Proxy forwarding on but no proxy addresses defined.
- variable_set('reverse_proxy', 1);
- $this->assertTrue(
- ip_address() == $this->remote_ip,
- t('Proxy forwarding without trusted proxies got remote IP address.')
- );
- // Proxy forwarding on and proxy address not trusted.
- variable_set('reverse_proxy_addresses', array($this->proxy_ip, $this->proxy2_ip));
- drupal_static_reset('ip_address');
- $_SERVER['REMOTE_ADDR'] = $this->untrusted_ip;
- $this->assertTrue(
- ip_address() == $this->untrusted_ip,
- t('Proxy forwarding with untrusted proxy got remote IP address.')
- );
- // Proxy forwarding on and proxy address trusted.
- $_SERVER['REMOTE_ADDR'] = $this->proxy_ip;
- $_SERVER['HTTP_X_FORWARDED_FOR'] = $this->forwarded_ip;
- drupal_static_reset('ip_address');
- $this->assertTrue(
- ip_address() == $this->forwarded_ip,
- t('Proxy forwarding with trusted proxy got forwarded IP address.')
- );
- // Multi-tier architecture with comma separated values in header.
- $_SERVER['REMOTE_ADDR'] = $this->proxy_ip;
- $_SERVER['HTTP_X_FORWARDED_FOR'] = implode(', ', array($this->untrusted_ip, $this->forwarded_ip, $this->proxy2_ip));
- drupal_static_reset('ip_address');
- $this->assertTrue(
- ip_address() == $this->forwarded_ip,
- t('Proxy forwarding with trusted 2-tier proxy got forwarded IP address.')
- );
- // Custom client-IP header.
- variable_set('reverse_proxy_header', 'HTTP_X_CLUSTER_CLIENT_IP');
- $_SERVER['HTTP_X_CLUSTER_CLIENT_IP'] = $this->cluster_ip;
- drupal_static_reset('ip_address');
- $this->assertTrue(
- ip_address() == $this->cluster_ip,
- t('Cluster environment got cluster client IP.')
- );
- // Verifies that drupal_valid_http_host() prevents invalid characters.
- $this->assertFalse(drupal_valid_http_host('security/.drupal.org:80'), t('HTTP_HOST with / is invalid'));
- $this->assertFalse(drupal_valid_http_host('security\\.drupal.org:80'), t('HTTP_HOST with \\ is invalid'));
- $this->assertFalse(drupal_valid_http_host('security<.drupal.org:80'), t('HTTP_HOST with < is invalid'));
- $this->assertFalse(drupal_valid_http_host('security..drupal.org:80'), t('HTTP_HOST with .. is invalid'));
- // IPv6 loopback address
- $this->assertTrue(drupal_valid_http_host('[::1]:80'), t('HTTP_HOST containing IPv6 loopback is valid'));
- }
- }
- class BootstrapPageCacheTestCase extends DrupalWebTestCase {
- public static function getInfo() {
- return array(
- 'name' => 'Page cache test',
- 'description' => 'Enable the page cache and test it with various HTTP requests.',
- 'group' => 'Bootstrap'
- );
- }
- function setUp() {
- parent::setUp('system_test');
- }
- /**
- * Test support for requests containing If-Modified-Since and If-None-Match headers.
- */
- function testConditionalRequests() {
- variable_set('cache', 1);
- // Fill the cache.
- $this->drupalGet('');
- $this->drupalHead('');
- $this->assertEqual($this->drupalGetHeader('X-Drupal-Cache'), 'HIT', t('Page was cached.'));
- $etag = $this->drupalGetHeader('ETag');
- $last_modified = $this->drupalGetHeader('Last-Modified');
- $this->drupalGet('', array(), array('If-Modified-Since: ' . $last_modified, 'If-None-Match: ' . $etag));
- $this->assertResponse(304, t('Conditional request returned 304 Not Modified.'));
- $this->drupalGet('', array(), array('If-Modified-Since: ' . gmdate(DATE_RFC822, strtotime($last_modified)), 'If-None-Match: ' . $etag));
- $this->assertResponse(304, t('Conditional request with obsolete If-Modified-Since date returned 304 Not Modified.'));
- $this->drupalGet('', array(), array('If-Modified-Since: ' . gmdate(DATE_RFC850, strtotime($last_modified)), 'If-None-Match: ' . $etag));
- $this->assertResponse(304, t('Conditional request with obsolete If-Modified-Since date returned 304 Not Modified.'));
- $this->drupalGet('', array(), array('If-Modified-Since: ' . $last_modified));
- $this->assertResponse(200, t('Conditional request without If-None-Match returned 200 OK.'));
- $this->assertEqual($this->drupalGetHeader('X-Drupal-Cache'), 'HIT', t('Page was cached.'));
- $this->drupalGet('', array(), array('If-Modified-Since: ' . gmdate(DATE_RFC1123, strtotime($last_modified) + 1), 'If-None-Match: ' . $etag));
- $this->assertResponse(200, t('Conditional request with new a If-Modified-Since date newer than Last-Modified returned 200 OK.'));
- $this->assertEqual($this->drupalGetHeader('X-Drupal-Cache'), 'HIT', t('Page was cached.'));
- $user = $this->drupalCreateUser();
- $this->drupalLogin($user);
- $this->drupalGet('', array(), array('If-Modified-Since: ' . $last_modified, 'If-None-Match: ' . $etag));
- $this->assertResponse(200, t('Conditional request returned 200 OK for authenticated user.'));
- $this->assertFalse($this->drupalGetHeader('X-Drupal-Cache'), t('Absense of Page was not cached.'));
- }
- /**
- * Test cache headers.
- */
- function testPageCache() {
- variable_set('cache', 1);
- // Fill the cache.
- $this->drupalGet('system-test/set-header', array('query' => array('name' => 'Foo', 'value' => 'bar')));
- $this->assertEqual($this->drupalGetHeader('X-Drupal-Cache'), 'MISS', t('Page was not cached.'));
- $this->assertEqual($this->drupalGetHeader('Vary'), 'Cookie,Accept-Encoding', t('Vary header was sent.'));
- $this->assertEqual($this->drupalGetHeader('Cache-Control'), 'public, max-age=0', t('Cache-Control header was sent.'));
- $this->assertEqual($this->drupalGetHeader('Expires'), 'Sun, 19 Nov 1978 05:00:00 GMT', t('Expires header was sent.'));
- $this->assertEqual($this->drupalGetHeader('Foo'), 'bar', t('Custom header was sent.'));
- // Check cache.
- $this->drupalGet('system-test/set-header', array('query' => array('name' => 'Foo', 'value' => 'bar')));
- $this->assertEqual($this->drupalGetHeader('X-Drupal-Cache'), 'HIT', t('Page was cached.'));
- $this->assertEqual($this->drupalGetHeader('Vary'), 'Cookie,Accept-Encoding', t('Vary: Cookie header was sent.'));
- $this->assertEqual($this->drupalGetHeader('Cache-Control'), 'public, max-age=0', t('Cache-Control header was sent.'));
- $this->assertEqual($this->drupalGetHeader('Expires'), 'Sun, 19 Nov 1978 05:00:00 GMT', t('Expires header was sent.'));
- $this->assertEqual($this->drupalGetHeader('Foo'), 'bar', t('Custom header was sent.'));
- // Check replacing default headers.
- $this->drupalGet('system-test/set-header', array('query' => array('name' => 'Expires', 'value' => 'Fri, 19 Nov 2008 05:00:00 GMT')));
- $this->assertEqual($this->drupalGetHeader('Expires'), 'Fri, 19 Nov 2008 05:00:00 GMT', t('Default header was replaced.'));
- $this->drupalGet('system-test/set-header', array('query' => array('name' => 'Vary', 'value' => 'User-Agent')));
- $this->assertEqual($this->drupalGetHeader('Vary'), 'User-Agent,Accept-Encoding', t('Default header was replaced.'));
- // Check that authenticated users bypass the cache.
- $user = $this->drupalCreateUser();
- $this->drupalLogin($user);
- $this->drupalGet('system-test/set-header', array('query' => array('name' => 'Foo', 'value' => 'bar')));
- $this->assertFalse($this->drupalGetHeader('X-Drupal-Cache'), t('Caching was bypassed.'));
- $this->assertTrue(strpos($this->drupalGetHeader('Vary'), 'Cookie') === FALSE, t('Vary: Cookie header was not sent.'));
- $this->assertEqual($this->drupalGetHeader('Cache-Control'), 'no-cache, must-revalidate, post-check=0, pre-check=0', t('Cache-Control header was sent.'));
- $this->assertEqual($this->drupalGetHeader('Expires'), 'Sun, 19 Nov 1978 05:00:00 GMT', t('Expires header was sent.'));
- $this->assertEqual($this->drupalGetHeader('Foo'), 'bar', t('Custom header was sent.'));
- }
- /**
- * Test page compression.
- *
- * The test should pass even if zlib.output_compression is enabled in php.ini,
- * .htaccess or similar, or if compression is done outside PHP, e.g. by the
- * mod_deflate Apache module.
- */
- function testPageCompression() {
- variable_set('cache', 1);
- // Fill the cache and verify that output is compressed.
- $this->drupalGet('', array(), array('Accept-Encoding: gzip,deflate'));
- $this->assertEqual($this->drupalGetHeader('X-Drupal-Cache'), 'MISS', t('Page was not cached.'));
- $this->drupalSetContent(gzinflate(substr($this->drupalGetContent(), 10, -8)));
- $this->assertRaw('</html>', t('Page was gzip compressed.'));
- // Verify that cached output is compressed.
- $this->drupalGet('', array(), array('Accept-Encoding: gzip,deflate'));
- $this->assertEqual($this->drupalGetHeader('X-Drupal-Cache'), 'HIT', t('Page was cached.'));
- $this->assertEqual($this->drupalGetHeader('Content-Encoding'), 'gzip', t('A Content-Encoding header was sent.'));
- $this->drupalSetContent(gzinflate(substr($this->drupalGetContent(), 10, -8)));
- $this->assertRaw('</html>', t('Page was gzip compressed.'));
- // Verify that a client without compression support gets an uncompressed page.
- $this->drupalGet('');
- $this->assertEqual($this->drupalGetHeader('X-Drupal-Cache'), 'HIT', t('Page was cached.'));
- $this->assertFalse($this->drupalGetHeader('Content-Encoding'), t('A Content-Encoding header was not sent.'));
- $this->assertTitle(t('Welcome to @site-name | @site-name', array('@site-name' => variable_get('site_name', 'Drupal'))), t('Site title matches.'));
- $this->assertRaw('</html>', t('Page was not compressed.'));
- }
- }
- class BootstrapVariableTestCase extends DrupalWebTestCase {
- function setUp() {
- parent::setUp('system_test');
- }
- public static function getInfo() {
- return array(
- 'name' => 'Variable test',
- 'description' => 'Make sure the variable system functions correctly.',
- 'group' => 'Bootstrap'
- );
- }
- /**
- * testVariable
- */
- function testVariable() {
- // Setting and retrieving values.
- $variable = $this->randomName();
- variable_set('simpletest_bootstrap_variable_test', $variable);
- $this->assertIdentical($variable, variable_get('simpletest_bootstrap_variable_test'), t('Setting and retrieving values'));
- // Make sure the variable persists across multiple requests.
- $this->drupalGet('system-test/variable-get');
- $this->assertText($variable, t('Variable persists across multiple requests'));
- // Deleting variables.
- $default_value = $this->randomName();
- variable_del('simpletest_bootstrap_variable_test');
- $variable = variable_get('simpletest_bootstrap_variable_test', $default_value);
- $this->assertIdentical($variable, $default_value, t('Deleting variables'));
- }
- /**
- * Makes sure that the default variable parameter is passed through okay.
- */
- function testVariableDefaults() {
- // Tests passing nothing through to the default.
- $this->assertIdentical(NULL, variable_get('simpletest_bootstrap_variable_test'), t('Variables are correctly defaulting to NULL.'));
- // Tests passing 5 to the default parameter.
- $this->assertIdentical(5, variable_get('simpletest_bootstrap_variable_test', 5), t('The default variable parameter is passed through correctly.'));
- }
- }
- /**
- * Test hook_boot() and hook_exit().
- */
- class HookBootExitTestCase extends DrupalWebTestCase {
- public static function getInfo() {
- return array(
- 'name' => 'Boot and exit hook invocation',
- 'description' => 'Test that hook_boot() and hook_exit() are called correctly.',
- 'group' => 'Bootstrap',
- );
- }
- function setUp() {
- parent::setUp('system_test', 'dblog');
- }
- /**
- * Test calling of hook_boot() and hook_exit().
- */
- function testHookBootExit() {
- // Test with cache disabled. Boot and exit should always fire.
- variable_set('cache', 0);
- $this->drupalGet('');
- $calls = 1;
- $this->assertEqual(db_query('SELECT COUNT(*) FROM {watchdog} WHERE type = :type AND message = :message', array(':type' => 'system_test', ':message' => 'hook_boot'))->fetchField(), $calls, t('hook_boot called with disabled cache.'));
- $this->assertEqual(db_query('SELECT COUNT(*) FROM {watchdog} WHERE type = :type AND message = :message', array(':type' => 'system_test', ':message' => 'hook_exit'))->fetchField(), $calls, t('hook_exit called with disabled cache.'));
- // Test with normal cache. Boot and exit should be called.
- variable_set('cache', 1);
- $this->drupalGet('');
- $calls++;
- $this->assertEqual(db_query('SELECT COUNT(*) FROM {watchdog} WHERE type = :type AND message = :message', array(':type' => 'system_test', ':message' => 'hook_boot'))->fetchField(), $calls, t('hook_boot called with normal cache.'));
- $this->assertEqual(db_query('SELECT COUNT(*) FROM {watchdog} WHERE type = :type AND message = :message', array(':type' => 'system_test', ':message' => 'hook_exit'))->fetchField(), $calls, t('hook_exit called with normal cache.'));
- // Boot and exit should not fire since the page is cached.
- variable_set('page_cache_invoke_hooks', FALSE);
- $this->assertTrue(cache_get(url('', array('absolute' => TRUE)), 'cache_page'), t('Page has been cached.'));
- $this->drupalGet('');
- $this->assertEqual(db_query('SELECT COUNT(*) FROM {watchdog} WHERE type = :type AND message = :message', array(':type' => 'system_test', ':message' => 'hook_boot'))->fetchField(), $calls, t('hook_boot not called with aggressive cache and a cached page.'));
- $this->assertEqual(db_query('SELECT COUNT(*) FROM {watchdog} WHERE type = :type AND message = :message', array(':type' => 'system_test', ':message' => 'hook_exit'))->fetchField(), $calls, t('hook_exit not called with aggressive cache and a cached page.'));
- // Test with page cache cleared, boot and exit should be called.
- $this->assertTrue(db_delete('cache_page')->execute(), t('Page cache cleared.'));
- $this->drupalGet('');
- $calls++;
- $this->assertEqual(db_query('SELECT COUNT(*) FROM {watchdog} WHERE type = :type AND message = :message', array(':type' => 'system_test', ':message' => 'hook_boot'))->fetchField(), $calls, t('hook_boot called with aggressive cache and no cached page.'));
- $this->assertEqual(db_query('SELECT COUNT(*) FROM {watchdog} WHERE type = :type AND message = :message', array(':type' => 'system_test', ':message' => 'hook_exit'))->fetchField(), $calls, t('hook_exit called with aggressive cache and no cached page.'));
- }
- }
- /**
- * Test drupal_get_filename()'s availability.
- */
- class BootstrapGetFilenameTestCase extends DrupalUnitTestCase {
- public static function getInfo() {
- return array(
- 'name' => 'Get filename test',
- 'description' => 'Test that drupal_get_filename() works correctly when the file is not found in the database.',
- 'group' => 'Bootstrap',
- );
- }
- /**
- * Test that drupal_get_filename() works correctly when the file is not found in the database.
- */
- function testDrupalGetFilename() {
- // Reset the static cache so we can test the "db is not active" code of
- // drupal_get_filename().
- drupal_static_reset('drupal_get_filename');
- // Retrieving the location of a module.
- $this->assertIdentical(drupal_get_filename('module', 'php'), 'modules/php/php.module', t('Retrieve module location.'));
- // Retrieving the location of a theme.
- $this->assertIdentical(drupal_get_filename('theme', 'stark'), 'themes/stark/stark.info', t('Retrieve theme location.'));
- // Retrieving the location of a theme engine.
- $this->assertIdentical(drupal_get_filename('theme_engine', 'phptemplate'), 'themes/engines/phptemplate/phptemplate.engine', t('Retrieve theme engine location.'));
- // Retrieving the location of a profile. Profiles are a special case with
- // a fixed location and naming.
- $this->assertIdentical(drupal_get_filename('profile', 'standard'), 'profiles/standard/standard.profile', t('Retrieve install profile location.'));
- // When a file is not found in the database cache, drupal_get_filename()
- // searches several locations on the filesystem, including the DRUPAL_ROOT
- // directory. We use the '.script' extension below because this is a
- // non-existent filetype that will definitely not exist in the database.
- // Since there is already a scripts directory, drupal_get_filename() will
- // automatically check there for 'script' files, just as it does for (e.g.)
- // 'module' files in modules.
- $this->assertIdentical(drupal_get_filename('script', 'test'), 'scripts/test.script', t('Retrieve test script location.'));
- }
- }
- class BootstrapTimerTestCase extends DrupalUnitTestCase {
- public static function getInfo() {
- return array(
- 'name' => 'Timer test',
- 'description' => 'Test that timer_read() works both when a timer is running and when a timer is stopped.',
- 'group' => 'Bootstrap',
- );
- }
- /**
- * Test timer_read() to ensure it properly accumulates time when the timer
- * started and stopped multiple times.
- * @return
- */
- function testTimer() {
- timer_start('test');
- sleep(1);
- $this->assertTrue(timer_read('test') >= 1000, t('Timer measured 1 second of sleeping while running.'));
- sleep(1);
- timer_stop('test');
- $this->assertTrue(timer_read('test') >= 2000, t('Timer measured 2 seconds of sleeping after being stopped.'));
- timer_start('test');
- sleep(1);
- $this->assertTrue(timer_read('test') >= 3000, t('Timer measured 3 seconds of sleeping after being restarted.'));
- sleep(1);
- $timer = timer_stop('test');
- $this->assertTrue(timer_read('test') >= 4000, t('Timer measured 4 seconds of sleeping after being stopped for a second time.'));
- $this->assertEqual($timer['count'], 2, t('Timer counted 2 instances of being started.'));
- }
- }
- /**
- * Test that resetting static variables works.
- */
- class BootstrapResettableStaticTestCase extends DrupalUnitTestCase {
- public static function getInfo() {
- return array(
- 'name' => 'Resettable static variables test',
- 'description' => 'Test that drupal_static() and drupal_static_reset() work.',
- 'group' => 'Bootstrap',
- );
- }
- /**
- * Test that a variable reference returned by drupal_static() gets reset when
- * drupal_static_reset() is called.
- */
- function testDrupalStatic() {
- $name = __CLASS__ . '_' . __METHOD__;
- $var = &drupal_static($name, 'foo');
- $this->assertEqual($var, 'foo', t('Variable returned by drupal_static() was set to its default.'));
- // Call the specific reset and the global reset each twice to ensure that
- // multiple resets can be issued without odd side effects.
- $var = 'bar';
- drupal_static_reset($name);
- $this->assertEqual($var, 'foo', t('Variable was reset after first invocation of name-specific reset.'));
- $var = 'bar';
- drupal_static_reset($name);
- $this->assertEqual($var, 'foo', t('Variable was reset after second invocation of name-specific reset.'));
- $var = 'bar';
- drupal_static_reset();
- $this->assertEqual($var, 'foo', t('Variable was reset after first invocation of global reset.'));
- $var = 'bar';
- drupal_static_reset();
- $this->assertEqual($var, 'foo', t('Variable was reset after second invocation of global reset.'));
- }
- }
- /**
- * Test miscellaneous functions in bootstrap.inc.
- */
- class BootstrapMiscTestCase extends DrupalUnitTestCase {
- public static function getInfo() {
- return array(
- 'name' => 'Miscellaneous bootstrap unit tests',
- 'description' => 'Test miscellaneous functions in bootstrap.inc.',
- 'group' => 'Bootstrap',
- );
- }
- /**
- * Test miscellaneous functions in bootstrap.inc.
- */
- function testMisc() {
- // Test drupal_array_merge_deep().
- $link_options_1 = array('fragment' => 'x', 'attributes' => array('title' => 'X', 'class' => array('a', 'b')), 'language' => 'en');
- $link_options_2 = array('fragment' => 'y', 'attributes' => array('title' => 'Y', 'class' => array('c', 'd')), 'html' => TRUE);
- $expected = array('fragment' => 'y', 'attributes' => array('title' => 'Y', 'class' => array('a', 'b', 'c', 'd')), 'language' => 'en', 'html' => TRUE);
- $this->assertIdentical(drupal_array_merge_deep($link_options_1, $link_options_2), $expected, t('drupal_array_merge_deep() returned a properly merged array.'));
- }
- }
- /**
- * Tests for overriding server variables via the API.
- */
- class BootstrapOverrideServerVariablesTestCase extends DrupalUnitTestCase {
- public static function getInfo() {
- return array(
- 'name' => 'Overriding server variables',
- 'description' => 'Test that drupal_override_server_variables() works correctly.',
- 'group' => 'Bootstrap',
- );
- }
- /**
- * Test providing a direct URL to to drupal_override_server_variables().
- */
- function testDrupalOverrideServerVariablesProvidedURL() {
- $tests = array(
- 'http://example.com' => array(
- 'HTTP_HOST' => 'example.com',
- 'SCRIPT_NAME' => isset($_SERVER['SCRIPT_NAME']) ? $_SERVER['SCRIPT_NAME'] : NULL,
- ),
- 'http://example.com/index.php' => array(
- 'HTTP_HOST' => 'example.com',
- 'SCRIPT_NAME' => '/index.php',
- ),
- 'http://example.com/subdirectory/index.php' => array(
- 'HTTP_HOST' => 'example.com',
- 'SCRIPT_NAME' => '/subdirectory/index.php',
- ),
- );
- foreach ($tests as $url => $expected_server_values) {
- // Remember the original value of $_SERVER, since the function call below
- // will modify it.
- $original_server = $_SERVER;
- // Call drupal_override_server_variables() and ensure that all expected
- // $_SERVER variables were modified correctly.
- drupal_override_server_variables(array('url' => $url));
- foreach ($expected_server_values as $key => $value) {
- $this->assertIdentical($_SERVER[$key], $value);
- }
- // Restore the original value of $_SERVER.
- $_SERVER = $original_server;
- }
- }
- }
|