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/typedmanytoone/TypedManyToOneTest.java | |||
Method name: void testStatefulIntercept()
|
Method name: void testCreateQueryNull()
|
|||
Number of AST nodes: 17 | Number of AST nodes: 17 | |||
1 | final StatefulInterceptor statefulInterceptor = new StatefulInterceptor();↵ | |||
2 | Session s = openSession( statefulInterceptor );↵ | |||
3 | statefulInterceptor.setSession(s);↵ | |||
1 | Customer cust = new Customer();↵ | |||
2 | cust.setCustomerId("xyz123");↵ | |||
3 | cust.setName("Matt");↵ | |||
4 | ↵ | |||
5 | Session s = openSession();↵ | |||
4 | Transaction t = s.beginTransaction();↵ | 6 | Transaction t = s.beginTransaction();↵ | |
5 | User u = new User("Gavin", "nivag");↵ | 7 | ↵ | |
6 | s.persist(u);↵ | |||
7 | u.setPassword("vagni");↵ | 8 | s.persist(cust);↵ | |
8 | t.commit();↵ | 9 | t.commit();↵ | |
9 | s.close();↵ | 10 | s.close();↵ | |
11 | ↵ | |||
10 | s = openSession();↵ | 12 | s = openSession();↵ | |
11 | t = s.beginTransaction();↵ | 13 | t = s.beginTransaction();↵ | |
12 | List logs = s.createCriteria(Log.class).list();↵ | 14 | List results = s.create↵ | |
13 | assertEquals( 2, logs.size() );↵ | |||
14 | s.delete(u);↵ | |||
15 | s.createQuery( "delete from Log" ).executeUpdate(↵ | 15 | Query("from Customer cust left join fetch cust.billingAddress where cust.customerId='xyz123'").list();↵ | |
16 | //List results = s.createQuery("from Customer cust left join fetch cust.billingAddress left join fetch cust.shippingAddress").list();↵ | |||
17 | cust = (Customer) results.get(0);↵ | |||
18 | assertNull( cust.getShippingAddress() );↵ | |||
19 | assertNull( cust.getBillingAddress() );↵ | |||
16 | );↵ | 20 | s.delete( cust );↵ | |
17 | t.commit();↵ | 21 | t.commit();↵ | |
18 | s.close(); | 22 |
| |
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 | 178 |
Number of mapped statements | 11 |
Number of unmapped statements in the first code fragment | 6 |
Number of unmapped statements in the second code fragment | 6 |
Time elapsed for statement mapping (ms) | 0.0 |
Clone type | Type 2 |
ID | Statement | ID | Statement | ||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| 1 | Customer cust = new Customer(); | |||||||||||||||||||||||
1 | final StatefulInterceptor statefulInterceptor = new StatefulInterceptor(); | | |||||||||||||||||||||||
|
| 2 | cust.setCustomerId("xyz123"); | ||||||||||||||||||||||
|
| 3 | cust.setName("Matt"); | ||||||||||||||||||||||
2 | Session s = openSession(statefulInterceptor); |
| 4 | Session s = openSession(); | |||||||||||||||||||||
3 | statefulInterceptor.setSession(s); |
| | ||||||||||||||||||||||
4 | Transaction t = s.beginTransaction(); | 5 | Transaction t = s.beginTransaction(); | ||||||||||||||||||||||
5 | User u = new User("Gavin", "nivag"); |
| | ||||||||||||||||||||||
6 | s.persist(u); |
| 6 | s.persist(cust); | |||||||||||||||||||||
7 | u.setPassword("vagni"); |
| | ||||||||||||||||||||||
8 | t.commit(); | 7 | t.commit(); | ||||||||||||||||||||||
9 | s.close(); | 8 | s.close(); | ||||||||||||||||||||||
10 | s = openSession(); | 9 | s = openSession(); | ||||||||||||||||||||||
11 | t = s.beginTransaction(); | 10 | t = s.beginTransaction(); | ||||||||||||||||||||||
|
| 11 | List results = s.createQuery("from Customer cust left join fetch cust.billingAddress where cust.customerId='xyz123'").list(); | ||||||||||||||||||||||
|
| 12 | cust = (Customer)results.get(0); | ||||||||||||||||||||||
12 | List logs = s.createCriteria(Log.class).list(); |
| | ||||||||||||||||||||||
13 | assertEquals(2, logs.size()); |
| 13 | assertNull(cust.getShippingAddress()); | |||||||||||||||||||||
| 14 | assertNull(cust.getBillingAddress()); | |||||||||||||||||||||||
14 | s.delete(u); |
| 15 | s.delete(cust); | |||||||||||||||||||||
15 | s.createQuery("delete from Log").executeUpdate(); |
| | ||||||||||||||||||||||
16 | t.commit(); | 16 | t.commit(); | ||||||||||||||||||||||
17 | s.close(); | 17 | s.close(); |
Row | Violation |
---|---|
1 | Unmatched statement cust.setCustomerId("xyz123"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
2 | Unmatched statement cust.setName("Matt"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
3 | Expression openSession(statefulInterceptor) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
4 | Expression openSession() cannot be parameterized, because it has dependencies to/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 User u=new User("Gavin","nivag"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
7 | Type org.hibernate.test.interceptor.User of variable u does not match with type org.hibernate.test.typedmanytoone.Customer of variable cust |
8 | Unmatched statement u.setPassword("vagni"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
9 | Unmatched statement List results=s.createQuery("from Customer cust left join fetch cust.billingAddress where cust.customerId='xyz123'").list(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
10 | Unmatched statement cust=(Customer)results.get(0); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
11 | 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 |
12 | Expression assertEquals(2,logs.size()) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
13 | Expression assertNull(cust.getShippingAddress()) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
14 | Expression assertEquals(2,logs.size()) is a void method call, and thus it cannot be parameterized |
15 | Expression assertNull(cust.getShippingAddress()) is a void method call, and thus it cannot be parameterized |
16 | Expression assertEquals(2,logs.size()) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
17 | Expression assertNull(cust.getShippingAddress()) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
18 | Expression assertEquals(2,logs.size()) is a void method call, and thus it cannot be parameterized |
19 | Expression assertNull(cust.getShippingAddress()) is a void method call, and thus it cannot be parameterized |
20 | Type org.hibernate.test.interceptor.User of variable u does not match with type org.hibernate.test.typedmanytoone.Customer of variable cust |
21 | 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 |