Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/blastcloud/guzzler

Supercharge your app or SDK with a testing library specifically for Guzzle
https://github.com/blastcloud/guzzler

guzzlehttp mock php phpunit testing

Last synced: about 2 months ago
JSON representation

Supercharge your app or SDK with a testing library specifically for Guzzle

Awesome Lists containing this project

README

        
















---

> Full Documentation at [guzzler.dev](https://guzzler.dev)

Supercharge your app or SDK with a testing library specifically for Guzzle. Guzzler covers the process of setting up a mock handler, recording history of requests, and provides several convenience methods for creating expectations and assertions on that history.

## Installation

```bash
composer require --dev --prefer-dist blastcloud/guzzler
```

## Example Usage

```php
guzzler->getClient([
/* Any configs for a client */
"base_uri" => "https://example.com/api"
]);

// You can then inject this client object into your code or IOC container.
$this->classToTest = new ClassToTest($client);
}

public function testSomethingWithExpectations()
{
$this->guzzler->expects($this->once())
->post("/some-url")
->withHeader("X-Authorization", "some-key")
->willRespond(new Response(201));

$this->classToTest->someMethod();
}

public function testSomethingWithAssertions()
{
$this->guzzler->queueResponse(
new Response(204),
new \Exception("Some message"),
// any needed responses to return from the client.
);

$this->classToTest->someMethod();
// ... Some other number of calls

$this->guzzler->assertAll(function ($expect) {
return $expect->withHeader("Authorization", "some-key");
});
}
}
```

## Documentation

[Full Documentation](https://guzzler.dev)

## License

Guzzler is open-source software licensed under the [MIT License](https://opensource.org/licenses/MIT).