File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/perf/org/hibernate/test/perf/NewerPerformanceTest.java | File path: /hibernate-distribution-3.3.2.GA/project/testsuite/src/test/perf/org/hibernate/test/perf/NewerPerformanceTest.java | |||
Method name: void testHibernateOnly()
|
Method name: void testJdbcOnly()
|
|||
Number of AST nodes: 32 | Number of AST nodes: 30 | |||
1 | for ( int n=2; n<4000; n*=2 ) {↵ | |||
2 | Session s = openSession();↵ | 1 | Session s = openSession();↵ | |
3 | Simple[] simples = new Simple[n];↵ | 2 | Simple[] simples = new Simple[n];↵ | |
4 | s.delete("from Simple");↵ | 3 | s.delete("from Simple");↵ | |
5 | s.flush();↵ | 4 | s.flush();↵ | |
6 | Serializable[] ids = new Serializable[n];↵ | 5 | Serializable[] ids = new Serializable[n];↵ | |
7 | for ( int i=0; i<n; i++ ) {↵ | 6 | for ( int i=0; i<n; i++ ) {↵ | |
8 | simples[i] = new Simple();↵ | 7 | simples[i] = new Simple();↵ | |
9 | simples[i].init();↵ | 8 | simples[i].init();↵ | |
10 | simples[i].setCount(i);↵ | 9 | simples[i].setCount(i);↵ | |
11 | ids[i] = new Long(i);↵ | 10 | ids[i] = new Long(i);↵ | |
12 | s.save(simples[i], ids[i]);↵ | 11 | s.save(simples[i], ids[i]);↵ | |
13 | }↵ | 12 | }↵ | |
14 | s.flush();↵ | 13 | s.flush();↵ | |
15 | s.connection().commit();↵ | 14 | s.connection().commit();↵ | |
16 | s.close();↵ | 15 | s.close();↵ | |
17 | //Now do timings↵ | 16 | //Now do timings↵ | |
18 | s = openSession();↵ | 17 | Connection c = cp.getConnection();↵ | |
19 | long time = System.currentTimeMillis();↵ | 18 | long time = System.currentTimeMillis();↵ | |
20 | hibernate(s, simples, ids, n, "h1");↵ | 19 | directJDBC( c, simples, ids, n, "j1" );↵ | |
21 | long hiber = System.currentTimeMillis() - time;↵ | 20 | long jdbc = System.currentTimeMillis() - time;↵ | |
22 | s.close();↵ | 21 | cp.closeConnection(c);↵ | |
23 | s = openSession();↵ | 22 | c = cp.getConnection();↵ | |
24 | time = System.currentTimeMillis();↵ | 23 | time = System.currentTimeMillis();↵ | |
25 | hibernate(s, simples, ids, n, "h2");↵ | 24 | directJDBC( c, simples, ids, n, "j2" );↵ | |
26 | hiber += System.currentTimeMillis() - time;↵ | 25 | jdbc += System.currentTimeMillis() - time;↵ | |
27 | s.close();↵ | 26 | cp.closeConnection(c);↵ | |
28 | s = openSession();↵ | 27 | c = cp.getConnection();↵ | |
29 | time = System.currentTimeMillis();↵ | 28 | time = System.currentTimeMillis();↵ | |
30 | hibernate(s, simples, ids, n, "h2");↵ | 29 | directJDBC( c, simples, ids, n, "j2" );↵ | |
31 | hiber += System.currentTimeMillis() - time;↵ | 30 | jdbc += System.currentTimeMillis() - time;↵ | |
32 | s.close();↵ | 31 | cp.closeConnection(c);↵ | |
33 | System.out.println( "Objects: " + n + " - Hibernate: " + hiber );↵ | 32 | System.out.println( "Objects: " + n + " ↵ | |
34 | }↵ | |||
35 | System.gc(); | 33 | Direct JDBC: " + jdbc ); | |
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.2 |
Clones location | Clones are declared in the same class |
Number of node comparisons | 375 |
Number of mapped statements | 21 |
Number of unmapped statements in the first code fragment | 9 |
Number of unmapped statements in the second code fragment | 9 |
Time elapsed for statement mapping (ms) | 62.2 |
Clone type | Type 2 |
ID | Statement | ID | Statement | ||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
2 | Session s = openSession(); | 3 | Session s = openSession(); | ||||||||||||||
3 | Simple[] simples = new Simple[n]; | 4 | Simple[] simples = new Simple[n]; | ||||||||||||||
4 | s.delete("from Simple"); | 5 | s.delete("from Simple"); | ||||||||||||||
5 | s.flush(); | 6 | s.flush(); | ||||||||||||||
6 | Serializable[] ids = new Serializable[n]; | 7 | Serializable[] ids = new Serializable[n]; | ||||||||||||||
7 | for (int i = 0; i < n; i++) | 8 | for (int i = 0; i < n; i++) | ||||||||||||||
8 | simples[i] = new Simple(); | 9 | simples[i] = new Simple(); | ||||||||||||||
9 | simples[i].init(); | 10 | simples[i].init(); | ||||||||||||||
10 | simples[i].setCount(i); | 11 | simples[i].setCount(i); | ||||||||||||||
11 | ids[i] = new Long(i); | 12 | ids[i] = new Long(i); | ||||||||||||||
12 | s.save(simples[i], ids[i]); | 13 | s.save(simples[i], ids[i]); | ||||||||||||||
13 | s.flush(); | 14 | s.flush(); | ||||||||||||||
14 | s.connection().commit(); | 15 | s.connection().commit(); | ||||||||||||||
15 | s.close(); | 16 | s.close(); | ||||||||||||||
16 | s = openSession(); |
| | ||||||||||||||
|
| 17 | Connection c = cp.getConnection(); | ||||||||||||||
17 | long time = System.currentTimeMillis(); | 18 | long time = System.currentTimeMillis(); | ||||||||||||||
18 | hibernate(s, simples, ids, n, "h1"); |
| | ||||||||||||||
|
| 19 | directJDBC(c, simples, ids, n, "j1"); | ||||||||||||||
19 | long hiber = System.currentTimeMillis() - time; |
| 20 | long jdbc = System.currentTimeMillis() - time; | |||||||||||||
20 | s.close(); | | |||||||||||||||
|
| 21 | cp.closeConnection(c); | ||||||||||||||
21 | s = openSession(); |
| | ||||||||||||||
|
| 22 | c = cp.getConnection(); | ||||||||||||||
22 | time = System.currentTimeMillis(); | 23 | time = System.currentTimeMillis(); | ||||||||||||||
23 | hibernate(s, simples, ids, n, "h2"); |
| | ||||||||||||||
|
| 24 | directJDBC(c, simples, ids, n, "j2"); | ||||||||||||||
24 | hiber += System.currentTimeMillis() - time; |
| 25 | jdbc += System.currentTimeMillis() - time; | |||||||||||||
25 | s.close(); | | |||||||||||||||
|
| 26 | cp.closeConnection(c); | ||||||||||||||
26 | s = openSession(); |
| | ||||||||||||||
|
| 27 | c = cp.getConnection(); | ||||||||||||||
27 | time = System.currentTimeMillis(); | 28 | time = System.currentTimeMillis(); | ||||||||||||||
28 | hibernate(s, simples, ids, n, "h2"); |
| | ||||||||||||||
|
| 29 | directJDBC(c, simples, ids, n, "j2"); | ||||||||||||||
29 | hiber += System.currentTimeMillis() - time; |
| 30 | jdbc += System.currentTimeMillis() - time; | |||||||||||||
30 | s.close(); |
| | ||||||||||||||
|
| 31 | cp.closeConnection(c); | ||||||||||||||
31 | System.out.println("Objects: " + n + " - Hibernate: " + hiber); |
| 32 | System.out.println("Objects: " + n + " Direct JDBC: " + jdbc); |
Row | Violation |
---|---|
1 | Unmatched statement s=openSession(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
2 | Unmatched statement Connection c=cp.getConnection(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
3 | Unmatched statement hibernate(s,simples,ids,n,"h1"); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
4 | Unmatched statement directJDBC(c,simples,ids,n,"j1"); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
5 | Unmatched statement cp.closeConnection(c); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
6 | Unmatched statement s=openSession(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
7 | Unmatched statement c=cp.getConnection(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
8 | Unmatched statement hibernate(s,simples,ids,n,"h2"); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
9 | Unmatched statement directJDBC(c,simples,ids,n,"j2"); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
10 | Unmatched statement cp.closeConnection(c); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
11 | Unmatched statement s=openSession(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
12 | Unmatched statement c=cp.getConnection(); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
13 | Unmatched statement hibernate(s,simples,ids,n,"h2"); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
14 | Unmatched statement directJDBC(c,simples,ids,n,"j2"); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
15 | Unmatched statement s.close(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
16 | Unmatched statement cp.closeConnection(c); cannot be moved before the extracted code, because it has control dependencies from statements that will be extracted |
17 | Clone fragment #1 returns variables s, simples, ids , while Clone fragment #2 returns variables simples, ids |