2c9f898f967066a23f0380bba61a570b411a989a
[utils] /
1 /*
2  * Copyright 2005 the original author or authors.
3  * 
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  * 
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  * 
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 package org.wamblee.general;
18
19 import junit.framework.TestCase;
20
21 /**
22  * Tests the bean kernel. The lookup of the bean factory itself can be tested
23  * only partially. Using a global property file for all test cases would tie all
24  * test cases together therefore no global property file is used.
25  *
26  * @author Erik Brakkee
27  */
28 public class BeanKernelTest extends TestCase {
29
30     /**
31      * Loads the bean factory based on a property file configuration. Verifies
32      * the correct bean factory is loaded.
33      * 
34      */
35     public void testLoadBeanFactoryFromProperties() {
36         BeanFactory factory = BeanKernel
37                 .lookupBeanFactory("org/wamblee/general/beankernel.properties");
38         assertTrue(factory instanceof TestBeanFactory);
39     }
40
41     /**
42      * Loads the bean factory based on a non-existing property file. 
43      * Verifies that BeanFactoryException is thrown. 
44      * 
45      */
46     public void testNonExistentPropertyFile() {
47         try {
48             BeanKernel
49                     .lookupBeanFactory("org/wamblee/general/beankernel-nonexistent.properties");
50         } catch (BeanFactoryException e) {
51             return; // ok
52         }
53         fail();
54     }
55     
56     /**
57      * Loads the bean factory based on a property file with a non-existing
58      * bean factory defined in it.  
59      * Verifies that BeanFactoryException is thrown. 
60      * 
61      */
62     public void testNonExistentBeanFactory() {
63         try {
64             BeanKernel
65                     .lookupBeanFactory("org/wamblee/general/beankernel-wrong.properties");
66         } catch (BeanFactoryException e) {
67             return; // ok
68         }
69         fail();
70     }
71     
72
73     /**
74      * Retrieves a bean factory throug the bean kernel. Verifies that beans can
75      * be retrieved.
76      * 
77      */
78     public void testRetrieveFactory() {
79         BeanKernel.overrideBeanFactory(new TestBeanFactory()); // bypass
80                                                                 // default
81                                                                 // property
82                                                                 // lookup
83         BeanFactory factory = BeanKernel.getBeanFactory();
84         assertNotNull(factory);
85         assertEquals("hello", factory.find(String.class));
86     }
87
88 }