class MockSerializer in Config Entity Revisions 8.2
Same name and namespace in other branches
- 8 tests/src/Unit/ConfigEntityRevisionsRevertFormBaseTest.php \Drupal\Tests\config_entity_revisions\Unit\MockSerializer
- 1.x tests/src/Unit/ConfigEntityRevisionsRevertFormBaseTest.php \Drupal\Tests\config_entity_revisions\Unit\MockSerializer
MockSerializer class.
The serializer (sic) we'd normally mock above has deserialize as a final method. Instead of using it, define our own class here.
Hierarchy
- class \Drupal\Tests\config_entity_revisions\Unit\MockSerializer
Expanded class hierarchy of MockSerializer
File
- tests/
src/ Unit/ ConfigEntityRevisionsRevertFormBaseTest.php, line 691
Namespace
Drupal\Tests\config_entity_revisions\UnitView source
class MockSerializer {
/**
* The test class passed to the constructor.
*
* @var \Drupal\Tests\config_entity_revisions\Unit\ConfigEntityRevisionsRevertFormBaseTest
*/
public $testClass = NULL;
/**
* Whether the unserialise method was called.
*
* @var bool
*/
public $wasCalled = FALSE;
/**
* The key value pairs.
*
* @var array
*/
public $keyValuePairs = [];
/**
* Constructor. Store a copy of the test class so we can use its prophecy.
*
* @param \Drupal\tests\config_entity_revisions\Unit\ConfigEntityRevisionsRevertFormBaseTest $testClass
* The test class instance.
*/
public function __construct(ConfigEntityRevisionsRevertFormBaseTest $testClass) {
$this->testClass = $testClass;
}
/**
* Mock data unserialise function.
*
* @param string $data
* The serialised data.
* @param string $type
* Unused type parameter.
* @param string $format
* Unused format parameter.
* @param array $context
* Unused context array.
*
* @return string
* The unserialises data.
*
* @throws \Exception
*/
public function deserialize($data, $type, $format, array $context = []) {
if ($data !== 'serialisedConfiguration') {
throw new \Exception("Mock Serializer class's deserialize method should be called with data = 'serialisedConfiguration'");
}
$this->wasCalled = TRUE;
$configEntity = $this->testClass
->prophesizeProxy(ConfigEntityRevisionsConfigEntityInterface::CLASS);
$configEntity
->enforceIsNew(Argument::type('bool'))
->shouldBeCalled()
->will(function ($args) {
if (!$args || $args[0]) {
throw new \Exception("enforceIsNew wasn't set to FALSE.");
}
});
$configEntity
->get(Argument::type('string'))
->shouldBeCalledTimes(1)
->willReturn('originalSettings');
$keyValuePairs =& $this->keyValuePairs;
$configEntity
->set(Argument::type('string'), Argument::any())
->will(function ($args) use (&$keyValuePairs) {
$keyValuePairs[$args[0]] = $args[1];
});
$configEntity
->save()
->shouldBeCalled();
return $configEntity
->reveal();
}
}
Members
Name![]() |
Modifiers | Type | Description | Overrides |
---|---|---|---|---|
MockSerializer:: |
public | property | The key value pairs. | |
MockSerializer:: |
public | property | The test class passed to the constructor. | |
MockSerializer:: |
public | property | Whether the unserialise method was called. | |
MockSerializer:: |
public | function | Mock data unserialise function. | |
MockSerializer:: |
public | function | Constructor. Store a copy of the test class so we can use its prophecy. |