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 | 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) | 15.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(); | |||||||||||||||||||||||
|
| 19 | directJDBC(c, simples, ids, n, "j1"); | |||||||||||||||||||||||
18 | hibernate(s, simples, ids, n, "h1"); |
| 21 | cp.closeConnection(c); | ||||||||||||||||||||||
19 | long hiber = System.currentTimeMillis() - time; |
| 20 | long jdbc = System.currentTimeMillis() - time; | ||||||||||||||||||||||
20 | s.close(); | | ||||||||||||||||||||||||
21 | s = openSession(); |
| | |||||||||||||||||||||||
|
| 22 | c = cp.getConnection(); | |||||||||||||||||||||||
22 | time = System.currentTimeMillis(); | 23 | time = System.currentTimeMillis(); | |||||||||||||||||||||||
|
| 24 | directJDBC(c, simples, ids, n, "j2"); | |||||||||||||||||||||||
23 | hibernate(s, simples, ids, n, "h2"); |
| 26 | cp.closeConnection(c); | ||||||||||||||||||||||
24 | hiber += System.currentTimeMillis() - time; |
| 25 | jdbc += System.currentTimeMillis() - time; | ||||||||||||||||||||||
25 | s.close(); | | ||||||||||||||||||||||||
26 | s = openSession(); |
| | |||||||||||||||||||||||
|
| 27 | c = cp.getConnection(); | |||||||||||||||||||||||
27 | time = System.currentTimeMillis(); | 28 | time = System.currentTimeMillis(); | |||||||||||||||||||||||
|
| 29 | directJDBC(c, simples, ids, n, "j2"); | |||||||||||||||||||||||
28 | hibernate(s, simples, ids, n, "h2"); |
| 31 | cp.closeConnection(c); | ||||||||||||||||||||||
29 | hiber += System.currentTimeMillis() - time; |
| 30 | jdbc += System.currentTimeMillis() - time; | ||||||||||||||||||||||
30 | s.close(); | | ||||||||||||||||||||||||
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 or after the extracted code, because it has dependencies to/from statements that will be extracted |
3 | 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 |
4 | Expression hibernate(s,simples,ids,n,"h1") cannot be parameterized, because it has dependencies to/from statements that will be extracted |
5 | Expression hibernate(s,simples,ids,n,"h1") is a void method call, and thus it cannot be parameterized |
6 | Expression cp.closeConnection(c) is a void method call, and thus it cannot be parameterized |
7 | Expression hibernate(s,simples,ids,n,"h1") cannot be parameterized, because it has dependencies to/from statements that will be extracted |
8 | Expression hibernate(s,simples,ids,n,"h1") is a void method call, and thus it cannot be parameterized |
9 | Expression cp.closeConnection(c) is a void method call, and thus it cannot be parameterized |
10 | Unmatched statement s=openSession(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
11 | Unmatched statement c=cp.getConnection(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
12 | 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 |
13 | Expression hibernate(s,simples,ids,n,"h2") cannot be parameterized, because it has dependencies to/from statements that will be extracted |
14 | Expression hibernate(s,simples,ids,n,"h2") is a void method call, and thus it cannot be parameterized |
15 | Expression cp.closeConnection(c) is a void method call, and thus it cannot be parameterized |
16 | Expression hibernate(s,simples,ids,n,"h2") cannot be parameterized, because it has dependencies to/from statements that will be extracted |
17 | Expression hibernate(s,simples,ids,n,"h2") is a void method call, and thus it cannot be parameterized |
18 | Expression cp.closeConnection(c) is a void method call, and thus it cannot be parameterized |
19 | Unmatched statement s=openSession(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
20 | Unmatched statement c=cp.getConnection(); cannot be moved before or after the extracted code, because it has dependencies to/from statements that will be extracted |
21 | 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 |
22 | Expression hibernate(s,simples,ids,n,"h2") cannot be parameterized, because it has dependencies to/from statements that will be extracted |
23 | Expression hibernate(s,simples,ids,n,"h2") is a void method call, and thus it cannot be parameterized |
24 | Expression cp.closeConnection(c) is a void method call, and thus it cannot be parameterized |
25 | Expression hibernate(s,simples,ids,n,"h2") cannot be parameterized, because it has dependencies to/from statements that will be extracted |
26 | Expression hibernate(s,simples,ids,n,"h2") is a void method call, and thus it cannot be parameterized |
27 | Expression cp.closeConnection(c) is a void method call, and thus it cannot be parameterized |
28 | Clone fragment #1 returns variables s , while Clone fragment #2 returns variables simples, ids |