統計
| ブランチ: | リビジョン:

pictcode / lib / Cake / Test / Case / Utility / ClassRegistryTest.php @ 515fc59d

履歴 | 表示 | アノテート | ダウンロード (8.353 KB)

1
<?php
2
/**
3
 * ClassRegistryTest file
4
 *
5
 * CakePHP(tm) Tests <http://book.cakephp.org/2.0/en/development/testing.html>
6
 * Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
7
 *
8
 * Licensed under The MIT License
9
 * For full copyright and license information, please see the LICENSE.txt
10
 * Redistributions of files must retain the above copyright notice
11
 *
12
 * @copyright     Copyright (c) Cake Software Foundation, Inc. (http://cakefoundation.org)
13
 * @link          http://book.cakephp.org/2.0/en/development/testing.html CakePHP(tm) Tests
14
 * @package       Cake.Test.Case.Utility
15
 * @since         CakePHP(tm) v 1.2.0.5432
16
 * @license       http://www.opensource.org/licenses/mit-license.php MIT License
17
 */
18

    
19
App::uses('ClassRegistry', 'Utility');
20

    
21
/**
22
 * ClassRegisterModel class
23
 *
24
 * @package       Cake.Test.Case.Utility
25
 */
26
class ClassRegisterModel extends CakeTestModel {
27

    
28
/**
29
 * useTable property
30
 *
31
 * @var bool
32
 */
33
        public $useTable = false;
34
}
35

    
36
/**
37
 * RegisterArticle class
38
 *
39
 * @package       Cake.Test.Case.Utility
40
 */
41
class RegisterArticle extends ClassRegisterModel {
42
}
43

    
44
/**
45
 * RegisterArticleFeatured class
46
 *
47
 * @package       Cake.Test.Case.Utility
48
 */
49
class RegisterArticleFeatured extends ClassRegisterModel {
50
}
51

    
52
/**
53
 * RegisterArticleTag class
54
 *
55
 * @package       Cake.Test.Case.Utility
56
 */
57
class RegisterArticleTag extends ClassRegisterModel {
58
}
59

    
60
/**
61
 * RegistryPluginAppModel class
62
 *
63
 * @package       Cake.Test.Case.Utility
64
 */
65
class RegistryPluginAppModel extends ClassRegisterModel {
66

    
67
/**
68
 * tablePrefix property
69
 *
70
 * @var string
71
 */
72
        public $tablePrefix = 'something_';
73
}
74

    
75
/**
76
 * TestRegistryPluginModel class
77
 *
78
 * @package       Cake.Test.Case.Utility
79
 */
80
class TestRegistryPluginModel extends RegistryPluginAppModel {
81
}
82

    
83
/**
84
 * RegisterCategory class
85
 *
86
 * @package       Cake.Test.Case.Utility
87
 */
88
class RegisterCategory extends ClassRegisterModel {
89
}
90
/**
91
 * RegisterPrefixedDs class
92
 *
93
 * @package       Cake.Test.Case.Utility
94
 */
95
class RegisterPrefixedDs extends ClassRegisterModel {
96

    
97
/**
98
 * useDbConfig property
99
 *
100
 * @var string
101
 */
102
        public $useDbConfig = 'doesnotexist';
103
}
104

    
105
/**
106
 * Abstract class for testing ClassRegistry.
107
 */
108
abstract class ClassRegistryAbstractModel extends ClassRegisterModel {
109

    
110
        public abstract function doSomething();
111

    
112
}
113

    
114
/**
115
 * Interface for testing ClassRegistry
116
 */
117
interface ClassRegistryInterfaceTest {
118

    
119
        public function doSomething();
120

    
121
}
122

    
123
/**
124
 * ClassRegistryTest class
125
 *
126
 * @package       Cake.Test.Case.Utility
127
 */
