class MockHandlerStack in Apigee Edge 8
The mock handler stack.
The Mock handler stack overrides the Mock handler so we can add a response factory as well.
Hierarchy
- class \Drupal\apigee_mock_api_client\MockHandlerStack extends \Apigee\MockClient\GuzzleHttp\MockHandler
Expanded class hierarchy of MockHandlerStack
1 string reference to 'MockHandlerStack'
- apigee_mock_api_client.services.yml in tests/
modules/ apigee_mock_api_client/ apigee_mock_api_client.services.yml - tests/modules/apigee_mock_api_client/apigee_mock_api_client.services.yml
1 service uses MockHandlerStack
- apigee_mock_api_client.mock_http_handler_stack in tests/
modules/ apigee_mock_api_client/ apigee_mock_api_client.services.yml - Drupal\apigee_mock_api_client\MockHandlerStack
File
- tests/
modules/ apigee_mock_api_client/ src/ MockHandlerStack.php, line 36
Namespace
Drupal\apigee_mock_api_clientView source
class MockHandlerStack extends MockHandler {
/**
* Responses that have been loaded from the response file.
*
* @var array
*/
protected $responses = [];
/**
* The response factory.
*
* @var \Apigee\MockClient\ResponseFactoryInterface
*/
protected $responseFactory;
/**
* The twig environment used in the response generator.
*
* @var \Twig_Environment
*/
protected $twig;
/**
* Override the mock handler constructor.
*
* @param \Apigee\MockClient\MockStorageInterface $storage
* Mock storage.
* @param \Apigee\MockClient\ResponseFactoryInterface $response_factory
* The response factory.
* @param \Twig_Environment $twig
* The twig environment used in the response generator.
*/
public function __construct(MockStorageInterface $storage, ResponseFactoryInterface $response_factory, \Twig_Environment $twig) {
parent::__construct($storage);
$this->responseFactory = $response_factory;
$this->twig = $twig;
}
/**
* Queue a response that is in the catalog.
*
* Dynamic values can be passed and
* will be replaced in the response.
*
* @param string|array $response_ids
* The name of the response template to queue (without file extension)
* e.g. `get-developer` or `get_developer` @see /tests/response-templates.
*
* @return $this
*/
public function queueMockResponse($response_ids) {
$org_name = \Drupal::service('apigee_edge.sdk_connector')
->getOrganization();
if (empty($this->responses)) {
// Get the module path for this module.
$module_path = \Drupal::moduleHandler()
->getModule('apigee_mock_api_client')
->getPath();
$this->responses = Yaml::parseFile($module_path . '/response_catalog.yml')['responses'];
}
// Loop through responses and add each one.
foreach ((array) $response_ids as $index => $item) {
// The catalog id should either be the item itself or the keys if an
// associative array has been passed.
$id = !is_array($item) ? $item : $index;
// Body text can have elements replaced in it for certain values.
$context = is_array($item) ? $item : [];
$context['org_name'] = isset($context['org_name']) ? $context['org_name'] : $org_name;
// Add the default headers if headers aren't defined in the response
// catalog.
$headers = isset($this->responses[$id]['headers']) ? $this->responses[$id]['headers'] : [
'content-type' => 'application/json;charset=utf-8',
];
// Set the default status code.
$status_code = !empty($this->responses[$id]['status_code']) ? $this->responses[$id]['status_code'] : 200;
$status_code = !empty($context['status_code']) ? $context['status_code'] : $status_code;
if ($this->twig
->getLoader()
->exists($id)) {
$this
->addResponse($this->responseFactory
->generateResponse(new TwigSource($id, $context, $status_code, $headers)));
}
else {
$this
->addResponse(new Response($status_code, $headers, ''));
}
}
return $this;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
MockHandlerStack:: |
protected | property | The response factory. | |
MockHandlerStack:: |
protected | property | Responses that have been loaded from the response file. | |
MockHandlerStack:: |
protected | property | The twig environment used in the response generator. | |
MockHandlerStack:: |
public | function | Queue a response that is in the catalog. | |
MockHandlerStack:: |
public | function | Override the mock handler constructor. |