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 | 4 |
Number of unmapped statements in the first code fragment | 17 |
Number of unmapped statements in the second code fragment | 15 |
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"); | ||||||||||||||||||||||
| 10 | s.flush(); | ||||||||||||||||||||||
|
| 13 | s = openSession(); | |||||||||||||||||||||
| 14 | baz = (Baz)s.load(Baz.class, id); | ||||||||||||||||||||||
15 | s.beginTransaction(); | | ||||||||||||||||||||||
| 16 | s.delete(baz); | ||||||||||||||||||||||
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)); | | ||||||||||||||||||||||
20 | s.getTransaction().commit(); |
| 15 | assertTrue(baz.getStringList().size() == 3 && baz.getStringList().contains("bar")); | ||||||||||||||||||||
21 | s.close(); |
| 12 | s.close(); | ||||||||||||||||||||
| 17 | s.flush(); | ||||||||||||||||||||||
| 18 | s.connection().commit(); | ||||||||||||||||||||||
| 19 | s.close(); |
Row | Violation |
---|---|
1 | Type org.hibernate.Transaction of variable s.getTransaction() does not match with type java.sql.Connection of variable s.connection() |
2 | Type org.hibernate.Session of variable s does not match with type org.hibernate.classic.Session of variable s |
3 | Expression s.clear() is a void method call, and thus it cannot be parameterized |
4 | Expression s.flush() is a void method call, and thus it cannot be parameterized |
5 | Type org.hibernate.Session of variable s does not match with type org.hibernate.classic.Session of variable s |
6 | Unmatched statement s=openSession(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
7 | Expression s.getTransaction().commit() is a void method call, and thus it cannot be parameterized |
8 | Expression assertTrue(baz.getStringList().size() == 3 && baz.getStringList().contains("bar")) is a void method call, and thus it cannot be parameterized |
9 | Expression s.getTransaction().commit() is a void method call, and thus it cannot be parameterized |
10 | Expression assertTrue(baz.getStringList().size() == 3 && baz.getStringList().contains("bar")) is a void method call, and thus it cannot be parameterized |
11 | Type org.hibernate.Session of variable s does not match with type org.hibernate.classic.Session of variable s |