$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\Batch;
use Guzzle\Batch\Batch;
use Guzzle\Batch\Exception\BatchTransferException;
/**
* @covers Guzzle\Batch\Batch
*/
class BatchTest extends \Guzzle\Tests\GuzzleTestCase
{
private function getMockTransfer()
{
return $this->getMock('Guzzle\Batch\BatchTransferInterface');
}
private function getMockDivisor()
{
return $this->getMock('Guzzle\Batch\BatchDivisorInterface');
}
public function testAddsItemsToQueue()
{
$batch = new Batch($this->getMockTransfer(), $this->getMockDivisor());
$this->assertSame($batch, $batch->add('foo'));
$this->assertEquals(1, count($batch));
}
public function testFlushReturnsItems()
{
$transfer = $this->getMockTransfer();
$transfer->expects($this->exactly(2))
->method('transfer');
$divisor = $this->getMockDivisor();
$divisor->expects($this->once())
->method('createBatches')
->will($this->returnValue(array(array('foo', 'baz'), array('bar'))));
$batch = new Batch($transfer, $divisor);
$batch->add('foo')->add('baz')->add('bar');
$items = $batch->flush();
$this->assertEquals(array('foo', 'baz', 'bar'), $items);
}
public function testThrowsExceptionContainingTheFailedBatch()
{
$called = 0;
$originalException = new \Exception('Foo!');
$transfer = $this->getMockTransfer();
$transfer->expects($this->exactly(2))
->method('transfer')
->will($this->returnCallback(function () use (&$called, $originalException) {
if (++$called == 2) {
throw $originalException;
}
}));
$divisor = $this->getMockDivisor();
$batch = new Batch($transfer, $divisor);
// PHPunit clones objects before passing them to a callback.
// Horrible hack to get around this!
$queue = $this->readAttribute($batch, 'queue');
$divisor->expects($this->once())
->method('createBatches')
->will($this->returnCallback(function ($batch) use ($queue) {
foreach ($queue as $item) {
$items[] = $item;
}
return array_chunk($items, 2);
}));
$batch->add('foo')->add('baz')->add('bar')->add('bee')->add('boo');
$this->assertFalse($batch->isEmpty());
try {
$items = $batch->flush();
$this->fail('Expected exception');
} catch (BatchTransferException $e) {
$this->assertEquals($originalException, $e->getPrevious());
$this->assertEquals(array('bar', 'bee'), array_values($e->getBatch()));
$this->assertEquals(1, count($batch));
}
}
}