From b9ae22930090d5209a30a76fce731aea84f46f0a Mon Sep 17 00:00:00 2001 From: fmizzell Date: Mon, 21 Oct 2019 12:15:19 -0500 Subject: [PATCH] Loosen storage contracts, add hydratable interface, and allow hydration instances (#10) * Loosen the storage related contracts to allow things, other than strings, to be stored, and retrieved. * Adding a hydratable interface, and being more specific, at least in the documentation, about what our storage related interfaces support. * Allowing an instance to be passed during hydration. --- src/HydratableInterface.php | 8 ++++++++ src/Mock/IdGenerator/Sequential.php | 4 +++- src/Mock/Storage/JsonObjectMemory.php | 2 +- src/Mock/Storage/Memory.php | 7 ++++--- src/RetrieverInterface.php | 7 ++----- src/StorerInterface.php | 4 ++-- test/Mock/IdGenerator/SequentialTest.php | 2 -- 7 files changed, 20 insertions(+), 14 deletions(-) create mode 100644 src/HydratableInterface.php diff --git a/src/HydratableInterface.php b/src/HydratableInterface.php new file mode 100644 index 0000000..30b8f45 --- /dev/null +++ b/src/HydratableInterface.php @@ -0,0 +1,8 @@ +validate($data); return parent::store($data, $id); diff --git a/src/Mock/Storage/Memory.php b/src/Mock/Storage/Memory.php index 17e7b33..15b2ebd 100644 --- a/src/Mock/Storage/Memory.php +++ b/src/Mock/Storage/Memory.php @@ -2,15 +2,16 @@ namespace Contracts\Mock\Storage; +use Contracts\RetrieverInterface; use Contracts\StorerInterface; use Contracts\BulkRetrieverInterface; -class Memory implements StorerInterface, BulkRetrieverInterface +class Memory implements RetrieverInterface, StorerInterface, BulkRetrieverInterface { protected $storage = []; - public function retrieve(string $id): ?string + public function retrieve(string $id) { if (isset($this->storage[$id])) { return $this->storage[$id]; @@ -23,7 +24,7 @@ public function retrieveAll(): array return $this->storage; } - public function store(string $data, string $id = null): string + public function store($data, string $id = null): string { if (!isset($id)) { throw new \Exception("An id is required to store the data."); diff --git a/src/RetrieverInterface.php b/src/RetrieverInterface.php index e00bf5b..27e9d86 100644 --- a/src/RetrieverInterface.php +++ b/src/RetrieverInterface.php @@ -10,11 +10,8 @@ interface RetrieverInterface * @param string $id * The identifier for the data. * - * @return string + * @return string | HydratableInterface * The data or null if no data could be retrieved. - * - * @throws \Exception - * No data matched the identifier. */ - public function retrieve(string $id): ?string; + public function retrieve(string $id); } diff --git a/src/StorerInterface.php b/src/StorerInterface.php index 4cb8e11..b8e8eb5 100644 --- a/src/StorerInterface.php +++ b/src/StorerInterface.php @@ -7,7 +7,7 @@ interface StorerInterface /** * Store. * - * @param string $data + * @param string|HydratableInterface $data * The data to be stored. * @param string $id * The identifier for the data. If the act of storing generates the @@ -19,5 +19,5 @@ interface StorerInterface * @throws \Exception * Issues storing the data. */ - public function store(string $data, string $id = null): string; + public function store($data, string $id = null): string; } diff --git a/test/Mock/IdGenerator/SequentialTest.php b/test/Mock/IdGenerator/SequentialTest.php index 3c75bfc..f1e743c 100644 --- a/test/Mock/IdGenerator/SequentialTest.php +++ b/test/Mock/IdGenerator/SequentialTest.php @@ -1,9 +1,7 @@