From f65a4076badc983cac65826f05d180a436348d72 Mon Sep 17 00:00:00 2001 From: fulmeek <36341513+fulmeek@users.noreply.github.com> Date: Mon, 4 Feb 2019 14:58:11 +0100 Subject: [PATCH] [CacheImplementationTest] Add unit tests for cache implementations (#1007) --- tests/CacheImplementationTest.php | 44 +++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 tests/CacheImplementationTest.php diff --git a/tests/CacheImplementationTest.php b/tests/CacheImplementationTest.php new file mode 100644 index 00000000..7eb1af51 --- /dev/null +++ b/tests/CacheImplementationTest.php @@ -0,0 +1,44 @@ +setCache($path); + $this->assertTrue($this->class === ucfirst($this->class), 'class name must start with uppercase character'); + $this->assertEquals(0, substr_count($this->class, ' '), 'class name must not contain spaces'); + $this->assertStringEndsWith('Cache', $this->class, 'class name must end with "Cache"'); + } + + /** + * @dataProvider dataCachesProvider + */ + public function testClassType($path) { + $this->setCache($path); + $this->assertInstanceOf(CacheInterface::class, $this->obj); + } + + //////////////////////////////////////////////////////////////////////////// + + public function dataCachesProvider() { + $caches = array(); + foreach (glob(PATH_LIB_CACHES . '*.php') as $path) { + $caches[basename($path, '.php')] = array($path); + } + return $caches; + } + + private function setCache($path) { + require_once $path; + $this->class = basename($path, '.php'); + $this->assertTrue(class_exists($this->class), 'class ' . $this->class . ' doesn\'t exist'); + $this->obj = new $this->class(); + } +}