doppiogancio/mocked-client
最新稳定版本:v4.1.4
Composer 安装命令:
composer require --dev doppiogancio/mocked-client
包简介
A simple way to mock a client
README 文档
README
Mocked Client
This package will help test components that depend on clients for HTTP calls. At the moment only Guzzle Client is supported.
Install
Via Composer
$ composer require doppiogancio/mocked-client guzzlehttp/guzzle php-http/discovery
Requirements
This version requires a minimum PHP version 8.1
How to mock a client
use DoppioGancio\MockedClient\HandlerBuilder; use DoppioGancio\MockedClient\ClientBuilder; use DoppioGancio\MockedClient\Route\RouteBuilder; use GuzzleHttp\Psr7\Response; use Http\Discovery\Psr17FactoryDiscovery; use Psr\Log\NullLogger; $handlerBuilder = new HandlerBuilder( Psr17FactoryDiscovery::findServerRequestFactory(), new NullLogger() ); $route = new RouteBuilder( Psr17FactoryDiscovery::findResponseFactory(), Psr17FactoryDiscovery::findStreamFactory(), ); // Route with Response $handlerBuilder->addRoute( $route->new() ->withMethod('GET') ->withPath('/country/IT') ->withResponse(new Response(200, [], '{"id":"+39","code":"IT","name":"Italy"}')) ->build() ); $clientBuilder = new ClientBuilder($handlerBuilder); $client = $clientBuilder->build();
Advanced examples
- Route with a file
- Route with a string
- Route with consecutive calls
- Route with callbacks
- Guzzle client with middlewares
How to use the client
$response = $client->request('GET', '/country/DE/json'); $body = (string) $response->getBody(); $country = json_decode($body, true); print_r($country); // will return Array ( [id] => +49 [code] => DE [name] => Germany )
Some recommendations...
Fail Fast, Fail Often
If you don't know in advance which routes are needed, don't worry, start with a client without routes, and let it suggests which routes to add.
$handlerBuilder = new HandlerBuilder( Psr17FactoryDiscovery::findServerRequestFactory(), new NullLogger() ); // don't add any route for now... $clientBuilder = new ClientBuilder($handlerBuilder); $client = $clientBuilder->build();
Run the test: the test will fail, but it will suggest you the route that is missing. By doing this, it will only specify the needed routes.
An example:
DoppioGancio\MockedClient\Exception\RouteNotFound: Mocked route GET /admin/dashboard not found
Inject the client in the service container
If you have a service container, add the client to it, so that every service depending on it will be able to auto wire.
self::$container->set(Client::class, $client); // In Symfony self::$container->set('eight_points_guzzle.client.my_client', $client);
统计信息
- 总下载量: 73.5k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 21
- 点击次数: 1
- 依赖项目数: 4
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2021-08-12