$serviceBuilder
$serviceBuilder :
Base testcase class for all Guzzle testcases.
getServer() : \Guzzle\Tests\Http\Server
Get the global server object used throughout the unit tests of Guzzle
setServiceBuilder(\Guzzle\Service\Builder\ServiceBuilderInterface $builder)
Set the service builder to use for tests
\Guzzle\Service\Builder\ServiceBuilderInterface | $builder | Service builder |
getServiceBuilder() : \Guzzle\Service\Builder\ServiceBuilder
Get a service builder object that can be used throughout the service tests
getWildcardObserver(\Guzzle\Common\HasDispatcherInterface $hasDispatcher) : \Guzzle\Tests\Mock\MockObserver
Get a wildcard observer for an event dispatcher
\Guzzle\Common\HasDispatcherInterface | $hasDispatcher |
setMockBasePath(string $path) : \Guzzle\Tests\GuzzleTestCase
Set the mock response base path
string | $path | Path to mock response folder |
addMockedRequest(\Guzzle\Http\Message\RequestInterface $request) : self
Mark a request as being mocked
\Guzzle\Http\Message\RequestInterface | $request |
getMockResponse(string $path) : \Guzzle\Http\Message\Response
Get a mock response for a client by mock file name
string | $path | Relative path to the mock response file |
setMockResponse(\Guzzle\Http\Client $client, string $paths) : \Guzzle\Plugin\Mock\MockPlugin
Set a mock response from a mock file on the next client request.
This method assumes that mock response files are located under the Command/Mock/ directory of the Service being tested (e.g. Unfuddle/Command/Mock/). A mock response is added to the next request sent by the client.
\Guzzle\Http\Client | $client | Client object to modify |
string | $paths | Path to files within the Mock folder of the service |
returns the created mock plugin
compareHeaders(array $filteredHeaders, array $actualHeaders) : array|boolean
Compare HTTP headers and use special markup to filter values A header prefixed with '!' means it must not exist A header prefixed with '_' means it must be ignored A header value of '*' means anything after the * will be ignored
array | $filteredHeaders | Array of special headers |
array | $actualHeaders | Array of headers to check against |
Returns an array of the differences or FALSE if none
hasSubscriber(\Guzzle\Common\HasDispatcherInterface $dispatcher, \Symfony\Component\EventDispatcher\EventSubscriberInterface $subscriber) : boolean
Check if an event dispatcher has a subscriber
\Guzzle\Common\HasDispatcherInterface | $dispatcher | |
\Symfony\Component\EventDispatcher\EventSubscriberInterface | $subscriber |
<?php
namespace Guzzle\Tests\Service\Command\LocationVisitor\Request;
use Guzzle\Http\Message\EntityEnclosingRequest;
use Guzzle\Service\Description\Operation;
use Guzzle\Service\Description\Parameter;
use Guzzle\Service\Description\SchemaValidator;
use Guzzle\Service\Command\OperationCommand;
use Guzzle\Tests\Service\Mock\Command\MockCommand;
use Guzzle\Tests\Service\Mock\MockClient;
abstract class AbstractVisitorTestCase extends \Guzzle\Tests\GuzzleTestCase
{
protected $command;
protected $request;
protected $param;
protected $validator;
public function setUp()
{
$this->command = new MockCommand();
$this->request = new EntityEnclosingRequest('POST', 'http://www.test.com/some/path.php');
$this->validator = new SchemaValidator();
}
protected function getCommand($location)
{
$command = new OperationCommand(array(), $this->getNestedCommand($location));
$command->setClient(new MockClient());
return $command;
}
protected function getNestedCommand($location)
{
return new Operation(array(
'httpMethod' => 'POST',
'parameters' => array(
'foo' => new Parameter(array(
'type' => 'object',
'location' => $location,
'sentAs' => 'Foo',
'required' => true,
'properties' => array(
'test' => array(
'type' => 'object',
'required' => true,
'properties' => array(
'baz' => array(
'type' => 'boolean',
'default' => true
),
'jenga' => array(
'type' => 'string',
'default' => 'hello',
'sentAs' => 'Jenga_Yall!',
'filters' => array('strtoupper')
)
)
),
'bar' => array('default' => 123)
),
'additionalProperties' => array(
'type' => 'string',
'filters' => array('strtoupper'),
'location' => $location
)
)),
'arr' => new Parameter(array(
'type' => 'array',
'location' => $location,
'items' => array(
'type' => 'string',
'filters' => array('strtoupper')
)
)),
)
));
}
protected function getCommandWithArrayParamAndFilters()
{
$operation = new Operation(array(
'httpMethod' => 'POST',
'parameters' => array(
'foo' => new Parameter(array(
'type' => 'string',
'location' => 'query',
'sentAs' => 'Foo',
'required' => true,
'default' => 'bar',
'filters' => array('strtoupper')
)),
'arr' => new Parameter(array(
'type' => 'array',
'location' => 'query',
'sentAs' => 'Arr',
'required' => true,
'default' => array(123, 456, 789),
'filters' => array(array('method' => 'implode', 'args' => array(',', '@value')))
))
)
));
$command = new OperationCommand(array(), $operation);
$command->setClient(new MockClient());
return $command;
}
}