aboutsummaryrefslogtreecommitdiffstats
path: root/tests/class_loader
diff options
context:
space:
mode:
authorNils Adermann <naderman@naderman.de>2011-08-15 21:38:47 -0400
committerNils Adermann <naderman@naderman.de>2011-09-29 15:42:46 +0200
commit96209e022477d97b581b79cabace4caddd19501b (patch)
tree660134bf3d3bc3a3ab50a222e789aafea5379b4a /tests/class_loader
parent989bd9cde7314024999f5b92fc2ff4572b9ac937 (diff)
downloadforums-96209e022477d97b581b79cabace4caddd19501b.tar
forums-96209e022477d97b581b79cabace4caddd19501b.tar.gz
forums-96209e022477d97b581b79cabace4caddd19501b.tar.bz2
forums-96209e022477d97b581b79cabace4caddd19501b.tar.xz
forums-96209e022477d97b581b79cabace4caddd19501b.zip
[feature/extension-manager] The class loader no longer knows about extensions
Instead the class loader is instantiated twice. Once with the phpbb_ prefix and once with the phpbb_ext_ prefix. PHPBB3-10323
Diffstat (limited to 'tests/class_loader')
-rw-r--r--tests/class_loader/class_loader_test.php46
-rw-r--r--tests/class_loader/ext/foo/class.php6
2 files changed, 30 insertions, 22 deletions
diff --git a/tests/class_loader/class_loader_test.php b/tests/class_loader/class_loader_test.php
index 7d5f57aac3..9744a1c703 100644
--- a/tests/class_loader/class_loader_test.php
+++ b/tests/class_loader/class_loader_test.php
@@ -13,20 +13,26 @@ class phpbb_class_loader_test extends PHPUnit_Framework_TestCase
{
public function setUp()
{
- global $class_loader;
- $class_loader->unregister();
+ global $phpbb_class_loader;
+ $phpbb_class_loader->unregister();
+
+ global $phpbb_class_loader_ext;
+ $phpbb_class_loader_ext->unregister();
}
public function tearDown()
{
- global $class_loader;
- $class_loader->register();
+ global $phpbb_class_loader_ext;
+ $phpbb_class_loader_ext->register();
+
+ global $phpbb_class_loader;
+ $phpbb_class_loader->register();
}
public function test_resolve_path()
{
$prefix = dirname(__FILE__) . '/';
- $class_loader = new phpbb_class_loader($prefix . 'includes/', $prefix . 'ext/');
+ $class_loader = new phpbb_class_loader('phpbb_', $prefix . 'includes/');
$prefix .= 'includes/';
@@ -56,20 +62,19 @@ class phpbb_class_loader_test extends PHPUnit_Framework_TestCase
$class_loader->resolve_path('phpbb_dir2'),
'Class with name of dir within dir (short class name)'
);
- $this->assertEquals(
- dirname(__FILE__) . '/ext/foo/class.php',
- $class_loader->resolve_path('phpbb_ext_foo_class'),
- 'Extension class'
- );
}
public function test_resolve_cached()
{
- $cacheMap = array('class_loader' => array('phpbb_a_cached_name' => 'a/cached_name'));
- $cache = new phpbb_mock_cache($cacheMap);
+ $cache_map = array(
+ 'class_loader_phpbb_' => array('phpbb_a_cached_name' => 'a/cached_name'),
+ 'class_loader_phpbb_ext_' => array('phpbb_ext_foo' => 'foo'),
+ );
+ $cache = new phpbb_mock_cache($cache_map);
$prefix = dirname(__FILE__) . '/';
- $class_loader = new phpbb_class_loader($prefix . 'includes/', $prefix . 'ext/', '.php', $cache);
+ $class_loader = new phpbb_class_loader('phpbb_', $prefix . 'includes/', '.php', $cache);
+ $class_loader_ext = new phpbb_class_loader('phpbb_ext_', $prefix . 'includes/', '.php', $cache);
$prefix .= 'includes/';
@@ -79,13 +84,22 @@ class phpbb_class_loader_test extends PHPUnit_Framework_TestCase
'Class in a directory'
);
+ $this->assertFalse($class_loader->resolve_path('phpbb_ext_foo'));
+ $this->assertFalse($class_loader_ext->resolve_path('phpbb_a_cached_name'));
+
$this->assertEquals(
$prefix . 'a/cached_name.php',
$class_loader->resolve_path('phpbb_a_cached_name'),
- 'Class in a directory'
+ 'Cached class found'
+ );
+
+ $this->assertEquals(
+ $prefix . 'foo.php',
+ $class_loader_ext->resolve_path('phpbb_ext_foo'),
+ 'Cached class found in alternative loader'
);
- $cacheMap['class_loader']['phpbb_dir_class_name'] = 'dir/class_name';
- $cache->check($this, $cacheMap);
+ $cache_map['class_loader_phpbb_']['phpbb_dir_class_name'] = 'dir/class_name';
+ $cache->check($this, $cache_map);
}
}
diff --git a/tests/class_loader/ext/foo/class.php b/tests/class_loader/ext/foo/class.php
deleted file mode 100644
index 7b1555c98d..0000000000
--- a/tests/class_loader/ext/foo/class.php
+++ /dev/null
@@ -1,6 +0,0 @@
-<?php
-
-class phpbb_ext_foo_class
-{
-}
-