File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/idgen/enhanced/sequence/PooledSequenceTest.java | File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/idgen/enhanced/table/HiLoTableTest.java | |||
Method name: void testNormalBoundary()
|
Method name: void testNormalBoundary()
|
|||
Number of AST nodes: 28 | Number of AST nodes: 29 | |||
1 | EntityPersister persister = sfi().getEntityPersister( Entity.class.getName() );↵ | 1 | EntityPersister persister = sfi().getEntityPersister( Entity.class.getName() );↵ | |
2 | assertClassAssignability( SequenceStyleGenerator.class, persister.getIdentifierGenerator().getClass() );↵ | 2 | assertClassAssignability( TableGenerator.class, persister.getIdentifierGenerator().getClass() );↵ | |
3 | SequenceStyleGenerator generator = ( SequenceStyleGenerator ) persister.getIdentifierGenerator();↵ | 3 | TableGenerator generator = ( TableGenerator ) persister.getIdentifierGenerator();↵ | |
4 | assertClassAssignability( OptimizerFactory.PooledOptimizer.class, generator.getOptimizer().getClass() );↵ | 4 | assertClassAssignability( OptimizerFactory.HiLoOptimizer.class, generator.getOptimizer().getClass() );↵ | |
5 | OptimizerFactory.PooledOptimizer optimizer = ( OptimizerFactory.PooledOptimizer ) generator.getOptimizer();↵ | 5 | OptimizerFactory.HiLoOptimizer optimizer = ( OptimizerFactory.HiLoOptimizer ) generator.getOptimizer();↵ | |
6 | int increment = optimizer.getIncrementSize();↵ | 6 | int increment = optimizer.getIncrementSize();↵ | |
7 | Entity[] entities = new Entity[ increment + 1 ];↵ | 7 | Entity[] entities = new Entity[ increment + 1 ];↵ | |
8 | Session s = openSession();↵ | 8 | Session s = openSession();↵ | |
9 | s.beginTransaction();↵ | 9 | s.beginTransaction();↵ | |
10 | for ( int i = 0; i < increment; i++ ) {↵ | 10 | for ( int i = 0; i < increment; i++ ) {↵ | |
11 | entities[i] = new Entity( "" + ( i + 1 ) );↵ | 11 | entities[i] = new Entity( "" + ( i + 1 ) );↵ | |
12 | s.save( entities[i] );↵ | 12 | s.save( entities[i] );↵ | |
13 | assertEquals( 2, generator.getDatabaseStructure().getTimesAccessed() ); // initialization calls seq twice↵ | 13 | assertEquals( 1, generator.getTableAccessCount() ); // initialization↵ | |
14 | assertEquals( increment + 1, optimizer.getLastSourceValue() ); // initialization calls seq twice↵ | 14 | assertEquals( 1, optimizer.getLastSourceValue() ); // initialization↵ | |
15 | assertEquals( i + 1, optimizer.getLastValue() );↵ | 15 | assertEquals( i + 1, optimizer.getLastValue() );↵ | |
16 | assertEquals( increment + 1, optimizer.getLastSourceValue() );↵ | 16 | assertEquals( increment + 1, optimizer.getHiValue() );↵ | |
17 | }↵ | 17 | }↵ | |
18 | // now force a "clock over"↵ | 18 | // now force a "clock over"↵ | |
19 | entities[ increment ] = new Entity( "" + increment );↵ | 19 | entities[ increment ] = new Entity( "" + increment );↵ | |
20 | s.save( entities[ increment ] );↵ | 20 | s.save( entities[ increment ] );↵ | |
21 | assertEquals( 3, generator.getDatabaseStructure().getTimesAccessed() ); // initialization (2) + clock over↵ | 21 | assertEquals( 2, generator.getTableAccessCount() ); // initialization↵ | |
22 | assertEquals( ( increment * 2 ) + 1, optimizer.getLastSourceValue() ); // initialization (2) + clock over↵ | 22 | assertEquals( 2, optimizer.getLastSourceValue() ); // initialization↵ | |
23 | assertEquals( increment + 1, optimizer.getLastValue() );↵ | |||
23 | assertEquals( increment + 1, optimizer.getLastValue() );↵ | 24 | assertEquals( ( increment * 2 ) + 1, optimizer.getHiValue() );↵ | |
24 | s.getTransaction().commit();↵ | 25 | s.getTransaction().commit();↵ | |
25 | s.beginTransaction();↵ | 26 | s.beginTransaction();↵ | |
26 | for ( int i = 0; i < entities.length; i++ ) {↵ | 27 | for ( int i = 0; i < entities.length; i++ ) {↵ | |
27 | assertEquals( i + 1, entities[i].getId().intValue() );↵ | 28 | assertEquals( i + 1, entities[i].getId().intValue() );↵ | |
28 | s.delete( entities[i] );↵ | 29 | s.delete( entities[i] );↵ | |
29 | }↵ | 30 | }↵ | |
30 | s.getTransaction().commit();↵ | 31 | s.getTransaction().commit();↵ | |
31 | s.close(); | 32 |
| |
See real code fragment | See real code fragment |
Number of common nesting structure subtrees | 1 |
Number of refactorable cases | 0 |
Number of non-refactorable cases | 1 |
Time elapsed for finding largest common nesting structure subtrees (ms) | 0.7 |
Clones location | Clones are in different classes having the same super class |
Number of node comparisons | 298 |
Number of mapped statements | 23 |
Number of unmapped statements in the first code fragment | 5 |
Number of unmapped statements in the second code fragment | 6 |
Time elapsed for statement mapping (ms) | 133.2 |
Clone type | Type 3 |
ID | Statement | ID | Statement | |||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | EntityPersister persister = sfi().getEntityPersister(Entity.class.getName()); |
| 1 | EntityPersister persister = sfi().getEntityPersister(Entity.class.getName()); | ||||||||||||||||||||||||||||
2 | assertClassAssignability(SequenceStyleGenerator.class, persister.getIdentifierGenerator().getClass()); |
| 2 | assertClassAssignability(TableGenerator.class, persister.getIdentifierGenerator().getClass()); | ||||||||||||||||||||||||||||
3 | SequenceStyleGenerator generator = (SequenceStyleGenerator)persister.getIdentifierGenerator(); |
| 3 | TableGenerator generator = (TableGenerator)persister.getIdentifierGenerator(); | ||||||||||||||||||||||||||||
4 | assertClassAssignability(OptimizerFactory.PooledOptimizer.class, generator.getOptimizer().getClass()); |
| 4 | assertClassAssignability(OptimizerFactory.HiLoOptimizer.class, generator.getOptimizer().getClass()); | ||||||||||||||||||||||||||||
5 | OptimizerFactory.PooledOptimizer optimizer = (OptimizerFactory.PooledOptimizer)generator.getOptimizer(); |
| 5 | OptimizerFactory.HiLoOptimizer optimizer = (OptimizerFactory.HiLoOptimizer)generator.getOptimizer(); | ||||||||||||||||||||||||||||
6 | int increment = optimizer.getIncrementSize(); |
| 6 | int increment = optimizer.getIncrementSize(); | ||||||||||||||||||||||||||||
|
| 7 | Entity[] entities = new Entity[increment + 1]; | |||||||||||||||||||||||||||||
7 | Entity[] entities = new Entity[increment + 1]; |
| | |||||||||||||||||||||||||||||
8 | Session s = openSession(); | 8 | Session s = openSession(); | |||||||||||||||||||||||||||||
9 | s.beginTransaction(); | 9 | s.beginTransaction(); | |||||||||||||||||||||||||||||
10 | for (int i = 0; i < increment; i++) | 10 | for (int i = 0; i < increment; i++) | |||||||||||||||||||||||||||||
|
| 11 | entities[i] = new Entity("" + (i + 1)); | |||||||||||||||||||||||||||||
11 | entities[i] = new Entity("" + (i + 1)); |
| | |||||||||||||||||||||||||||||
12 | s.save(entities[i]); |
| 12 | s.save(entities[i]); | ||||||||||||||||||||||||||||
|
| 13 | assertEquals(1, generator.getTableAccessCount()); | |||||||||||||||||||||||||||||
13 | assertEquals(2, generator.getDatabaseStructure().getTimesAccessed()); |
| | |||||||||||||||||||||||||||||
14 | assertEquals(increment + 1, optimizer.getLastSourceValue()); |
| 14 | assertEquals(1, optimizer.getLastSourceValue()); | ||||||||||||||||||||||||||||
15 | assertEquals(i + 1, optimizer.getLastValue()); |
| 15 | assertEquals(i + 1, optimizer.getLastValue()); | ||||||||||||||||||||||||||||
16 | assertEquals(increment + 1, optimizer.getLastSourceValue()); |
| 16 | assertEquals(increment + 1, optimizer.getHiValue()); | ||||||||||||||||||||||||||||
|
| 17 | entities[increment] = new Entity("" + increment); | |||||||||||||||||||||||||||||
17 | entities[increment] = new Entity("" + increment); |
| | |||||||||||||||||||||||||||||
18 | s.save(entities[increment]); |
| 18 | s.save(entities[increment]); | ||||||||||||||||||||||||||||
|
| 19 | assertEquals(2, generator.getTableAccessCount()); | |||||||||||||||||||||||||||||
19 | assertEquals(3, generator.getDatabaseStructure().getTimesAccessed()); |
| | |||||||||||||||||||||||||||||
|
| 20 | assertEquals(2, optimizer.getLastSourceValue()); | |||||||||||||||||||||||||||||
20 | assertEquals((increment * 2) + 1, optimizer.getLastSourceValue()); |
| 22 | assertEquals((increment * 2) + 1, optimizer.getHiValue()); | ||||||||||||||||||||||||||||
21 | assertEquals(increment + 1, optimizer.getLastValue()); |
| 21 | assertEquals(increment + 1, optimizer.getLastValue()); | ||||||||||||||||||||||||||||
22 | s.getTransaction().commit(); | 23 | s.getTransaction().commit(); | |||||||||||||||||||||||||||||
23 | s.beginTransaction(); | 24 | s.beginTransaction(); | |||||||||||||||||||||||||||||
24 | for (int i = 0; i < entities.length; i++) |
| 25 | for (int i = 0; i < entities.length; i++) | ||||||||||||||||||||||||||||
25 | assertEquals(i + 1, entities[i].getId().intValue()); |
| 26 | assertEquals(i + 1, entities[i].getId().intValue()); | ||||||||||||||||||||||||||||
26 | s.delete(entities[i]); |
| 27 | s.delete(entities[i]); | ||||||||||||||||||||||||||||
27 | s.getTransaction().commit(); | 28 | s.getTransaction().commit(); | |||||||||||||||||||||||||||||
28 | s.close(); | 29 | s.close(); |
Row | Violation |
---|---|
1 | Expression (SequenceStyleGenerator)persister.getIdentifierGenerator() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
2 | Expression (TableGenerator)persister.getIdentifierGenerator() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
3 | Expression generator cannot be unified with expression generator , because common superclass org.hibernate.id.PersistentIdentifierGenerator does not declare member(s) public org.hibernate.id.enhanced.Optimizer getOptimizer() |
4 | Expression (OptimizerFactory.PooledOptimizer)generator.getOptimizer() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
5 | Expression (OptimizerFactory.HiLoOptimizer)generator.getOptimizer() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
6 | Expression generator cannot be unified with expression generator , because common superclass org.hibernate.id.PersistentIdentifierGenerator does not declare member(s) public org.hibernate.id.enhanced.Optimizer getOptimizer() |
7 | Unmatched statement Entity[] entities=new Entity[increment + 1]; cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
8 | Unmatched statement Entity[] entities=new Entity[increment + 1]; cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
9 | Unmatched statement entities[i]=new Entity("" + (i + 1)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
10 | Unmatched statement entities[i]=new Entity("" + (i + 1)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
11 | Type org.hibernate.test.idgen.enhanced.sequence.Entity[] of variable entities does not match with type org.hibernate.test.idgen.enhanced.table.Entity[] of variable entities |
12 | Unmatched statement assertEquals(1,generator.getTableAccessCount()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
13 | Unmatched statement assertEquals(2,generator.getDatabaseStructure().getTimesAccessed()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
14 | Expression increment + 1 cannot be parameterized, because it has dependencies to/from statements that will be extracted |
15 | Expression optimizer cannot be unified with expression optimizer , because common superclass org.hibernate.id.enhanced.OptimizerFactory.OptimizerSupport does not declare member(s) public long getLastValue() |
16 | Expression optimizer.getLastSourceValue() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
17 | Expression optimizer.getHiValue() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
18 | Expression optimizer cannot be unified with expression optimizer , because common superclass org.hibernate.id.enhanced.OptimizerFactory.OptimizerSupport does not declare member(s) public long getHiValue() |
19 | Unmatched statement entities[increment]=new Entity("" + increment); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
20 | Unmatched statement entities[increment]=new Entity("" + increment); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
21 | Type org.hibernate.test.idgen.enhanced.sequence.Entity[] of variable entities does not match with type org.hibernate.test.idgen.enhanced.table.Entity[] of variable entities |
22 | Unmatched statement assertEquals(2,generator.getTableAccessCount()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
23 | Unmatched statement assertEquals(3,generator.getDatabaseStructure().getTimesAccessed()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
24 | Unmatched statement assertEquals(2,optimizer.getLastSourceValue()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
25 | Expression optimizer.getLastSourceValue() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
26 | Expression optimizer.getHiValue() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
27 | Expression optimizer cannot be unified with expression optimizer , because common superclass org.hibernate.id.enhanced.OptimizerFactory.OptimizerSupport does not declare member(s) public long getHiValue() |
28 | Expression optimizer cannot be unified with expression optimizer , because common superclass org.hibernate.id.enhanced.OptimizerFactory.OptimizerSupport does not declare member(s) public long getLastValue() |
29 | Type int of variable entities.length does not match with type int of variable entities.length |
30 | Type org.hibernate.test.idgen.enhanced.sequence.Entity[] of variable entities does not match with type org.hibernate.test.idgen.enhanced.table.Entity[] of variable entities |
31 | Type org.hibernate.test.idgen.enhanced.sequence.Entity[] of variable entities does not match with type org.hibernate.test.idgen.enhanced.table.Entity[] of variable entities |
32 | Clone fragment #1 returns variables increment, i, generator , while Clone fragment #2 returns variables increment, i, generator, optimizer |