mirror of
https://github.com/DesignPatternsPHP/DesignPatternsPHP.git
synced 2025-08-17 20:21:15 +02:00
PHP7 Registry
This commit is contained in:
@@ -6,7 +6,8 @@ Purpose
|
|||||||
|
|
||||||
To implement a central storage for objects often used throughout the
|
To implement a central storage for objects often used throughout the
|
||||||
application, is typically implemented using an abstract class with only
|
application, is typically implemented using an abstract class with only
|
||||||
static methods (or using the Singleton pattern)
|
static methods (or using the Singleton pattern). Remember that this introduces
|
||||||
|
global state, which should be avoided at all times! Instead implement it using Dependency Injection!
|
||||||
|
|
||||||
Examples
|
Examples
|
||||||
--------
|
--------
|
||||||
|
@@ -2,46 +2,51 @@
|
|||||||
|
|
||||||
namespace DesignPatterns\Structural\Registry;
|
namespace DesignPatterns\Structural\Registry;
|
||||||
|
|
||||||
/**
|
|
||||||
* class Registry.
|
|
||||||
*/
|
|
||||||
abstract class Registry
|
abstract class Registry
|
||||||
{
|
{
|
||||||
const LOGGER = 'logger';
|
const LOGGER = 'logger';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* this introduces global state in your application which can not be mocked up for testing
|
||||||
|
* and is therefor considered an anti-pattern! Use dependency injection instead!
|
||||||
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
protected static $storedValues = array();
|
private static $storedValues = [];
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
private static $allowedKeys = [
|
||||||
|
self::LOGGER,
|
||||||
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* sets a value.
|
|
||||||
*
|
|
||||||
* @param string $key
|
* @param string $key
|
||||||
* @param mixed $value
|
* @param mixed $value
|
||||||
*
|
*
|
||||||
* @static
|
|
||||||
*
|
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public static function set($key, $value)
|
public static function set(string $key, $value)
|
||||||
{
|
{
|
||||||
|
if (!in_array($key, self::$allowedKeys)) {
|
||||||
|
throw new \InvalidArgumentException('Invalid key given');
|
||||||
|
}
|
||||||
|
|
||||||
self::$storedValues[$key] = $value;
|
self::$storedValues[$key] = $value;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* gets a value from the registry.
|
|
||||||
*
|
|
||||||
* @param string $key
|
* @param string $key
|
||||||
*
|
*
|
||||||
* @static
|
|
||||||
*
|
|
||||||
* @return mixed
|
* @return mixed
|
||||||
*/
|
*/
|
||||||
public static function get($key)
|
public static function get(string $key)
|
||||||
{
|
{
|
||||||
|
if (!in_array($key, self::$allowedKeys) || !isset(self::$storedValues[$key])) {
|
||||||
|
throw new \InvalidArgumentException('Invalid key given');
|
||||||
|
}
|
||||||
|
|
||||||
return self::$storedValues[$key];
|
return self::$storedValues[$key];
|
||||||
}
|
}
|
||||||
|
|
||||||
// typically there would be methods to check if a key has already been registered and so on ...
|
|
||||||
}
|
}
|
||||||
|
@@ -9,12 +9,33 @@ class RegistryTest extends \PHPUnit_Framework_TestCase
|
|||||||
public function testSetAndGetLogger()
|
public function testSetAndGetLogger()
|
||||||
{
|
{
|
||||||
$key = Registry::LOGGER;
|
$key = Registry::LOGGER;
|
||||||
$object = new \StdClass();
|
$logger = new \stdClass();
|
||||||
|
|
||||||
Registry::set($key, $object);
|
Registry::set($key, $logger);
|
||||||
$actual = Registry::get($key);
|
$storedLogger = Registry::get($key);
|
||||||
|
|
||||||
$this->assertEquals($object, $actual);
|
$this->assertSame($logger, $storedLogger);
|
||||||
$this->assertInstanceOf('StdClass', $actual);
|
$this->assertInstanceOf('stdClass', $storedLogger);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @expectedException \InvalidArgumentException
|
||||||
|
*/
|
||||||
|
public function testThrowsExceptionWhenTryingToSetInvalidKey()
|
||||||
|
{
|
||||||
|
Registry::set('foobar', new \stdClass());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* notice @runInSeparateProcess here: without it, a previous test might have set it already and
|
||||||
|
* testing would not be possible. That's why you should implement Dependency Injection where an
|
||||||
|
* injected class may easily be replaced by a mockup
|
||||||
|
*
|
||||||
|
* @runInSeparateProcess
|
||||||
|
* @expectedException \InvalidArgumentException
|
||||||
|
*/
|
||||||
|
public function testThrowsExceptionWhenTryingToGetNotSetKey()
|
||||||
|
{
|
||||||
|
Registry::get(Registry::LOGGER);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user