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/legacy/FooBarTest.java | |||
Method name: void testAnyMappingReference()
|
Method name: void testLateCollectionAdd()
|
|||
Number of AST nodes: 21 | Number of AST nodes: 19 | |||
1 | Session s = openSession();↵ | 1 | Session s = openSession();↵ | |
2 | s.beginTransaction();↵ | 2 | ↵ | |
3 | PropertyValue redValue = new StringPropertyValue( "red" );↵ | |||
4 | PropertyValue lonliestNumberValue = new IntegerPropertyValue( 1 );↵ | |||
5 | Long id;↵ | |||
6 | PropertySet ps = new PropertySet( "my properties" ↵ | 3 | Baz baz = new Baz();↵ | |
7 | );↵ | 4 | List l = new ArrayList();↵ | |
8 | ps.setSomeSpecificProperty( redValue );↵ | 5 | baz.setS↵ | |
9 | ps.getGeneralProperties().put( "the lonliest number", lonliestNumberValue );↵ | |||
10 | ps.getGen↵ | 6 | tringList(l);↵ | |
7 | l.add("foo");↵ | |||
11 | eralProperties().put( "i like", new StringPropertyValue( "pina coladas" ) ↵ | 8 | Serializable id = s.save(baz);↵ | |
12 | );↵ | 9 | l.add("bar");↵ | |
13 | ps.getGeneralProperties().put( "i also like", new StringPropertyValue( "getting caught in the rain" ) );↵ | 10 | s.↵ | |
14 | s.save( ps ↵ | 11 | flush();↵ | |
12 | l.add("baz");↵ | |||
15 | );↵ | 13 | s.flush();↵ | |
16 | s.getTransaction().commit();↵ | 14 | s.connection().commit();↵ | |
17 | id = ps.getId();↵ | 15 | ↵ | |
18 | s.clear();↵ | 16 | s.close();↵ | |
19 | s.beginTransaction();↵ | 17 | s = openSession();↵ | |
20 | // TODO : setEntity() currently will not work here, but that would be *very* nice↵ | 18 | ↵ | |
21 | // does not work because the corresponding EntityType is then used as the "bind type" rather↵ | |||
22 | // than the "discovered" AnyType...↵ | |||
23 | s.createQuery( "from PropertySet p where p.someSpecificProperty = :ssp" ).setParameter( "ssp", redValue ).list();↵ | |||
24 | s.createQuery( "from PropertySet p where p.someSpecificProperty.id is not null" ).list();↵ | |||
25 | s.createQuery( "from PropertySet p join p.generalProperties gp where gp.id is not null" ).list(↵ | 19 | baz = (Baz) s.load(Baz.class, id);↵ | |
26 | );↵ | 20 | assertTrue( baz.getStringList().size()==3 && baz.getStringList().contains("bar") );↵ | |
27 | s.delete( s.load( PropertySet.class, id ) ↵ | 21 | s.delete(baz);↵ | |
28 | );↵ | 22 | s.flush();↵ | |
29 | s.getTransaction().commit();↵ | 23 | s.connection().commit();↵ | |
30 | s.close(); | 24 |
| |
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 | 399 |
Number of mapped statements | 5 |
Number of unmapped statements in the first code fragment | 16 |
Number of unmapped statements in the second code fragment | 14 |
Time elapsed for statement mapping (ms) | 0.0 |
Clone type | Type 3 |
ID | Statement | ID | Statement | |||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | Session s = openSession(); |
| 1 | Session s = openSession(); | ||||||||||||||||||||||||
| 2 | Baz baz = new Baz(); | ||||||||||||||||||||||||||
2 | s.beginTransaction(); |
| | |||||||||||||||||||||||||
| 3 | List l = new ArrayList(); | ||||||||||||||||||||||||||
3 | PropertyValue redValue = new StringPropertyValue("red"); |
| | |||||||||||||||||||||||||
|
| 4 | baz.setStringList(l); | |||||||||||||||||||||||||
4 | PropertyValue lonliestNumberValue = new IntegerPropertyValue(1); |
| | |||||||||||||||||||||||||
| 5 | l.add("foo"); | ||||||||||||||||||||||||||
5 | Long id; | | ||||||||||||||||||||||||||
|
| 6 | Serializable id = s.save(baz); | |||||||||||||||||||||||||
6 | PropertySet ps = new PropertySet("my properties"); |
| | |||||||||||||||||||||||||
| 7 | l.add("bar"); | ||||||||||||||||||||||||||
7 | ps.setSomeSpecificProperty(redValue); |
| | |||||||||||||||||||||||||
8 | ps.getGeneralProperties().put("the lonliest number", lonliestNumberValue); | | ||||||||||||||||||||||||||
9 | ps.getGeneralProperties().put("i like", new StringPropertyValue("pina coladas")); | | ||||||||||||||||||||||||||
10 | ps.getGeneralProperties().put("i also like", new StringPropertyValue("getting caught in the rain")); | | ||||||||||||||||||||||||||
11 | s.save(ps); |
| | |||||||||||||||||||||||||
12 | s.getTransaction().commit(); |
| 11 | s.connection().commit(); | ||||||||||||||||||||||||
13 | id = ps.getId(); | | ||||||||||||||||||||||||||
14 | s.clear(); |
| 8 | s.flush(); | ||||||||||||||||||||||||
| 9 | l.add("baz"); | ||||||||||||||||||||||||||
15 | s.beginTransaction(); |
| | |||||||||||||||||||||||||
16 | s.createQuery("from PropertySet p where p.someSpecificProperty = :ssp").setParameter("ssp", redValue).list(); |
| | |||||||||||||||||||||||||
17 | s.createQuery("from PropertySet p where p.someSpecificProperty.id is not null").list(); |
| | |||||||||||||||||||||||||
18 | s.createQuery("from PropertySet p join p.generalProperties gp where gp.id is not null").list(); |
| | |||||||||||||||||||||||||
19 | s.delete(s.load(PropertySet.class, id)); |
| 10 | s.flush(); | ||||||||||||||||||||||||
20 | s.getTransaction().commit(); |
| | |||||||||||||||||||||||||
21 | s.close(); |
| 12 | s.close(); | ||||||||||||||||||||||||
|
| 13 | s = openSession(); | |||||||||||||||||||||||||
| 14 | baz = (Baz)s.load(Baz.class, id); | ||||||||||||||||||||||||||
| 15 | assertTrue(baz.getStringList().size() == 3 && baz.getStringList().contains("bar")); | ||||||||||||||||||||||||||
| 16 | s.delete(baz); | ||||||||||||||||||||||||||
| 17 | s.flush(); | ||||||||||||||||||||||||||
| 18 | s.connection().commit(); | ||||||||||||||||||||||||||
| 19 | s.close(); |
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 PropertyValue redValue=new StringPropertyValue("red"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
3 | Unmatched statement baz.setStringList(l); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
4 | Unmatched statement PropertyValue lonliestNumberValue=new IntegerPropertyValue(1); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
5 | Unmatched statement Serializable id=s.save(baz); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
6 | Unmatched statement PropertySet ps=new PropertySet("my properties"); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
7 | Unmatched statement ps.setSomeSpecificProperty(redValue); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
8 | Unmatched statement s.save(ps); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
9 | Expression s.getTransaction() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
10 | Expression s.connection() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
11 | Type org.hibernate.Transaction of variable s.getTransaction() does not match with type java.sql.Connection of variable s.connection() |
12 | Expression s.clear() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
13 | Expression s.flush() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
14 | Expression s.clear() is a void method call, and thus it cannot be parameterized |
15 | Expression s.flush() is a void method call, and thus it cannot be parameterized |
16 | Unmatched statement s.beginTransaction(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
17 | Unmatched statement s.createQuery("from PropertySet p where p.someSpecificProperty = :ssp").setParameter("ssp",redValue).list(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
18 | Unmatched statement s.createQuery("from PropertySet p where p.someSpecificProperty.id is not null").list(); 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("from PropertySet p join p.generalProperties gp where gp.id is not null").list(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
20 | Expression s.delete(s.load(PropertySet.class,id)) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
21 | Expression s.flush() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
22 | Expression s.delete(s.load(PropertySet.class,id)) is a void method call, and thus it cannot be parameterized |
23 | Expression s.flush() is a void method call, and thus it cannot be parameterized |
24 | Expression s.delete(s.load(PropertySet.class,id)) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
25 | Expression s.flush() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
26 | Expression s.delete(s.load(PropertySet.class,id)) is a void method call, and thus it cannot be parameterized |
27 | Expression s.flush() is a void method call, and thus it cannot be parameterized |
28 | 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 |
29 | Unmatched statement s=openSession(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
30 | Clone fragment #1 returns variable s with type org.hibernate.Session , while Clone fragment #2 returns variable s with type org.hibernate.classic.Session |