128
class ClassRegistryTest extends CakeTestCase {
129

    
130
/**
131
 * testAddModel method
132
 *
133
 * @return void
134
 */
135
        public function testAddModel() {
136
                $Tag = ClassRegistry::init('RegisterArticleTag');
137
                $this->assertInstanceOf('RegisterArticleTag', $Tag);
138

    
139
                $TagCopy = ClassRegistry::isKeySet('RegisterArticleTag');
140
                $this->assertTrue($TagCopy);
141

    
142
                $Tag->name = 'SomeNewName';
143

    
144
                $TagCopy = ClassRegistry::getObject('RegisterArticleTag');
145

    
146
                $this->assertInstanceOf('RegisterArticleTag', $TagCopy);
147
                $this->assertSame($Tag, $TagCopy);
148

    
149
                $NewTag = ClassRegistry::init(array('class' => 'RegisterArticleTag', 'alias' => 'NewTag'));
150
                $this->assertInstanceOf('RegisterArticleTag', $Tag);
151

    
152
                $NewTagCopy = ClassRegistry::init(array('class' => 'RegisterArticleTag', 'alias' => 'NewTag'));
153

    
154
                $this->assertNotSame($Tag, $NewTag);
155
                $this->assertSame($NewTag, $NewTagCopy);
156

    
157
                $NewTag->name = 'SomeOtherName';
158
                $this->assertNotSame($Tag, $NewTag);
159
                $this->assertSame($NewTag, $NewTagCopy);
160

    
161
                $Tag->name = 'SomeOtherName';
162
                $this->assertNotSame($Tag, $NewTag);
163

    
164
                $this->assertTrue($TagCopy->name === 'SomeOtherName');
165

    
166
                $User = ClassRegistry::init(array('class' => 'RegisterUser', 'alias' => 'User', 'table' => false));
167
                $this->assertInstanceOf('AppModel', $User);
168

    
169
                $UserCopy = ClassRegistry::init(array('class' => 'RegisterUser', 'alias' => 'User', 'table' => false));
170
                $this->assertInstanceOf('AppModel', $UserCopy);
171
                $this->assertEquals($User, $UserCopy);
172

    
173
                $Category = ClassRegistry::init(array('class' => 'RegisterCategory'));
174
                $this->assertInstanceOf('RegisterCategory', $Category);
175

    
176
                $ParentCategory = ClassRegistry::init(array('class' => 'RegisterCategory', 'alias' => 'ParentCategory'));
177
                $this->assertInstanceOf('RegisterCategory', $ParentCategory);
178
                $this->assertNotSame($Category, $ParentCategory);
179

    
180
                $this->assertNotEquals($Category->alias, $ParentCategory->alias);
181
                $this->assertEquals('RegisterCategory', $Category->alias);
182
                $this->assertEquals('ParentCategory', $ParentCategory->alias);
183
        }
184

    
185
/**
186
 * testClassRegistryFlush method
187
 *
188
 * @return void
189
 */
190
        public function testClassRegistryFlush() {
191
                ClassRegistry::init('RegisterArticleTag');
192

    
193
                $ArticleTag = ClassRegistry::getObject('RegisterArticleTag');
194
                $this->assertInstanceOf('RegisterArticleTag', $ArticleTag);
195
                ClassRegistry::flush();
196

    
197
                $NoArticleTag = ClassRegistry::isKeySet('RegisterArticleTag');
198
                $this->assertFalse($NoArticleTag);
199
                $this->assertInstanceOf('RegisterArticleTag', $ArticleTag);
200
        }
201

    
202
/**
203
 * testAddMultipleModels method
204
 *
205
 * @return void
206
 */
207
        public function testAddMultipleModels() {
208
                $Article = ClassRegistry::isKeySet('Article');
209
                $this->assertFalse($Article);
210

    
211
                $Featured = ClassRegistry::isKeySet('Featured');
212
                $this->assertFalse($Featured);
213

    
214
                $Tag = ClassRegistry::isKeySet('Tag');
215
                $this->assertFalse($Tag);
216

    
217
                $models = array(array('class' => 'RegisterArticle', 'alias' => 'Article'),
218
                                array('class' => 'RegisterArticleFeatured', 'alias' => 'Featured'),
219
                                array('class' => 'RegisterArticleTag', 'alias' => 'Tag'));
220

    
221
                $added = ClassRegistry::init($models);
222
                $this->assertTrue($added);
223

    
224
                $Article = ClassRegistry::isKeySet('Article');
225
                $this->assertTrue($Article);
226

    
227
                $Featured = ClassRegistry::isKeySet('Featured');
228
                $this->assertTrue($Featured);
229

    
230
                $Tag = ClassRegistry::isKeySet('Tag');
231
                $this->assertTrue($Tag);
232

    
233
                $Article = ClassRegistry::getObject('Article');
234
                $this->assertInstanceOf('RegisterArticle', $Article);
235

    
236
                $Featured = ClassRegistry::getObject('Featured');
237
                $this->assertInstanceOf('RegisterArticleFeatured', $Featured);
238

    
239
                $Tag = ClassRegistry::getObject('Tag');
240
                $this->assertInstanceOf('RegisterArticleTag', $Tag);
241
        }
242

    
243
/**
244
 * testPluginAppModel method
245
 *
246
 * @return void
247
 */
248
        public function testPluginAppModel() {
249
                $TestRegistryPluginModel = ClassRegistry::isKeySet('TestRegistryPluginModel');
250
                $this->assertFalse($TestRegistryPluginModel);
251

    
252
                //Faking a plugin
253
                CakePlugin::load('RegistryPlugin', array('path' => '/fake/path'));
254
                $TestRegistryPluginModel = ClassRegistry::init('RegistryPlugin.TestRegistryPluginModel');
255
                $this->assertInstanceOf('TestRegistryPluginModel', $TestRegistryPluginModel);
256

    
257
                $this->assertEquals('something_', $TestRegistryPluginModel->tablePrefix);
258

    
259
                $PluginUser = ClassRegistry::init(array('class' => 'RegistryPlugin.RegisterUser', 'alias' => 'RegistryPluginUser', 'table' => false));
260
                $this->assertInstanceOf('RegistryPluginAppModel', $PluginUser);
261

    
262
                $PluginUserCopy = ClassRegistry::getObject('RegistryPluginUser');
263
                $this->assertInstanceOf('RegistryPluginAppModel', $PluginUserCopy);
264
                $this->assertSame($PluginUser, $PluginUserCopy);
265
                CakePlugin::unload();
266
        }
267

    
268
/**
269
 * Tests prefixed datasource names for test purposes
270
 *
271
 * @return void
272
 */
273
        public function testPrefixedTestDatasource() {
274
                ClassRegistry::config(array('testing' => true));
275
                $Model = ClassRegistry::init('RegisterPrefixedDs');
276
                $this->assertEquals('test', $Model->useDbConfig);
277
                ClassRegistry::removeObject('RegisterPrefixedDs');
278

    
279
                $testConfig = ConnectionManager::getDataSource('test')->config;
280
                ConnectionManager::create('test_doesnotexist', $testConfig);
281

    
282
                $Model = ClassRegistry::init('RegisterArticle');
283
                $this->assertEquals('test', $Model->useDbConfig);
284
                $Model = ClassRegistry::init('RegisterPrefixedDs');
285
                $this->assertEquals('test_doesnotexist', $Model->useDbConfig);
286
        }
287

    
288
/**
289
 * Tests that passing the string parameter to init() will return false if the model does not exists
290
 *
291
 * @return void
292
 */
293
        public function testInitStrict() {
294
                $this->assertFalse(ClassRegistry::init('NonExistent', true));
295
        }
296

    
297
/**
298
 * Test that you cannot init() an abstract class. An exception will be raised.
299
 *
300
 * @expectedException CakeException
301
 * @return void
302
 */
303
        public function testInitAbstractClass() {
304
                ClassRegistry::init('ClassRegistryAbstractModel');
305
        }
306

    
307
/**
308
 * Test that you cannot init() an abstract class. A exception will be raised.
309
 *
310
 * @expectedException CakeException
311
 * @return void
312
 */
313
        public function testInitInterface() {
314
                ClassRegistry::init('ClassRegistryInterfaceTest');
315
        }
316
}