cacert-testmgr/external/ZendFramework-1.9.5/tests/Zend/Http/Client/CommonHttpTests.php

876 lines
27 KiB
PHP
Raw Permalink Normal View History

<?php
/**
* Zend Framework
*
* LICENSE
*
* This source file is subject to the new BSD license that is bundled
* with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://framework.zend.com/license/new-bsd
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@zend.com so we can send you a copy immediately.
*
* @category Zend
* @package Zend_Http
* @subpackage UnitTests
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @version $Id: CommonHttpTests.php 17843 2009-08-27 14:40:35Z cogo $
*/
// Read local configuration
if (! defined('TESTS_ZEND_HTTP_CLIENT_BASEURI') &&
is_readable('TestConfiguration.php')) {
require_once 'TestConfiguration.php';
}
require_once realpath(dirname(__FILE__) . '/../../../') . '/TestHelper.php';
require_once 'Zend/Http/Client.php';
require_once 'Zend/Uri/Http.php';
/**
* This Testsuite includes all Zend_Http_Client that require a working web
* server to perform. It was designed to be extendable, so that several
* test suites could be run against several servers, with different client
* adapters and configurations.
*
* Note that $this->baseuri must point to a directory on a web server
* containing all the files under the _files directory. You should symlink
* or copy these files and set 'baseuri' properly.
*
* You can also set the proper constant in your test configuration file to
* point to the right place.
*
* @category Zend
* @package Zend_Http_Client
* @subpackage UnitTests
* @copyright Copyright (c) 2005-2009 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
* @group Zend_Http
* @group Zend_Http_Client
*/
abstract class Zend_Http_Client_CommonHttpTests extends PHPUnit_Framework_TestCase
{
/**
* The bast URI for this test, containing all files in the _files directory
* Should be set in TestConfiguration.php or TestConfiguration.php.dist
*
* @var string
*/
protected $baseuri;
/**
* Common HTTP client
*
* @var Zend_Http_Client
*/
protected $client = null;
/**
* Common HTTP client adapter
*
* @var Zend_Http_Client_Adapter_Interface
*/
protected $_adapter = null;
/**
* Configuration array
*
* @var array
*/
protected $config = array(
'adapter' => 'Zend_Http_Client_Adapter_Socket'
);
/**
* Set up the test case
*
*/
protected function setUp()
{
if (defined('TESTS_ZEND_HTTP_CLIENT_BASEURI') &&
Zend_Uri_Http::check(TESTS_ZEND_HTTP_CLIENT_BASEURI)) {
$this->baseuri = TESTS_ZEND_HTTP_CLIENT_BASEURI;
if (substr($this->baseuri, -1) != '/') $this->baseuri .= '/';
$name = $this->getName();
if (($pos = strpos($name, ' ')) !== false) {
$name = substr($name, 0, $pos);
}
$uri = $this->baseuri . $name . '.php';
$this->_adapter = new $this->config['adapter'];
$this->client = new Zend_Http_Client($uri, $this->config);
$this->client->setAdapter($this->_adapter);
} else {
// Skip tests
$this->markTestSkipped("Zend_Http_Client dynamic tests are not enabled in TestConfiguration.php");
}
}
/**
* Clean up the test environment
*
*/
protected function tearDown()
{
$this->client = null;
$this->_adapter = null;
}
/**
* Simple request tests
*/
/**
* Test simple requests
*
*/
public function testSimpleRequests()
{
$methods = array('GET', 'POST', 'OPTIONS', 'PUT', 'DELETE');
foreach ($methods as $method) {
$res = $this->client->request($method);
$this->assertEquals('Success', $res->getBody(), "HTTP {$method} request failed.");
}
}
/**
* Test we can get the last request as string
*
*/
public function testGetLastRequest()
{
$this->client->setUri($this->baseuri . 'testHeaders.php');
$this->client->setParameterGet('someinput', 'somevalue');
$this->client->setHeaders(array(
'X-Powered-By' => 'My Glorious Golden Ass',
));
$res = $this->client->request(Zend_Http_Client::TRACE);
if ($res->getStatus() == 405 || $res->getStatus() == 501) {
$this->markTestSkipped("Server does not allow the TRACE method");
}
$this->assertEquals($this->client->getLastRequest(), $res->getBody(), 'Response body should be exactly like the last request');
}
/**
* GET and POST parameters tests
*/
/**
* Test we can properly send GET parameters
*
* @dataProvider parameterArrayProvider
*/
public function testGetData($params)
{
$this->client->setUri($this->client->getUri(true) . '?name=Arthur');
$this->client->setParameterGet($params);
$res = $this->client->request('GET');
$this->assertEquals(serialize(array_merge(array('name' => 'Arthur'), $params)), $res->getBody());
}
/**
* Test we can properly send POST parameters with
* application/x-www-form-urlencoded content type
*
* @dataProvider parameterArrayProvider
*/
public function testPostDataUrlEncoded($params)
{
$this->client->setUri($this->baseuri . 'testPostData.php');
$this->client->setEncType(Zend_Http_Client::ENC_URLENCODED);
$this->client->setParameterPost($params);
$res = $this->client->request('POST');
$this->assertEquals(serialize($params), $res->getBody(), "POST data integrity test failed");
}
/**
* Test we can properly send POST parameters with
* multipart/form-data content type
*
* @dataProvider parameterArrayProvider
*/
public function testPostDataMultipart($params)
{
$this->client->setUri($this->baseuri . 'testPostData.php');
$this->client->setEncType(Zend_Http_Client::ENC_FORMDATA);
$this->client->setParameterPost($params);
$res = $this->client->request('POST');
$this->assertEquals(serialize($params), $res->getBody(), "POST data integrity test failed");
}
/**
* Test using raw HTTP POST data
*
*/
public function testRawPostData()
{
$data = "Chuck Norris never wet his bed as a child. The bed wet itself out of fear.";
$res = $this->client->setRawData($data, 'text/html')->request('POST');
$this->assertEquals($data, $res->getBody(), 'Response body does not contain the expected data');
}
/**
* Make sure we can reset the parameters between consecutive requests
*
*/
public function testResetParameters()
{
$params = array(
'quest' => 'To seek the holy grail',
'YourMother' => 'Was a hamster',
'specialChars' => '<>$+ &?=[]^%',
'array' => array('firstItem', 'secondItem', '3rdItem')
);
$this->client->setParameterPost($params);
$this->client->setParameterGet($params);
$res = $this->client->request('POST');
$this->assertContains(serialize($params) . "\n" . serialize($params),
$res->getBody(), "returned body does not contain all GET and POST parameters (it should!)");
$this->client->resetParameters();
$res = $this->client->request('POST');
$this->assertNotContains(serialize($params), $res->getBody(),
"returned body contains GET or POST parameters (it shouldn't!)");
}
/**
* Test parameters get reset when we unset them
*
*/
public function testParameterUnset()
{
$this->client->setUri($this->baseuri . 'testResetParameters.php');
$gparams = array (
'cheese' => 'camambert',
'beer' => 'jever pilnsen',
);
$pparams = array (
'from' => 'bob',
'to' => 'alice'
);
$this->client->setParameterGet($gparams)->setParameterPost($pparams);
// Remove some parameters
$this->client->setParameterGet('cheese', null)->setParameterPost('to', null);
$res = $this->client->request('POST');
$this->assertNotContains('cheese', $res->getBody(), 'The "cheese" GET parameter was expected to be unset');
$this->assertNotContains('alice', $res->getBody(), 'The "to" POST parameter was expected to be unset');
}
/**
* Header Tests
*/
/**
* Make sure we can set a single header
*
*/
public function testHeadersSingle()
{
$this->client->setUri($this->baseuri . 'testHeaders.php');
$headers = array(
'Accept-encoding' => 'gzip,deflate',
'X-baz' => 'Foo',
'X-powered-by' => 'A large wooden badger'
);
foreach ($headers as $key => $val) {
$this->client->setHeaders($key, $val);
}
$acceptHeader = "Accept: text/xml,text/html,*/*";
$this->client->setHeaders($acceptHeader);
$res = $this->client->request('TRACE');
if ($res->getStatus() == 405 || $res->getStatus() == 501) {
$this->markTestSkipped("Server does not allow the TRACE method");
}
$body = strtolower($res->getBody());
foreach ($headers as $key => $val)
$this->assertContains(strtolower("$key: $val"), $body);
$this->assertContains(strtolower($acceptHeader), $body);
}
/**
* Test we can set an array of headers
*
*/
public function testHeadersArray()
{
$this->client->setUri($this->baseuri . 'testHeaders.php');
$headers = array(
'Accept-encoding' => 'gzip,deflate',
'X-baz' => 'Foo',
'X-powered-by' => 'A large wooden badger',
'Accept: text/xml,text/html,*/*'
);
$this->client->setHeaders($headers);
$res = $this->client->request('TRACE');
if ($res->getStatus() == 405 || $res->getStatus() == 501) {
$this->markTestSkipped("Server does not allow the TRACE method");
}
$body = strtolower($res->getBody());
foreach ($headers as $key => $val) {
if (is_string($key)) {
$this->assertContains(strtolower("$key: $val"), $body);
} else {
$this->assertContains(strtolower($val), $body);
}
}
}
/**
* Test we can set a set of values for one header
*
*/
public function testMultipleHeader()
{
$this->client->setUri($this->baseuri . 'testHeaders.php');
$headers = array(
'Accept-encoding' => 'gzip,deflate',
'X-baz' => 'Foo',
'X-powered-by' => array(
'A large wooden badger',
'My Shiny Metal Ass',
'Dark Matter'
),
'Cookie' => array(
'foo=bar',
'baz=waka'
)
);
$this->client->setHeaders($headers);
$res = $this->client->request('TRACE');
if ($res->getStatus() == 405 || $res->getStatus() == 501) {
$this->markTestSkipped("Server does not allow the TRACE method");
}
$body = strtolower($res->getBody());
foreach ($headers as $key => $val) {
if (is_array($val))
$val = implode(', ', $val);
$this->assertContains(strtolower("$key: $val"), $body);
}
}
/**
* Redirection tests
*/
/**
* Test the client properly redirects in default mode
*
*/
public function testRedirectDefault()
{
$this->client->setUri($this->baseuri . 'testRedirections.php');
// Set some parameters
$this->client->setParameterGet('swallow', 'african');
$this->client->setParameterPost('Camelot', 'A silly place');
// Request
$res = $this->client->request('POST');
$this->assertEquals(3, $this->client->getRedirectionsCount(), 'Redirection counter is not as expected');
// Make sure the body does *not* contain the set parameters
$this->assertNotContains('swallow', $res->getBody());
$this->assertNotContains('Camelot', $res->getBody());
}
/**
* Make sure the client properly redirects in strict mode
*
*/
public function testRedirectStrict()
{
$this->client->setUri($this->baseuri . 'testRedirections.php');
// Set some parameters
$this->client->setParameterGet('swallow', 'african');
$this->client->setParameterPost('Camelot', 'A silly place');
// Set strict redirections
$this->client->setConfig(array('strictredirects' => true));
// Request
$res = $this->client->request('POST');
$this->assertEquals(3, $this->client->getRedirectionsCount(), 'Redirection counter is not as expected');
// Make sure the body *does* contain the set parameters
$this->assertContains('swallow', $res->getBody());
$this->assertContains('Camelot', $res->getBody());
}
/**
* Make sure redirections stop when limit is exceeded
*
*/
public function testMaxRedirectsExceeded()
{
$this->client->setUri($this->baseuri . 'testRedirections.php');
// Set some parameters
$this->client->setParameterGet('swallow', 'african');
$this->client->setParameterPost('Camelot', 'A silly place');
// Set lower max redirections
// Try with strict redirections first
$this->client->setConfig(array('strictredirects' => true, 'maxredirects' => 2));
$res = $this->client->request('POST');
$this->assertTrue($res->isRedirect(),
"Last response was not a redirection as expected. Response code: {$res->getStatus()}. Redirections counter: {$this->client->getRedirectionsCount()} (when strict redirects are on)");
// Then try with normal redirections
$this->client->setParameterGet('redirection', '0');
$this->client->setConfig(array('strictredirects' => false));
$res = $this->client->request('POST');
$this->assertTrue($res->isRedirect(),
"Last response was not a redirection as expected. Response code: {$res->getStatus()}. Redirections counter: {$this->client->getRedirectionsCount()} (when strict redirects are off)");
}
/**
* Test we can properly redirect to an absolute path (not full URI)
*
*/
public function testAbsolutePathRedirect()
{
$this->client->setUri($this->baseuri . 'testRelativeRedirections.php');
$this->client->setParameterGet('redirect', 'abpath');
$this->client->setConfig(array('maxredirects' => 1));
// Get the host and port part of our baseuri
$uri = $this->client->getUri()->getScheme() . '://' . $this->client->getUri()->getHost() . ':' .
$this->client->getUri()->getPort();
$res = $this->client->request('GET');
$this->assertEquals("{$uri}/path/to/fake/file.ext?redirect=abpath", $this->client->getUri(true),
"The new location is not as expected: {$this->client->getUri(true)}");
}
/**
* Test we can properly redirect to a relative path
*
*/
public function testRelativePathRedirect()
{
$this->client->setUri($this->baseuri . 'testRelativeRedirections.php');
$this->client->setParameterGet('redirect', 'relpath');
$this->client->setConfig(array('maxredirects' => 1));
// Set the new expected URI
$uri = clone $this->client->getUri();
$uri->setPath(dirname($uri->getPath()) . '/path/to/fake/file.ext');
$uri = $uri->__toString();
$res = $this->client->request('GET');
$this->assertEquals("{$uri}?redirect=relpath", $this->client->getUri(true),
"The new location is not as expected: {$this->client->getUri(true)}");
}
/**
* HTTP Authentication Tests
*
*/
/**
* Test we can properly use Basic HTTP authentication
*
*/
public function testHttpAuthBasic()
{
$this->client->setUri($this->baseuri. 'testHttpAuth.php');
$this->client->setParameterGet(array(
'user' => 'alice',
'pass' => 'secret',
'method' => 'Basic'
));
// First - fail password
$this->client->setAuth('alice', 'wrong');
$res = $this->client->request();
$this->assertEquals(401, $res->getStatus(), 'Expected HTTP 401 response was not recieved');
// Now use good password
$this->client->setAuth('alice', 'secret');
$res = $this->client->request();
$this->assertEquals(200, $res->getStatus(), 'Expected HTTP 200 response was not recieved');
}
/**
* Test we can unset HTTP authentication
*
*/
public function testCancelAuth()
{
$this->client->setUri($this->baseuri. 'testHttpAuth.php');
// Set auth and cancel it
$this->client->setAuth('alice', 'secret');
$this->client->setAuth(false);
$res = $this->client->request();
$this->assertEquals(401, $res->getStatus(), 'Expected HTTP 401 response was not recieved');
$this->assertNotContains('alice', $res->getBody(), "Body contains the user name, but it shouldn't");
$this->assertNotContains('secret', $res->getBody(), "Body contains the password, but it shouldn't");
}
/**
* Cookie and CookieJar Tests
*
*/
/**
* Test we can set string cookies with no jar
*
*/
public function testCookiesStringNoJar()
{
$this->client->setUri($this->baseuri. 'testCookies.php');
$cookies = array(
'name' => 'value',
'cookie' => 'crumble'
);
foreach ($cookies as $k => $v) {
$this->client->setCookie($k, $v);
}
$res = $this->client->request();
$this->assertEquals($res->getBody(), serialize($cookies), 'Response body does not contain the expected cookies');
}
/**
* Make sure we can set object cookies with no jar
*
*/
public function testSetCookieObjectNoJar()
{
$this->client->setUri($this->baseuri. 'testCookies.php');
$refuri = $this->client->getUri();
$cookies = array(
Zend_Http_Cookie::fromString('chocolate=chips', $refuri),
Zend_Http_Cookie::fromString('crumble=apple', $refuri)
);
$strcookies = array();
foreach ($cookies as $c) {
$this->client->setCookie($c);
$strcookies[$c->getName()] = $c->getValue();
}
$res = $this->client->request();
$this->assertEquals($res->getBody(), serialize($strcookies), 'Response body does not contain the expected cookies');
}
/**
* Make sure we can set an array of object cookies
*
*/
public function testSetCookieObjectArray()
{
$this->client->setUri($this->baseuri. 'testCookies.php');
$refuri = $this->client->getUri();
$cookies = array(
Zend_Http_Cookie::fromString('chocolate=chips', $refuri),
Zend_Http_Cookie::fromString('crumble=apple', $refuri),
Zend_Http_Cookie::fromString('another=cookie', $refuri)
);
$this->client->setCookie($cookies);
$strcookies = array();
foreach ($cookies as $c) {
$strcookies[$c->getName()] = $c->getValue();
}
$res = $this->client->request();
$this->assertEquals($res->getBody(), serialize($strcookies), 'Response body does not contain the expected cookies');
}
/**
* Make sure we can set an array of string cookies
*
*/
public function testSetCookieStringArray()
{
$this->client->setUri($this->baseuri. 'testCookies.php');
$cookies = array(
'chocolate' => 'chips',
'crumble' => 'apple',
'another' => 'cookie'
);
$this->client->setCookie($cookies);
$res = $this->client->request();
$this->assertEquals($res->getBody(), serialize($cookies), 'Response body does not contain the expected cookies');
}
/**
* Make sure we can set cookie objects with a jar
*
*/
public function testSetCookieObjectJar()
{
$this->client->setUri($this->baseuri. 'testCookies.php');
$this->client->setCookieJar();
$refuri = $this->client->getUri();
$cookies = array(
Zend_Http_Cookie::fromString('chocolate=chips', $refuri),
Zend_Http_Cookie::fromString('crumble=apple', $refuri)
);
$strcookies = array();
foreach ($cookies as $c) {
$this->client->setCookie($c);
$strcookies[$c->getName()] = $c->getValue();
}
$res = $this->client->request();
$this->assertEquals($res->getBody(), serialize($strcookies), 'Response body does not contain the expected cookies');
}
/**
* File Upload Tests
*
*/
/**
* Test we can upload raw data as a file
*
*/
public function testUploadRawData()
{
$this->client->setUri($this->baseuri. 'testUploads.php');
$rawdata = file_get_contents(__FILE__);
$this->client->setFileUpload('myfile.txt', 'uploadfile', $rawdata, 'text/plain');
$res = $this->client->request('POST');
$body = 'uploadfile myfile.txt text/plain ' . strlen($rawdata) . "\n";
$this->assertEquals($body, $res->getBody(), 'Response body does not include expected upload parameters');
}
/**
* Test we can upload an existing file
*
*/
public function testUploadLocalFile()
{
$this->client->setUri($this->baseuri. 'testUploads.php');
$this->client->setFileUpload(__FILE__, 'uploadfile', null, 'text/x-foo-bar');
$res = $this->client->request('POST');
$size = filesize(__FILE__);
$body = "uploadfile " . basename(__FILE__) . " text/x-foo-bar $size\n";
$this->assertEquals($body, $res->getBody(), 'Response body does not include expected upload parameters');
}
public function testUploadLocalDetectMime()
{
$detect = null;
if (function_exists('finfo_file')) {
$f = @finfo_open(FILEINFO_MIME);
if ($f) $detect = 'finfo';
} elseif (function_exists('mime_content_type')) {
if (mime_content_type(__FILE__)) {
$detect = 'mime_magic';
}
}
if (! $detect) {
$this->markTestSkipped('No MIME type detection capability (fileinfo or mime_magic extensions) is available');
}
$file = dirname(realpath(__FILE__)) . DIRECTORY_SEPARATOR . '_files' . DIRECTORY_SEPARATOR . 'staticFile.jpg';
$this->client->setUri($this->baseuri. 'testUploads.php');
$this->client->setFileUpload($file, 'uploadfile');
$res = $this->client->request('POST');
$size = filesize($file);
$body = "uploadfile " . basename($file) . " image/jpeg $size\n";
$this->assertEquals($body, $res->getBody(), 'Response body does not include expected upload parameters (detect: ' . $detect . ')');
}
public function testUploadNameWithSpecialChars()
{
$this->client->setUri($this->baseuri. 'testUploads.php');
$rawdata = file_get_contents(__FILE__);
$this->client->setFileUpload('/some strage/path%/with[!@#$&]/myfile.txt', 'uploadfile', $rawdata, 'text/plain');
$res = $this->client->request('POST');
$body = 'uploadfile myfile.txt text/plain ' . strlen($rawdata) . "\n";
$this->assertEquals($body, $res->getBody(), 'Response body does not include expected upload parameters');
}
public function testStaticLargeFileDownload()
{
$this->client->setUri($this->baseuri . 'staticFile.jpg');
$got = $this->client->request()->getBody();
$expected = $this->_getTestFileContents('staticFile.jpg');
$this->assertEquals($expected, $got, 'Downloaded file does not seem to match!');
}
/**
* Test that one can upload multiple files with the same form name, as an
* array
*
* @link http://framework.zend.com/issues/browse/ZF-5744
*/
public function testMutipleFilesWithSameFormNameZF5744()
{
$rawData = 'Some test raw data here...';
$this->client->setUri($this->baseuri . 'testUploads.php');
$files = array('file1.txt', 'file2.txt', 'someotherfile.foo');
$expectedBody = '';
foreach($files as $filename) {
$this->client->setFileUpload($filename, 'uploadfile[]', $rawData, 'text/plain');
$expectedBody .= "uploadfile $filename text/plain " . strlen($rawData) . "\n";
}
$res = $this->client->request('POST');
$this->assertEquals($expectedBody, $res->getBody(), 'Response body does not include expected upload parameters');
}
/**
* Test that lines that might be evaluated as boolean false do not break
* the reading prematurely.
*
* @see http://framework.zend.com/issues/browse/ZF-4238
*/
public function testZF4238FalseLinesInResponse()
{
$this->client->setUri($this->baseuri . 'ZF4238-zerolineresponse.txt');
$got = $this->client->request()->getBody();
$expected = $this->_getTestFileContents('ZF4238-zerolineresponse.txt');
$this->assertEquals($expected, $got);
}
/**
* Internal helpder function to get the contents of test files
*
* @param string $file
* @return string
*/
protected function _getTestFileContents($file)
{
return file_get_contents(dirname(realpath(__FILE__)) . DIRECTORY_SEPARATOR .
'_files' . DIRECTORY_SEPARATOR . $file);
}
/**
* Data provider for complex, nesting parameter arrays
*
* @return array
*/
static public function parameterArrayProvider()
{
return array(
array(
array(
'quest' => 'To seek the holy grail',
'YourMother' => 'Was a hamster',
'specialChars' => '<>$+ &?=[]^%',
'array' => array('firstItem', 'secondItem', '3rdItem')
)
),
array(
array(
'someData' => array(
"1",
"2",
'key' => 'value',
'nesting' => array(
'a' => 'AAA',
'b' => 'BBB'
)
),
'someOtherData' => array('foo', 'bar')
)
),
array(
array(
'foo1' => 'bar',
'foo2' => array('baz', 'w00t')
)
)
);
}
/**
* Data provider for invalid configuration containers
*
* @return array
*/
static public function invalidConfigProvider()
{
return array(
array(false),
array('foo => bar'),
array(null),
array(new stdClass),
array(55)
);
}
}