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/legacy/FooBarTest.java | |||
Method name: void testStatefulIntercept()
|
Method name: void testSerializableType()
|
|||
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);↵ | |||
4 | Transaction t = s.beginTransaction();↵ | |||
5 | User u = new User("Gavin", "nivag");↵ | |||
6 | s.persist(u);↵ | |||
7 | u.setPassword("vagni");↵ | |||
8 | t↵ | 1 | Session s = openSession();↵ | |
2 | Vetoer v = new Vetoer();↵ | |||
3 | v.setStrings( new String[] { "foo", "bar", "baz" } );↵ | |||
4 | s.save(v); Serializable id = s.save(v);↵ | |||
5 | v.getStrings()[1] = "osama";↵ | |||
6 | s.flush();↵ | |||
9 | .commit();↵ | 7 | s.connection().commit();↵ | |
10 | s.close();↵ | 8 | s.close();↵ | |
11 | s = openSession();↵ | 9 | s = openSession();↵ | |
12 | t = s.beginTransaction();↵ | 10 | v = ↵ | |
13 | List logs = s.createCriteria(Log.class).list();↵ | |||
14 | assertEquals( 2, logs.size(↵ | 11 | (Vetoer) s.load(Vetoer.class, id);↵ | |
15 | ) );↵ | 12 | assertTrue( "serializable type", v.getStrings()[1].equals("osama") );↵ | |
16 | s.delete(u);↵ | 13 | s.delete(v);↵ | |
17 | s.createQuery( "delete from Log" ).executeUpdate();↵ | |||
18 | t↵ | 14 | s.delete(v);↵ | |
15 | s.flush();↵ | |||
19 | .commit();↵ | 16 | s.connection().commit();↵ | |
20 | s.close(); | 17 |
| |
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 | 229 |
Number of mapped statements | 6 |
Number of unmapped statements in the first code fragment | 11 |
Number of unmapped statements in the second code fragment | 11 |
Time elapsed for statement mapping (ms) | 0.0 |
Clone type | Type 2 |
ID | Statement | ID | Statement | |||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | final StatefulInterceptor statefulInterceptor = new StatefulInterceptor(); | | ||||||||||||||||||||||||||
2 | Session s = openSession(statefulInterceptor); |
| 1 | Session s = openSession(); | ||||||||||||||||||||||||
| 2 | Vetoer v = new Vetoer(); | ||||||||||||||||||||||||||
|
| 3 | v.setStrings(new String[] {"foo", "bar", "baz"}); | |||||||||||||||||||||||||
3 | statefulInterceptor.setSession(s); |
| | |||||||||||||||||||||||||
|
| 4 | s.save(v); | |||||||||||||||||||||||||
4 | Transaction t = s.beginTransaction(); |
| | |||||||||||||||||||||||||
|
| 5 | Serializable id = s.save(v); | |||||||||||||||||||||||||
5 | User u = new User("Gavin", "nivag"); |
| | |||||||||||||||||||||||||
| 6 | v.getStrings()[1] = "osama"; | ||||||||||||||||||||||||||
6 | s.persist(u); |
| 7 | s.flush(); | ||||||||||||||||||||||||
7 | u.setPassword("vagni"); |
| | |||||||||||||||||||||||||
|
| 8 | s.connection().commit(); | |||||||||||||||||||||||||
8 | t.commit(); |
| | |||||||||||||||||||||||||
9 | s.close(); |
| 9 | s.close(); | ||||||||||||||||||||||||
10 | s = openSession(); |
| 10 | s = openSession(); | ||||||||||||||||||||||||
|
| 11 | v = (Vetoer)s.load(Vetoer.class, id); | |||||||||||||||||||||||||
11 | t = s.beginTransaction(); |
| | |||||||||||||||||||||||||
| 12 | assertTrue("serializable type", v.getStrings()[1].equals("osama")); | ||||||||||||||||||||||||||
12 | List logs = s.createCriteria(Log.class).list(); |
| | |||||||||||||||||||||||||
|
| 13 | s.delete(v); | |||||||||||||||||||||||||
13 | assertEquals(2, logs.size()); | | ||||||||||||||||||||||||||
14 | s.delete(u); |
| 14 | s.delete(v); | ||||||||||||||||||||||||
|
| 15 | s.flush(); | |||||||||||||||||||||||||
15 | s.createQuery("delete from Log").executeUpdate(); |
| | |||||||||||||||||||||||||
|
| 16 | s.connection().commit(); | |||||||||||||||||||||||||
16 | t.commit(); |
| | |||||||||||||||||||||||||
17 | s.close(); |
| 17 | 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 v.setStrings(new String[]{"foo","bar","baz"}); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
4 | 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 |
5 | Unmatched statement s.save(v); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
6 | 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 |
7 | Unmatched statement Serializable id=s.save(v); 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 | Expression s.persist(u) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
10 | Expression s.flush() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
11 | Expression s.persist(u) is a void method call, and thus it cannot be parameterized |
12 | Expression s.flush() is a void method call, and thus it cannot be parameterized |
13 | Expression s.persist(u) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
14 | Expression s.flush() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
15 | Expression s.persist(u) is a void method call, and thus it cannot be parameterized |
16 | Expression s.flush() is a void method call, and thus it cannot be parameterized |
17 | Unmatched statement u.setPassword("vagni"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
18 | Unmatched statement s.connection().commit(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
19 | Unmatched statement t.commit(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
20 | Unmatched statement v=(Vetoer)s.load(Vetoer.class,id); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
21 | 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 |
22 | 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 |
23 | Unmatched statement s.delete(v); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
24 | Type org.hibernate.test.interceptor.User of variable u does not match with type org.hibernate.test.legacy.Vetoer of variable v |
25 | Unmatched statement s.flush(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
26 | 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 |
27 | Unmatched statement s.connection().commit(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
28 | Unmatched statement t.commit(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
29 | Clone fragment #1 returns variable s with type org.hibernate.Session , while Clone fragment #2 returns variable s with type org.hibernate.classic.Session |