File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/interceptor/InterceptorTest.java | File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/keymanytoone/bidir/component/EagerKeyManyToOneTest.java | |||
Method name: void testStatefulIntercept()
|
Method name: void testLoadEntityWithEagerFetchingToKeyManyToOneReferenceBackToSelfFailureExpected()
|
|||
Number of AST nodes: 17 | Number of AST nodes: 15 | |||
1 | final StatefulInterceptor statefulInterceptor = new StatefulInterceptor();↵ | |||
2 | Session s = openSession( statefulInterceptor );↵ | 1 | Session s = openSession(); ↵ | |
3 | statefulInterceptor.setSession(s);↵ | 2 | s.beginTransaction();↵ | |
3 | ↵ | |||
4 | Transaction t = s.beginTransaction();↵ | 4 | Customer cust = new Customer( "Acme, Inc." ); ↵ | |
5 | User u = new User("Gavin", "nivag");↵ | 5 | Order order = new Order( new Order.Id( cust, 1 ) ); ↵ | |
6 | s.persist(u↵ | 6 | cust.getOrders().add( order );↵ | |
7 | );↵ | 7 | s.save( cust ); ↵ | |
8 | u.setPassword("vagni");↵ | 8 | ↵ | |
9 | t.commit();↵ | 9 | s.getTransaction().commit(); ↵ | |
10 | s.close();↵ | 10 | s.close();↵ | |
11 | ↵ | |||
11 | s = openSession();↵ | 12 | s = openSession(); ↵ | |
12 | t = s.beginTransaction();↵ | 13 | s.beginTransaction(); ↵ | |
13 | List logs = s.createCriteria(Log.class).list();↵ | 14 | ↵ | |
14 | assertEquals( 2, logs.size() );↵ | |||
15 | s.delete(u);↵ | |||
16 | s.createQuery( "delete from Log" ).executeUpdate(↵ | 15 | try {↵ | |
16 | cust = ( Customer ) s.get( Customer.class, cust.getId() );↵ | |||
17 | }↵ | |||
18 | catch( OverflowCondition overflow ) {↵ | |||
19 | fail( "get()/load() caused overflow condition" );↵ | |||
20 | }↵ | |||
17 | );↵ | 21 | s.delete( cust ); ↵ | |
18 | t.commit();↵ | 22 | s.getTransaction().commit(); ↵ | |
19 | s.close(); | 23 |
| |
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 | 169 |
Number of mapped statements | 5 |
Number of unmapped statements in the first code fragment | 12 |
Number of unmapped statements in the second code fragment | 8 |
Time elapsed for statement mapping (ms) | 0.0 |
Clone type | Type 3 |
ID | Statement | ID | Statement | |||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | final StatefulInterceptor statefulInterceptor = new StatefulInterceptor(); | | ||||||||||||||||
2 | Session s = openSession(statefulInterceptor); |
| 1 | Session s = openSession(); | ||||||||||||||
|
| 2 | s.beginTransaction(); | |||||||||||||||
|
| 3 | Customer cust = new Customer("Acme, Inc."); | |||||||||||||||
3 | statefulInterceptor.setSession(s); |
| | |||||||||||||||
|
| 4 | Order order = new Order(new Order.Id(cust, 1)); | |||||||||||||||
4 | Transaction t = s.beginTransaction(); |
| | |||||||||||||||
| 5 | cust.getOrders().add(order); | ||||||||||||||||
5 | User u = new User("Gavin", "nivag"); |
| | |||||||||||||||
|
| 6 | s.save(cust); | |||||||||||||||
6 | s.persist(u); |
| | |||||||||||||||
|
| 7 | s.getTransaction().commit(); | |||||||||||||||
7 | u.setPassword("vagni"); |
| | |||||||||||||||
8 | t.commit(); |
| | |||||||||||||||
9 | s.close(); | 8 | s.close(); | |||||||||||||||
10 | s = openSession(); | 9 | s = openSession(); | |||||||||||||||
|
| 10 | s.beginTransaction(); | |||||||||||||||
11 | t = s.beginTransaction(); |
| | |||||||||||||||
12 | List logs = s.createCriteria(Log.class).list(); |
| | |||||||||||||||
13 | assertEquals(2, logs.size()); | | ||||||||||||||||
14 | s.delete(u); |
| 13 | s.delete(cust); | ||||||||||||||
|
| 14 | s.getTransaction().commit(); | |||||||||||||||
15 | s.createQuery("delete from Log").executeUpdate(); |
| | |||||||||||||||
16 | t.commit(); |
| | |||||||||||||||
17 | s.close(); | 15 | s.close(); |
Row | Violation |
---|---|
1 | Expression openSession(statefulInterceptor) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
2 | Expression openSession() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
3 | Unmatched statement s.beginTransaction(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
4 | Unmatched statement Customer cust=new Customer("Acme, Inc."); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
5 | Unmatched statement statefulInterceptor.setSession(s); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
6 | Unmatched statement Order order=new Order(new Order.Id(cust,1)); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
7 | Unmatched statement Transaction t=s.beginTransaction(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
8 | Unmatched statement User u=new User("Gavin","nivag"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
9 | Unmatched statement s.save(cust); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
10 | Unmatched statement s.persist(u); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
11 | 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 |
12 | Unmatched statement u.setPassword("vagni"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
13 | Unmatched statement t.commit(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
14 | Unmatched statement s.beginTransaction(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
15 | Unmatched statement t=s.beginTransaction(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
16 | Unmatched statement List logs=s.createCriteria(Log.class).list(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
17 | Type org.hibernate.test.interceptor.User of variable u does not match with type org.hibernate.test.keymanytoone.bidir.component.Customer of variable cust |
18 | 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 |
19 | Unmatched statement s.createQuery("delete from Log").executeUpdate(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
20 | Unmatched statement t.commit(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |