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 | 13 |
Number of unmapped statements in the first code fragment | 1 |
Number of unmapped statements in the second code fragment | 2 |
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); |
| | ||||||||||||||||||||||
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 | assertNotNull(parent.getChildren()); | ||||||||||||||||||||||
14 | checkNumberOfResults(listeners, index); |
| 15 | checkNumberOfResults(listeners, 0); |
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 | Unmatched statement s.delete(parent); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
3 | Expression listeners.getInitializeCollectionListener() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
4 | Expression listeners.getPreCollectionRecreateListener() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
5 | Expression listeners.getPreCollectionRemoveListener() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
6 | Expression listeners.getPostCollectionRecreateListener() cannot be parameterized, because it has dependencies to/from statements that will be extracted |
7 | Expression checkResult(listeners,listeners.getPostCollectionRemoveListener(),parent,index++) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
8 | Expression checkNumberOfResults(listeners,index) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
9 | Expression checkResult(listeners,listeners.getPostCollectionRemoveListener(),parent,index++) is a void method call, and thus it cannot be parameterized |
10 | Expression checkNumberOfResults(listeners,index) is a void method call, and thus it cannot be parameterized |
11 | Expression checkResult(listeners,listeners.getPostCollectionRemoveListener(),parent,index++) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
12 | Expression checkNumberOfResults(listeners,index) cannot be parameterized, because it has dependencies to/from statements that will be extracted |
13 | Expression checkResult(listeners,listeners.getPostCollectionRemoveListener(),parent,index++) is a void method call, and thus it cannot be parameterized |
14 | Expression checkNumberOfResults(listeners,index) is a void method call, and thus it cannot be parameterized |
15 | Unmatched statement assertNotNull(parent.getChildren()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
16 | Expression index cannot be parameterized, because it has dependencies to/from statements that will be extracted |