251 lines
7.3 KiB
PHP
251 lines
7.3 KiB
PHP
|
<?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_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
|
||
|
* @version $Id: SocketTest.php 17363 2009-08-03 07:40:18Z bkarwin $
|
||
|
*/
|
||
|
|
||
|
require_once dirname(__FILE__) . '/CommonHttpTests.php';
|
||
|
|
||
|
require_once 'Zend/Http/Client/Adapter/Socket.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
|
||
|
*/
|
||
|
class Zend_Http_Client_SocketTest extends Zend_Http_Client_CommonHttpTests
|
||
|
{
|
||
|
/**
|
||
|
* Configuration array
|
||
|
*
|
||
|
* @var array
|
||
|
*/
|
||
|
protected $config = array(
|
||
|
'adapter' => 'Zend_Http_Client_Adapter_Socket'
|
||
|
);
|
||
|
|
||
|
/**
|
||
|
* Off-line common adapter tests
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Test that we can set a valid configuration array with some options
|
||
|
*
|
||
|
*/
|
||
|
public function testConfigSetAsArray()
|
||
|
{
|
||
|
$config = array(
|
||
|
'timeout' => 500,
|
||
|
'someoption' => 'hasvalue'
|
||
|
);
|
||
|
|
||
|
$this->_adapter->setConfig($config);
|
||
|
|
||
|
$hasConfig = $this->getObjectAttribute($this->_adapter, 'config');
|
||
|
foreach($config as $k => $v) {
|
||
|
$this->assertEquals($v, $hasConfig[$k]);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test that a Zend_Config object can be used to set configuration
|
||
|
*
|
||
|
* @link http://framework.zend.com/issues/browse/ZF-5577
|
||
|
*/
|
||
|
public function testConfigSetAsZendConfig()
|
||
|
{
|
||
|
require_once 'Zend/Config.php';
|
||
|
|
||
|
$config = new Zend_Config(array(
|
||
|
'timeout' => 400,
|
||
|
'nested' => array(
|
||
|
'item' => 'value',
|
||
|
)
|
||
|
));
|
||
|
|
||
|
$this->_adapter->setConfig($config);
|
||
|
|
||
|
$hasConfig = $this->getObjectAttribute($this->_adapter, 'config');
|
||
|
$this->assertEquals($config->timeout, $hasConfig['timeout']);
|
||
|
$this->assertEquals($config->nested->item, $hasConfig['nested']['item']);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Check that an exception is thrown when trying to set invalid config
|
||
|
*
|
||
|
* @expectedException Zend_Http_Client_Adapter_Exception
|
||
|
* @dataProvider invalidConfigProvider
|
||
|
*/
|
||
|
public function testSetConfigInvalidConfig($config)
|
||
|
{
|
||
|
$this->_adapter->setConfig($config);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Stream context related tests
|
||
|
*/
|
||
|
|
||
|
public function testGetNewStreamContext()
|
||
|
{
|
||
|
$adapter = new $this->config['adapter'];
|
||
|
$context = $adapter->getStreamContext();
|
||
|
|
||
|
$this->assertEquals('stream-context', get_resource_type($context));
|
||
|
}
|
||
|
|
||
|
public function testSetNewStreamContextResource()
|
||
|
{
|
||
|
$adapter = new $this->config['adapter'];
|
||
|
$context = stream_context_create();
|
||
|
|
||
|
$adapter->setStreamContext($context);
|
||
|
|
||
|
$this->assertEquals($context, $adapter->getStreamContext());
|
||
|
}
|
||
|
|
||
|
public function testSetNewStreamContextOptions()
|
||
|
{
|
||
|
$adapter = new $this->config['adapter'];
|
||
|
$options = array(
|
||
|
'socket' => array(
|
||
|
'bindto' => '1.2.3.4:0'
|
||
|
),
|
||
|
'ssl' => array(
|
||
|
'verify_peer' => true,
|
||
|
'allow_self_signed' => false
|
||
|
)
|
||
|
);
|
||
|
|
||
|
$adapter->setStreamContext($options);
|
||
|
|
||
|
$this->assertEquals($options, stream_context_get_options($adapter->getStreamContext()));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test that setting invalid options / context causes an exception
|
||
|
*
|
||
|
* @dataProvider invalidContextProvider
|
||
|
* @expectedException Zend_Http_Client_Adapter_Exception
|
||
|
*/
|
||
|
public function testSetInvalidContextOptions($invalid)
|
||
|
{
|
||
|
$adapter = new $this->config['adapter'];
|
||
|
$adapter->setStreamContext($invalid);
|
||
|
}
|
||
|
|
||
|
public function testSetHttpsStreamContextParam()
|
||
|
{
|
||
|
if ($this->client->getUri()->getScheme() != 'https') {
|
||
|
$this->markTestSkipped();
|
||
|
}
|
||
|
|
||
|
$adapter = new $this->config['adapter'];
|
||
|
$adapter->setStreamContext(array(
|
||
|
'ssl' => array(
|
||
|
'capture_peer_cert' => true,
|
||
|
'capture_peer_chain' => true
|
||
|
)
|
||
|
));
|
||
|
|
||
|
$this->client->setAdapter($adapter);
|
||
|
$this->client->setUri($this->baseuri . '/testSimpleRequests.php');
|
||
|
$this->client->request();
|
||
|
|
||
|
$opts = stream_context_get_options($adapter->getStreamContext());
|
||
|
$this->assertTrue(isset($opts['ssl']['peer_certificate']));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test that we get the right exception after a socket timeout
|
||
|
*
|
||
|
* @link http://framework.zend.com/issues/browse/ZF-7309
|
||
|
*/
|
||
|
public function testExceptionOnReadTimeout()
|
||
|
{
|
||
|
// Set 1 second timeout
|
||
|
$this->client->setConfig(array('timeout' => 1));
|
||
|
|
||
|
$start = microtime(true);
|
||
|
|
||
|
try {
|
||
|
$this->client->request();
|
||
|
$this->fail("Expected a timeout Zend_Http_Client_Adapter_Exception");
|
||
|
} catch (Zend_Http_Client_Adapter_Exception $e) {
|
||
|
$this->assertEquals(Zend_Http_Client_Adapter_Exception::READ_TIMEOUT, $e->getCode());
|
||
|
}
|
||
|
|
||
|
$time = (microtime(true) - $start);
|
||
|
|
||
|
// We should be very close to 1 second
|
||
|
$this->assertLessThan(2, $time);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Test that a chunked response with multibyte characters is properly read
|
||
|
*
|
||
|
* This can fail in various PHP environments - for example, when mbstring
|
||
|
* overloads substr() and strlen(), and mbstring's internal encoding is
|
||
|
* not a single-byte encoding.
|
||
|
*
|
||
|
* @link http://framework.zend.com/issues/browse/ZF-6218
|
||
|
*/
|
||
|
public function testMultibyteChunkedResponseZF6218()
|
||
|
{
|
||
|
$md5 = '7667818873302f9995be3798d503d8d3';
|
||
|
|
||
|
$response = $this->client->request();
|
||
|
$this->assertEquals($md5, md5($response->getBody()));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Data Providers
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Provide invalid context resources / options
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
static public function invalidContextProvider()
|
||
|
{
|
||
|
return array(
|
||
|
array(new stdClass()),
|
||
|
array(fopen('data://text/plain,', 'r')),
|
||
|
array(false),
|
||
|
array(null)
|
||
|
);
|
||
|
}
|
||
|
}
|