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/typedonetoone/TypedOneToOneTest.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.set↵ | 1 | Customer cust = new Customer();↵ | |
2 | cust.setCustomerId("xyz123");↵ | |||
3 | cust.setName("Matt");↵ | |||
4 | ↵ | |||
4 | Session(s);↵ | 5 | Session s = openSession();↵ | |
5 | Transaction t = s.beginTransaction();↵ | 6 | Transaction t = s.beginTransaction();↵ | |
6 | User u = new User("Gavin", "nivag");↵ | 7 | ↵ | |
7 | s.persist(u);↵ | |||
8 | u.setPassword("vagni");↵ | 8 | s.persist(cust);↵ | |
9 | t.commit();↵ | 9 | t.commit();↵ | |
10 | s.close();↵ | 10 | s.close();↵ | |
11 | ↵ | |||
11 | s = openSession();↵ | 12 | s = openSession();↵ | |
12 | t = s.beginTransaction();↵ | 13 | t = s.beginTransaction();↵ | |
13 | List logs = s.createCriteria(Log.class).list();↵ | 14 | List results = s.create↵ | |
14 | assertEquals( 2, logs.size() );↵ | |||
15 | s.delete(u);↵ | |||
16 | 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() );↵ | |||
17 | );↵ | 20 | s.delete(cust);↵ | |
18 | t.commit();↵ | 21 | t.commit();↵ | |
19 | 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 | 172 |
Number of mapped statements | 12 |
Number of unmapped statements in the first code fragment | 5 |
Number of unmapped statements in the second code fragment | 5 |
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"); |
| 11 | List results = s.createQuery("from Customer cust left join fetch cust.billingAddress where cust.customerId='xyz123'").list(); | |||||||||||||||||
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(); | ||||||||||||||||||
|
| 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 statefulInterceptor.setSession(s); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Expression s.createQuery("from Customer cust left join fetch cust.billingAddress where cust.customerId='xyz123'").list() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
3 | Expression u cannot be parameterized, because it has dependencies to/from statements that will be extracted |
4 | Type org.hibernate.test.interceptor.User of variable u does not match with type org.hibernate.test.typedonetoone.Customer of variable cust |
5 | 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 |
6 | 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 |
7 | Expression assertEquals(2,logs.size()) is a void method call, and thus it cannot be parameterized |
8 | Expression assertNull(cust.getShippingAddress()) is a void method call, and thus it cannot be parameterized |
9 | Expression assertEquals(2,logs.size()) is a void method call, and thus it cannot be parameterized |
10 | Expression assertNull(cust.getShippingAddress()) is a void method call, and thus it cannot be parameterized |
11 | Expression u cannot be parameterized, because it has dependencies to/from statements that will be extracted |
12 | Type org.hibernate.test.interceptor.User of variable u does not match with type org.hibernate.test.typedonetoone.Customer of variable cust |
13 | Clone fragment #1 returns variables s, u , while Clone fragment #2 returns variables results |