File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/event/collection/AbstractCollectionEventTest.java | File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/event/collection/BrokenCollectionEventTest.java | |||
Method name: void testDeleteParentWithNullChildren()
|
Method name: void testSaveParentNullChildrenFailureExpected()
|
|||
Number of AST nodes: 14 | Number of AST nodes: 15 | |||
1 | CollectionListeners listeners = new CollectionListeners( getSessions() );↵ | 1 | CollectionListeners listeners = new CollectionListeners( getSessions() );↵ | |
2 | ParentWithCollection parent = createParentWithNullChildren( "parent" );↵ | 2 | ParentWithCollection parent = createParentWithNullChildren( "parent" );↵ | |
3 | listeners.clear();↵ | 3 | ↵ | |
4 | Session s = openSession();↵ | |||
5 | Transaction tx = s.beginTransaction();↵ | |||
6 | parent = ( ParentWithCollection ) s.get( parent.getClass(), parent.getId() );↵ | |||
7 | s.delete( parent );↵ | |||
8 | tx.commit();↵ | |||
9 | s.close();↵ | |||
10 | int index = 0;↵ | 4 | assertNull( parent.getChildren() );↵ | |
5 | int index = 0;↵ | |||
6 | // pre- and post- collection recreate events should be created when creating an entity with a "null" collection↵ | |||
11 | checkResult( listeners, listeners.getInitializeCollectionListener(), parent, index++ );↵ | 7 | checkResult( listeners, listeners.getPreCollectionRecreateListener(), parent, index++ );↵ | |
12 | checkResult( listeners, listeners.getPreCollectionRemoveListener(), parent, index++ );↵ | 8 | checkResult( listeners, listeners.getPostCollectionRecreateListener(), parent, index++ );↵ | |
13 | checkResult( listeners, listeners.getPostCollectionRemoveListener(), parent, index++↵ | 9 | checkNumberOfResults( listeners, index );↵ | |
10 | listeners.clear();↵ | |||
11 | Session s = openSession();↵ | |||
12 | Transaction tx = s.beginTransaction();↵ | |||
13 | parent = ( ParentWithCollection ) s.get( parent.getClass(), parent.getId() );↵ | |||
14 | tx.commit();↵ | |||
15 | s.close();↵ | |||
14 | );↵ | 16 | assertNotNull( parent.getChildren() );↵ | |
15 | checkNumberOfResults( listeners, index ); | 17 | checkNumberOfResults( listeners, 0 ); | |
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 | 139 |
Number of mapped statements | 14 |
Number of unmapped statements in the first code fragment | 0 |
Number of unmapped statements in the second code fragment | 1 |
Time elapsed for statement mapping (ms) | 0.0 |
Clone type | Type 3 |
ID | Statement | ID | Statement | |||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
1 | CollectionListeners listeners = new CollectionListeners(getSessions()); | 1 | CollectionListeners listeners = new CollectionListeners(getSessions()); | |||||||||||||||||||||||||
2 | ParentWithCollection parent = createParentWithNullChildren("parent"); | 2 | ParentWithCollection parent = createParentWithNullChildren("parent"); | |||||||||||||||||||||||||
|
| 3 | assertNull(parent.getChildren()); | |||||||||||||||||||||||||
3 | listeners.clear(); | 8 | listeners.clear(); | |||||||||||||||||||||||||
4 | Session s = openSession(); | 9 | Session s = openSession(); | |||||||||||||||||||||||||
5 | Transaction tx = s.beginTransaction(); | 10 | Transaction tx = s.beginTransaction(); | |||||||||||||||||||||||||
6 | parent = (ParentWithCollection)s.get(parent.getClass(), parent.getId()); | 11 | parent = (ParentWithCollection)s.get(parent.getClass(), parent.getId()); | |||||||||||||||||||||||||
7 | s.delete(parent); |
| 15 | checkNumberOfResults(listeners, 0); | ||||||||||||||||||||||||
8 | tx.commit(); | 12 | tx.commit(); | |||||||||||||||||||||||||
9 | s.close(); | 13 | s.close(); | |||||||||||||||||||||||||
10 | int index = 0; | 4 | int index = 0; | |||||||||||||||||||||||||
11 | checkResult(listeners, listeners.getInitializeCollectionListener(), parent, index++); |
| 5 | checkResult(listeners, listeners.getPreCollectionRecreateListener(), parent, index++); | ||||||||||||||||||||||||
12 | checkResult(listeners, listeners.getPreCollectionRemoveListener(), parent, index++); |
| 6 | checkResult(listeners, listeners.getPostCollectionRecreateListener(), parent, index++); | ||||||||||||||||||||||||
13 | checkResult(listeners, listeners.getPostCollectionRemoveListener(), parent, index++); |
| 7 | checkNumberOfResults(listeners, index); | ||||||||||||||||||||||||
14 | checkNumberOfResults(listeners, index); |
| 14 | assertNotNull(parent.getChildren()); |
Row | Violation |
---|---|
1 | Unmatched statement assertNull(parent.getChildren()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Expression s.delete(parent) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
3 | Expression checkNumberOfResults(listeners,0) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
4 | Expression s.delete(parent) is a void method call, and thus it cannot be parameterized |
5 | Expression checkNumberOfResults(listeners,0) is a void method call, and thus it cannot be parameterized |
6 | Expression s.delete(parent) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
7 | Expression checkNumberOfResults(listeners,0) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
8 | Expression s.delete(parent) is a void method call, and thus it cannot be parameterized |
9 | Expression checkNumberOfResults(listeners,0) is a void method call, and thus it cannot be parameterized |
10 | Expression listeners.getInitializeCollectionListener() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
11 | Expression listeners.getPreCollectionRecreateListener() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
12 | Type org.hibernate.test.event.collection.CollectionListeners.InitializeCollectionListener of variable listeners.getInitializeCollectionListener() does not match with type org.hibernate.test.event.collection.CollectionListeners.PreCollectionRecreateListener of variable listeners.getPreCollectionRecreateListener() |
13 | Expression listeners.getPreCollectionRemoveListener() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
14 | Expression listeners.getPostCollectionRecreateListener() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
15 | Expression checkResult(listeners,listeners.getPostCollectionRemoveListener(),parent,index++) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
16 | Expression checkNumberOfResults(listeners,index) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
17 | Expression checkResult(listeners,listeners.getPostCollectionRemoveListener(),parent,index++) is a void method call, and thus it cannot be parameterized |
18 | Expression checkNumberOfResults(listeners,index) is a void method call, and thus it cannot be parameterized |
19 | Expression checkResult(listeners,listeners.getPostCollectionRemoveListener(),parent,index++) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
20 | Expression checkNumberOfResults(listeners,index) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
21 | Expression checkResult(listeners,listeners.getPostCollectionRemoveListener(),parent,index++) is a void method call, and thus it cannot be parameterized |
22 | Expression checkNumberOfResults(listeners,index) is a void method call, and thus it cannot be parameterized |
23 | Expression checkNumberOfResults(listeners,index) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
24 | Expression assertNotNull(parent.getChildren()) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
25 | Expression checkNumberOfResults(listeners,index) is a void method call, and thus it cannot be parameterized |
26 | Expression assertNotNull(parent.getChildren()) is a void method call, and thus it cannot be parameterized |
27 | Expression checkNumberOfResults(listeners,index) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
28 | Expression assertNotNull(parent.getChildren()) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
29 | Expression checkNumberOfResults(listeners,index) is a void method call, and thus it cannot be parameterized |
30 | Expression assertNotNull(parent.getChildren()) is a void method call, and thus it cannot be parameterized |
31 | Clone fragment #1 returns variables , while Clone fragment #2 returns variables parent |