1 |
|
package liquibase.change; |
2 |
|
|
3 |
|
import java.util.Comparator; |
4 |
|
import java.util.Map; |
5 |
|
import java.util.SortedSet; |
6 |
|
import java.util.TreeSet; |
7 |
|
import java.util.concurrent.ConcurrentHashMap; |
8 |
|
|
9 |
|
import liquibase.exception.UnexpectedLiquibaseException; |
10 |
|
import liquibase.servicelocator.ServiceLocator; |
11 |
|
|
12 |
|
|
13 |
|
|
14 |
|
|
15 |
|
|
16 |
|
|
17 |
|
@see |
18 |
|
|
|
|
| 75.6% |
Uncovered Elements: 10 (41) |
Complexity: 15 |
Complexity Density: 0.56 |
|
19 |
|
public class ChangeFactory { |
20 |
|
|
21 |
|
private static ChangeFactory instance; |
22 |
|
|
23 |
|
private Map<String, SortedSet<Class<? extends Change>>> registry = new ConcurrentHashMap<String, SortedSet<Class<? extends Change>>>(); |
24 |
|
|
|
|
| 83.3% |
Uncovered Elements: 1 (6) |
Complexity: 2 |
Complexity Density: 0.33 |
|
25 |
9
|
private ChangeFactory() {... |
26 |
9
|
Class<? extends Change>[] classes; |
27 |
9
|
try { |
28 |
9
|
classes = ServiceLocator.getInstance().findClasses(Change.class); |
29 |
|
|
30 |
9
|
for (Class<? extends Change> clazz : classes) { |
31 |
|
|
32 |
387
|
register(clazz); |
33 |
|
} |
34 |
|
|
35 |
|
} catch (Exception e) { |
36 |
0
|
throw new UnexpectedLiquibaseException(e); |
37 |
|
} |
38 |
|
|
39 |
|
} |
40 |
|
|
41 |
|
|
42 |
|
|
43 |
|
|
|
|
| 60% |
Uncovered Elements: 2 (5) |
Complexity: 2 |
Complexity Density: 0.67 |
|
44 |
38
|
public static synchronized ChangeFactory getInstance() {... |
45 |
38
|
if (instance == null) { |
46 |
0
|
instance = new ChangeFactory(); |
47 |
|
} |
48 |
38
|
return instance; |
49 |
|
} |
50 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
51 |
9
|
public static void reset() {... |
52 |
9
|
instance = new ChangeFactory(); |
53 |
|
} |
54 |
|
|
|
|
| 75% |
Uncovered Elements: 2 (8) |
Complexity: 3 |
Complexity Density: 0.5 |
|
55 |
394
|
public void register(Class<? extends Change> changeClass) {... |
56 |
394
|
try { |
57 |
394
|
String name = changeClass.newInstance().getChangeMetaData().getName(); |
58 |
394
|
if (registry.get(name) == null) { |
59 |
394
|
registry.put(name, new TreeSet<Class<? extends Change>>(new Comparator<Class<? extends Change>>() { |
|
|
| 0% |
Uncovered Elements: 3 (3) |
Complexity: 2 |
Complexity Density: 0.67 |
|
60 |
0
|
public int compare(Class<? extends Change> o1, Class<? extends Change> o2) {... |
61 |
0
|
try { |
62 |
0
|
return -1 |
63 |
|
* new Integer(o1.newInstance().getChangeMetaData().getPriority()).compareTo(o2 |
64 |
|
.newInstance().getChangeMetaData().getPriority()); |
65 |
|
} catch (Exception e) { |
66 |
0
|
throw new UnexpectedLiquibaseException(e); |
67 |
|
} |
68 |
|
} |
69 |
|
})); |
70 |
|
} |
71 |
394
|
registry.get(name).add(changeClass); |
72 |
|
} catch (Exception e) { |
73 |
0
|
throw new UnexpectedLiquibaseException(e); |
74 |
|
} |
75 |
|
} |
76 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
77 |
2
|
public void unregister(String name) {... |
78 |
2
|
registry.remove(name); |
79 |
|
} |
80 |
|
|
|
|
| 100% |
Uncovered Elements: 0 (1) |
Complexity: 1 |
Complexity Density: 1 |
|
81 |
13
|
public Map<String, SortedSet<Class<? extends Change>>> getRegistry() {... |
82 |
13
|
return registry; |
83 |
|
} |
84 |
|
|
|
|
| 87.5% |
Uncovered Elements: 1 (8) |
Complexity: 3 |
Complexity Density: 0.5 |
|
85 |
25
|
public Change create(String name) {... |
86 |
25
|
SortedSet<Class<? extends Change>> classes = registry.get(name); |
87 |
|
|
88 |
25
|
if (classes == null) { |
89 |
1
|
return null; |
90 |
|
} |
91 |
|
|
92 |
24
|
try { |
93 |
24
|
return classes.iterator().next().newInstance(); |
94 |
|
} catch (Exception e) { |
95 |
0
|
throw new UnexpectedLiquibaseException(e); |
96 |
|
} |
97 |
|
} |
98 |
|
|
99 |
|
} |