class AcsfMessageTest in Acquia Cloud Site Factory Connector 8
Same name and namespace in other branches
- 8.2 tests/AcsfMessageTest.php \AcsfMessageTest
AcsfMessageTest.
Hierarchy
- class \AcsfMessageTest extends \PHPUnit\Framework\TestCase
Expanded class hierarchy of AcsfMessageTest
File
- tests/
AcsfMessageTest.php, line 16 - Provides PHPUnit tests for AcsfMessage.
View source
class AcsfMessageTest extends TestCase {
/**
* Setup.
*/
public function setUp() {
// The files in this directory can't be autoloaded as long as they don't
// match their classes' namespaces.
$files = [
__DIR__ . '/AcsfConfigUnitTest.inc',
__DIR__ . '/AcsfConfigUnitTestMissingPassword.inc',
__DIR__ . '/AcsfConfigUnitTestMissingUrl.inc',
__DIR__ . '/AcsfConfigUnitTestMissingUsername.inc',
__DIR__ . '/AcsfConfigUnitTestIncompatible.inc',
__DIR__ . '/AcsfMessageUnitTestSuccess.inc',
__DIR__ . '/AcsfMessageUnitTestFailure.inc',
__DIR__ . '/AcsfMessageUnitTestFailureException.inc',
__DIR__ . '/AcsfMessageUnitTestMissingEndpoint.inc',
__DIR__ . '/AcsfMessageUnitTestMissingResponse.inc',
__DIR__ . '/AcsfMessageResponseUnitTest.inc',
];
foreach ($files as $file) {
// Acquia rules disallow 'include/require' with dynamic arguments.
// phpcs:disable
require_once $file;
// phpcs:enable
}
}
/**
* Tests the AcsfMessage constructor parameters.
*/
public function testAcsfMessageConstructor() {
$config = new AcsfConfigUnitTest('unit_test_site', 'unit_test_env');
$message = new AcsfMessageUnitTestSuccess('TEST', 'unit_test_endpoint', [], $config);
$this
->assertSame($message->method, 'TEST');
}
/**
* Tests that the config object must be an instance of AcsfConfig.
*/
public function testAcsfMessageConfigCompatible() {
// Provide a compatible config object to check that no error is generated.
// This isn't very precise since any error would make this test fail.
$config = new AcsfConfigUnitTest('unit_test_site', 'unit_test_env');
$this
->assertTrue(is_subclass_of($config, '\\Drupal\\acsf\\AcsfConfig'));
$message = new AcsfMessageUnitTestSuccess('TEST', 'unit_test_endpoint', [], $config);
}
/**
* Tests message sending and response works as expected.
*/
public function testAcsfMessageResponse() {
$config = new AcsfConfigUnitTest('unit_test_site', 'unit_test_env');
$message = new AcsfMessageUnitTestSuccess('TEST', 'unit_test_endpoint', [], $config);
$message
->send();
$response = $message
->getResponseBody();
$expected_response = [
'url' => 'http://gardener.unit.test',
'method' => 'TEST',
'endpoint' => 'unit_test_endpoint',
'parameters' => [],
'username' => 'gardener_unit_test',
'password' => 'Un1tT35t',
];
$this
->assertSame($response, json_encode($expected_response));
}
/**
* Tests that an exception is throw when endpoint is missing.
*/
public function testAcsfMessageResponseMissingEndpoint() {
$config = new AcsfConfigUnitTest('unit_test_site', 'unit_test_env');
$this
->expectException(AcsfMessageMalformedResponseException::class);
$message = new AcsfMessageUnitTestMissingEndpoint('TEST', 'unit_test_endpoint', [], $config);
$message
->send();
}
/**
* Tests that an exception is throw when response is missing.
*/
public function testAcsfMessageResponseMissingResponse() {
$config = new AcsfConfigUnitTest('unit_test_site', 'unit_test_env');
$this
->expectException(AcsfMessageMalformedResponseException::class);
$message = new AcsfMessageUnitTestMissingResponse('TEST', 'unit_test_endpoint', [], $config);
$message
->send();
}
/**
* Tests that a response code greater than 0 triggers the correct exception.
*/
public function testAcsfMessageResponseFailure() {
$config = new AcsfConfigUnitTest('unit_test_site', 'unit_test_env');
$message = new AcsfMessageUnitTestFailure('TEST', 'unit_test_endpoint', [], $config);
try {
$caught = FALSE;
$message
->send();
} catch (AcsfMessageFailedResponseException $e) {
$caught = TRUE;
}
$this
->assertTrue($caught);
$this
->assertSame($message
->getResponseCode(), 1);
}
/**
* Tests that the AcsfMessageFailureException exception is thrown.
*/
public function testAcsfMessageResponseFailureException() {
$config = new AcsfConfigUnitTest('unit_test_site', 'unit_test_env');
$this
->expectException(AcsfMessageFailureException::class);
$message = new AcsfMessageUnitTestFailureException('TEST', 'unit_test_endpoint', [], $config);
$message
->send();
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
AcsfMessageTest:: |
public | function | Setup. | |
AcsfMessageTest:: |
public | function | Tests that the config object must be an instance of AcsfConfig. | |
AcsfMessageTest:: |
public | function | Tests the AcsfMessage constructor parameters. | |
AcsfMessageTest:: |
public | function | Tests message sending and response works as expected. | |
AcsfMessageTest:: |
public | function | Tests that a response code greater than 0 triggers the correct exception. | |
AcsfMessageTest:: |
public | function | Tests that the AcsfMessageFailureException exception is thrown. | |
AcsfMessageTest:: |
public | function | Tests that an exception is throw when endpoint is missing. | |
AcsfMessageTest:: |
public | function | Tests that an exception is throw when response is missing. |