Update project structure to org.onap.aaf
[aaf/inno.git] / rosetta / src / test / java / com / data / test / Report.java
1 /*******************************************************************************\r
2  * ============LICENSE_START====================================================\r
3  * * org.onap.aaf\r
4  * * ===========================================================================\r
5  * * Copyright © 2017 AT&T Intellectual Property. All rights reserved.\r
6  * * ===========================================================================\r
7  * * Licensed under the Apache License, Version 2.0 (the "License");\r
8  * * you may not use this file except in compliance with the License.\r
9  * * You may obtain a copy of the License at\r
10  * * \r
11  *  *      http://www.apache.org/licenses/LICENSE-2.0\r
12  * * \r
13  *  * Unless required by applicable law or agreed to in writing, software\r
14  * * distributed under the License is distributed on an "AS IS" BASIS,\r
15  * * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\r
16  * * See the License for the specific language governing permissions and\r
17  * * limitations under the License.\r
18  * * ============LICENSE_END====================================================\r
19  * *\r
20  * * ECOMP is a trademark and service mark of AT&T Intellectual Property.\r
21  * *\r
22  ******************************************************************************/\r
23 package com.data.test;\r
24 \r
25 import java.io.IOException;\r
26 import java.io.Writer;\r
27 \r
28 import org.onap.aaf.inno.env.Trans;\r
29 import org.onap.aaf.inno.env.Trans.Metric;\r
30 \r
31 public class Report {\r
32         float total;\r
33         float buckets[];\r
34         String[] names;\r
35         private int iterations;\r
36         private int count;\r
37         \r
38         public Report(int iters, String ... names) {\r
39                 iterations = iters;\r
40                 buckets = new float[names.length];\r
41                 this.names = names;\r
42                 total=0;\r
43                 count = 0;\r
44         }\r
45         \r
46         public void glean(Trans trans, int ... type) {\r
47                 Metric m = trans.auditTrail(0, null, type);\r
48                 total+=m.total;\r
49                 int min = Math.min(buckets.length, m.buckets.length);\r
50                 for(int b=0;b<min;++b) {\r
51                         buckets[b]+=m.buckets[b];\r
52                 }\r
53         }\r
54         \r
55         public boolean go() {\r
56                 return ++count<iterations;\r
57         }\r
58         \r
59         \r
60         public void report(Writer sbw) throws IOException {\r
61                 sbw.append("\n"+count + " entries, Total Time: " + total + "ms, Avg Time: " + total/count + "ms\n");\r
62                 int min = Math.min(buckets.length, names.length);\r
63                 for(int i=0;i<min;++i) {\r
64                         sbw.append("  Time: " + names[i] + ' ' + buckets[i] + "ms, Avg Time: " + buckets[i]/count + "ms\n");\r
65                 }\r
66 \r
67         }\r
68 }\r