You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
cacert-testmgr/external/ZendFramework-1.9.5/tests/Zend/Http/Client/SocketTest.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)
);
}
}