File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/keymanytoone/bidir/component/LazyKeyManyToOneTest.java | File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/keymanytoone/bidir/embedded/KeyManyToOneTest.java | |||
Method name: void testLoadingStrategies()
|
Method name: void testLoadingStrategies()
|
|||
Number of AST nodes: 22 | Number of AST nodes: 22 | |||
1 | Session s = openSession();↵ | 1 | Session s = openSession();↵ | |
2 | s.beginTransaction();↵ | 2 | s.beginTransaction();↵ | |
3 | Customer cust = new Customer( "Acme, Inc." );↵ | 3 | Customer cust = new Customer( "Acme, Inc." );↵ | |
4 | Order order = new Order( new Order.Id( cust, 1 ) );↵ | 4 | Order order = new Order( cust, 1 );↵ | |
5 | cust.getOrders().add( order );↵ | 5 | cust.getOrders().add( order );↵ | |
6 | s.save( cust );↵ | 6 | s.save( cust );↵ | |
7 | s.getTransaction().commit();↵ | 7 | s.getTransaction().commit();↵ | |
8 | s.close();↵ | 8 | s.close();↵ | |
9 | s = openSession();↵ | 9 | s = openSession();↵ | |
10 | s.beginTransaction();↵ | 10 | s.beginTransaction();↵ | |
11 | cust = ( Customer ) s.get( Customer.class, cust.getId() );↵ | 11 | cust = ( Customer ) s.get( Customer.class, cust.getId() );↵ | |
12 | assertEquals( 1, cust.getOrders().size() );↵ | 12 | assertEquals( 1, cust.getOrders().size() );↵ | |
13 | s.clear();↵ | 13 | s.clear();↵ | |
14 | cust = ( Customer ) s.createQuery( "from Customer" ).uniqueResult();↵ | 14 | cust = ( Customer ) s.createQuery( "from Customer" ).uniqueResult();↵ | |
15 | assertEquals( 1, cust.getOrders().size() );↵ | 15 | assertEquals( 1, cust.getOrders().size() );↵ | |
16 | s.clear();↵ | 16 | s.clear();↵ | |
17 | cust = ( Customer ) s.createQuery( "from Customer c join fetch c.orders" ).uniqueResult();↵ | 17 | cust = ( Customer ) s.createQuery( "from Customer c join fetch c.orders" ).uniqueResult();↵ | |
18 | assertEquals( 1, cust.getOrders().size() );↵ | 18 | assertEquals( 1, cust.getOrders().size() );↵ | |
19 | s.clear();↵ | 19 | s.clear();↵ | |
20 | s.delete( cust );↵ | 20 | s.delete( cust );↵ | |
21 | s.getTransaction().commit();↵ | 21 | s.getTransaction().commit();↵ | |
22 | 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 | 113 |
Number of mapped statements | 21 |
Number of unmapped statements in the first code fragment | 1 |
Number of unmapped statements in the second code fragment | 1 |
Time elapsed for statement mapping (ms) | 0.0 |
Clone type | Type 2 |
ID | Statement | ID | Statement | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | Session s = openSession(); | 1 | Session s = openSession(); | ||||||||||||
2 | s.beginTransaction(); | 2 | s.beginTransaction(); | ||||||||||||
3 | Customer cust = new Customer("Acme, Inc."); | 3 | Customer cust = new Customer("Acme, Inc."); | ||||||||||||
|
| 4 | Order order = new Order(cust, 1); | ||||||||||||
4 | Order order = new Order(new Order.Id(cust, 1)); |
| | ||||||||||||
5 | cust.getOrders().add(order); |
| 5 | cust.getOrders().add(order); | |||||||||||
6 | s.save(cust); | 6 | s.save(cust); | ||||||||||||
7 | s.getTransaction().commit(); | 7 | s.getTransaction().commit(); | ||||||||||||
8 | s.close(); | 8 | s.close(); | ||||||||||||
9 | s = openSession(); | 9 | s = openSession(); | ||||||||||||
10 | s.beginTransaction(); | 10 | s.beginTransaction(); | ||||||||||||
11 | cust = (Customer)s.get(Customer.class, cust.getId()); | 11 | cust = (Customer)s.get(Customer.class, cust.getId()); | ||||||||||||
12 | assertEquals(1, cust.getOrders().size()); | 12 | assertEquals(1, cust.getOrders().size()); | ||||||||||||
13 | s.clear(); | 13 | s.clear(); | ||||||||||||
14 | cust = (Customer)s.createQuery("from Customer").uniqueResult(); | 14 | cust = (Customer)s.createQuery("from Customer").uniqueResult(); | ||||||||||||
15 | assertEquals(1, cust.getOrders().size()); | 15 | assertEquals(1, cust.getOrders().size()); | ||||||||||||
16 | s.clear(); | 16 | s.clear(); | ||||||||||||
17 | cust = (Customer)s.createQuery("from Customer c join fetch c.orders").uniqueResult(); | 17 | cust = (Customer)s.createQuery("from Customer c join fetch c.orders").uniqueResult(); | ||||||||||||
18 | assertEquals(1, cust.getOrders().size()); | 18 | assertEquals(1, cust.getOrders().size()); | ||||||||||||
19 | s.clear(); | 19 | s.clear(); | ||||||||||||
20 | s.delete(cust); | 20 | s.delete(cust); | ||||||||||||
21 | s.getTransaction().commit(); | 21 | s.getTransaction().commit(); | ||||||||||||
22 | s.close(); | 22 | s.close(); |
Row | Violation |
---|---|
1 | Unmatched statement Order order=new Order(cust,1); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Unmatched statement Order order=new Order(new Order.Id(cust,1)); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
3 | Type org.hibernate.test.keymanytoone.bidir.component.Order of variable order does not match with type org.hibernate.test.keymanytoone.bidir.embedded.Order of variable order |
4 | Clone fragment #1 returns variable cust with type org.hibernate.test.keymanytoone.bidir.component.Customer , while Clone fragment #2 returns variable cust with type org.hibernate.test.keymanytoone.bidir.embedded.Customer |