File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/hql/ASTParserLoadingTest.java | File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/jpa/removed/RemovedEntityTest.java | |||
Method name: void createTestBaseData()
|
Method name: void testRemoveThenGet()
|
|||
Number of AST nodes: 15 | Number of AST nodes: 15 | |||
1 | Session session = openSession();↵ | 1 | Session s = openSession(); ↵ | |
2 | Transaction txn = session.beginTransaction();↵ | 2 | s.beginTransaction();↵ | |
3 | ↵ | |||
3 | Mammal m1 = new Mammal();↵ | 4 | Item item = new Item(); ↵ | |
4 | m1.setBodyWeight( 11f↵ | 5 | item.setName( "dummy" );↵ | |
5 | );↵ | 6 | s.persist( item ); ↵ | |
6 | m1.setDescription( "Mammal #1" );↵ | 7 | s.getTransaction().commit();↵ | |
8 | ↵ | |||
7 | session.save( m1 );↵ | 9 | s↵ | |
8 | Mammal m2 = new Mammal();↵ | |||
9 | m2.setBodyWeight( 9f ↵ | 10 | .close();↵ | |
11 | Long id = item.getId();↵ | |||
10 | );↵ | 12 | s = openSession(); ↵ | |
11 | m2.setDescription( "Mammal #2" );↵ | 13 | s.beginTransaction(); ↵ | |
12 | m2.setMother( m1 );↵ | 14 | s.delete( item );↵ | |
15 | ↵ | |||
13 | session.save( m2 );↵ | 16 | item = ( Item ) s.get( Item.class, id );↵ | |
17 | ↵ | |||
14 | txn.commit();↵ | 18 | s.getTransaction().commit(); ↵ | |
15 | session.close();↵ | 19 | s.close();↵ | |
16 | createdAnimalIds.add( m1.getId() );↵ | |||
17 | createdAnimalIds.add( m2.getId()↵ | |||
18 | ); | 20 | assertNull( "expecting removed entity to be returned as null from get()", item ); | |
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.0 |
Clones location | Clones are in different classes having the same super class |
Number of node comparisons | 225 |
Number of mapped statements | 2 |
Number of unmapped statements in the first code fragment | 13 |
Number of unmapped statements in the second code fragment | 13 |
Time elapsed for statement mapping (ms) | 0.0 |
Clone type | Type 2 |
ID | Statement | ID | Statement | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | Session session = openSession(); |
| 1 | Session s = openSession(); | ||||||||||
|
| 2 | s.beginTransaction(); | |||||||||||
2 | Transaction txn = session.beginTransaction(); |
| | |||||||||||
| 3 | Item item = new Item(); | ||||||||||||
3 | Mammal m1 = new Mammal(); | | ||||||||||||
|
| 4 | item.setName("dummy"); | |||||||||||
4 | m1.setBodyWeight(11f); |
| | |||||||||||
|
| 5 | s.persist(item); | |||||||||||
5 | m1.setDescription("Mammal #1"); |
| | |||||||||||
|
| 6 | s.getTransaction().commit(); | |||||||||||
6 | session.save(m1); |
| | |||||||||||
7 | Mammal m2 = new Mammal(); | | ||||||||||||
| 8 | Long id = item.getId(); | ||||||||||||
8 | m2.setBodyWeight(9f); |
| | |||||||||||
|
| 9 | s = openSession(); | |||||||||||
9 | m2.setDescription("Mammal #2"); |
| | |||||||||||
| 10 | s.beginTransaction(); | ||||||||||||
10 | m2.setMother(m1); |
| | |||||||||||
| 11 | s.delete(item); | ||||||||||||
11 | session.save(m2); |
| | |||||||||||
| 12 | item = (Item)s.get(Item.class, id); | ||||||||||||
12 | txn.commit(); |
| | |||||||||||
13 | session.close(); |
| 7 | s.close(); | ||||||||||
| 13 | s.getTransaction().commit(); | ||||||||||||
| 14 | s.close(); | ||||||||||||
14 | createdAnimalIds.add(m1.getId()); | | ||||||||||||
| 15 | assertNull("expecting removed entity to be returned as null from get()", item); | ||||||||||||
15 | createdAnimalIds.add(m2.getId()); | |
Row | Violation |
---|---|
1 | Unmatched statement s.beginTransaction(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Unmatched statement Transaction txn=session.beginTransaction(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
3 | Unmatched statement item.setName("dummy"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
4 | Unmatched statement m1.setBodyWeight(11f); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
5 | Unmatched statement s.persist(item); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
6 | Unmatched statement m1.setDescription("Mammal #1"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
7 | Unmatched statement s.getTransaction().commit(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
8 | Unmatched statement session.save(m1); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
9 | Unmatched statement m2.setBodyWeight(9f); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
10 | Unmatched statement s=openSession(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
11 | Unmatched statement m2.setDescription("Mammal #2"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
12 | Unmatched statement m2.setMother(m1); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
13 | Unmatched statement session.save(m2); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
14 | Unmatched statement txn.commit(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |