File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/version/db/DbVersionTest.java | File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/java/org/hibernate/test/version/sybase/SybaseTimestampVersioningTest.java | |||
Method name: void testCollectionNoVersion()
|
Method name: void testCollectionNoVersion()
|
|||
Number of AST nodes: 30 | Number of AST nodes: 30 | |||
1 | Session s = openSession();↵ | 1 | Session s = openSession();↵ | |
2 | Transaction t = s.beginTransaction();↵ | 2 | Transaction t = s.beginTransaction();↵ | |
3 | User steve = new User( "steve" );↵ | 3 | User steve = new User( "steve" );↵ | |
4 | s.persist( steve );↵ | 4 | s.persist( steve );↵ | |
5 | Permission perm = new Permission( "silly", "user", "rw" );↵ | 5 | Permission perm = new Permission( "silly", "user", "rw" );↵ | |
6 | s.persist( perm );↵ | 6 | s.persist( perm );↵ | |
7 | t.commit();↵ | 7 | t.commit();↵ | |
8 | s.close();↵ | 8 | s.close();↵ | |
9 | Timestamp steveTimestamp = ( Timestamp ) steve.getTimestamp();↵ | 9 | byte[] steveTimestamp = steve.getTimestamp();↵ | |
10 | s = openSession();↵ | 10 | s = openSession();↵ | |
11 | t = s.beginTransaction();↵ | 11 | t = s.beginTransaction();↵ | |
12 | steve = ( User ) s.get( User.class, steve.getId() );↵ | 12 | steve = ( User ) s.get( User.class, steve.getId() );↵ | |
13 | perm = ( Permission ) s.get( Permission.class, perm.getId() );↵ | 13 | perm = ( Permission ) s.get( Permission.class, perm.getId() );↵ | |
14 | steve.getPermissions().add( perm );↵ | 14 | steve.getPermissions().add( perm );↵ | |
15 | t.commit();↵ | 15 | t.commit();↵ | |
16 | s.close();↵ | 16 | s.close();↵ | |
17 | assertTrue( "owner version was incremented", Hibernate.TIMESTAMP.isEqual( steveTimestamp, steve.getTimestamp() ) );↵ | 17 | assertTrue( "owner version was incremented", Hibernate.BINARY.isEqual( steveTimestamp, steve.getTimestamp() ) );↵ | |
18 | s = openSession();↵ | 18 | s = openSession();↵ | |
19 | t = s.beginTransaction();↵ | 19 | t = s.beginTransaction();↵ | |
20 | steve = ( User ) s.get( User.class, steve.getId() );↵ | 20 | steve = ( User ) s.get( User.class, steve.getId() );↵ | |
21 | steve.getPermissions().clear();↵ | 21 | steve.getPermissions().clear();↵ | |
22 | t.commit();↵ | 22 | t.commit();↵ | |
23 | s.close();↵ | 23 | s.close();↵ | |
24 | assertTrue( "owner version was incremented", Hibernate.TIMESTAMP.isEqual( steveTimestamp, steve.getTimestamp() ) );↵ | 24 | assertTrue( "owner version was incremented", Hibernate.BINARY.isEqual( steveTimestamp, steve.getTimestamp() ) );↵ | |
25 | s = openSession();↵ | 25 | s = openSession();↵ | |
26 | t = s.beginTransaction();↵ | 26 | t = s.beginTransaction();↵ | |
27 | s.delete( s.load( User.class, steve.getId() ) );↵ | 27 | s.delete( s.load( User.class, steve.getId() ) );↵ | |
28 | s.delete( s.load( Permission.class, perm.getId() ) );↵ | 28 | s.delete( s.load( Permission.class, perm.getId() ) );↵ | |
29 | t.commit();↵ | 29 | t.commit();↵ | |
30 | s.close(); | 30 |
| |
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 | 294 |
Number of mapped statements | 24 |
Number of unmapped statements in the first code fragment | 6 |
Number of unmapped statements in the second code fragment | 6 |
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 | Transaction t = s.beginTransaction(); | 2 | Transaction t = s.beginTransaction(); | ||||||||||||||||
| 3 | User steve = new User("steve"); | |||||||||||||||||
3 | User steve = new User("steve"); | | |||||||||||||||||
4 | s.persist(steve); |
| 4 | s.persist(steve); | |||||||||||||||
| 5 | Permission perm = new Permission("silly", "user", "rw"); | |||||||||||||||||
5 | Permission perm = new Permission("silly", "user", "rw"); | | |||||||||||||||||
6 | s.persist(perm); |
| 6 | s.persist(perm); | |||||||||||||||
7 | t.commit(); | 7 | t.commit(); | ||||||||||||||||
8 | s.close(); | 8 | s.close(); | ||||||||||||||||
| 9 | byte[] steveTimestamp = steve.getTimestamp(); | |||||||||||||||||
9 | Timestamp steveTimestamp = (Timestamp)steve.getTimestamp(); | | |||||||||||||||||
10 | s = openSession(); | 10 | s = openSession(); | ||||||||||||||||
11 | t = s.beginTransaction(); | 11 | t = s.beginTransaction(); | ||||||||||||||||
|
| 12 | steve = (User)s.get(User.class, steve.getId()); | ||||||||||||||||
12 | steve = (User)s.get(User.class, steve.getId()); |
| | ||||||||||||||||
|
| 13 | perm = (Permission)s.get(Permission.class, perm.getId()); | ||||||||||||||||
13 | perm = (Permission)s.get(Permission.class, perm.getId()); |
| | ||||||||||||||||
14 | steve.getPermissions().add(perm); |
| 14 | steve.getPermissions().add(perm); | |||||||||||||||
15 | t.commit(); | 15 | t.commit(); | ||||||||||||||||
16 | s.close(); | 16 | s.close(); | ||||||||||||||||
17 | assertTrue("owner version was incremented", Hibernate.TIMESTAMP.isEqual(steveTimestamp, steve.getTimestamp())); |
| 17 | assertTrue("owner version was incremented", Hibernate.BINARY.isEqual(steveTimestamp, steve.getTimestamp())); | |||||||||||||||
18 | s = openSession(); | 18 | s = openSession(); | ||||||||||||||||
19 | t = s.beginTransaction(); | 19 | t = s.beginTransaction(); | ||||||||||||||||
|
| 20 | steve = (User)s.get(User.class, steve.getId()); | ||||||||||||||||
20 | steve = (User)s.get(User.class, steve.getId()); |
| | ||||||||||||||||
21 | steve.getPermissions().clear(); |
| 21 | steve.getPermissions().clear(); | |||||||||||||||
22 | t.commit(); | 22 | t.commit(); | ||||||||||||||||
23 | s.close(); | 23 | s.close(); | ||||||||||||||||
24 | assertTrue("owner version was incremented", Hibernate.TIMESTAMP.isEqual(steveTimestamp, steve.getTimestamp())); |
| 24 | assertTrue("owner version was incremented", Hibernate.BINARY.isEqual(steveTimestamp, steve.getTimestamp())); | |||||||||||||||
25 | s = openSession(); | 25 | s = openSession(); | ||||||||||||||||
26 | t = s.beginTransaction(); | 26 | t = s.beginTransaction(); | ||||||||||||||||
27 | s.delete(s.load(User.class, steve.getId())); | 27 | s.delete(s.load(User.class, steve.getId())); | ||||||||||||||||
28 | s.delete(s.load(Permission.class, perm.getId())); | 28 | s.delete(s.load(Permission.class, perm.getId())); | ||||||||||||||||
29 | t.commit(); | 29 | t.commit(); | ||||||||||||||||
30 | s.close(); | 30 | s.close(); |
Row | Violation |
---|---|
1 | Type org.hibernate.test.version.db.User of variable steve does not match with type org.hibernate.test.version.sybase.User of variable steve |
2 | Type org.hibernate.test.version.db.Permission of variable perm does not match with type org.hibernate.test.version.sybase.Permission of variable perm |
3 | Unmatched statement steve=(User)s.get(User.class,steve.getId()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
4 | Unmatched statement steve=(User)s.get(User.class,steve.getId()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
5 | Unmatched statement perm=(Permission)s.get(Permission.class,perm.getId()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
6 | Unmatched statement perm=(Permission)s.get(Permission.class,perm.getId()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
7 | Type org.hibernate.test.version.db.Permission of variable perm does not match with type org.hibernate.test.version.sybase.Permission of variable perm |
8 | Type org.hibernate.test.version.db.User of variable steve does not match with type org.hibernate.test.version.sybase.User of variable steve |
9 | Type java.sql.Timestamp of variable steveTimestamp does not match with type byte[] of variable steveTimestamp |
10 | Unmatched statement steve=(User)s.get(User.class,steve.getId()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
11 | Unmatched statement steve=(User)s.get(User.class,steve.getId()); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
12 | Type org.hibernate.test.version.db.User of variable steve does not match with type org.hibernate.test.version.sybase.User of variable steve |
13 | Type java.sql.Timestamp of variable steveTimestamp does not match with type byte[] of variable steveTimestamp |