1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
/*
* JaCoCo Report Viewer, a web-based coverage report viewer
* Copyright (C) 2018 Pacien TRAN-GIRARD
* Adam NAILI
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
import React, { Component } from 'react';
import {Parser} from 'xml2js';
import {Counters, SessionInfo, PackagesCoverage} from './Blocks.js';
import './App.css';
class App extends Component {
constructor(props) {
super(props);
this.state = {
report: null,
hasError: false
};
}
componentDidCatch(error, info) {
this.setState({ hasError: true });
console.err(error, info);
}
_useReportFile(file) {
const fileReader = new FileReader();
fileReader.onloadend = (readEvent) => this._useReport(readEvent.target.result);
fileReader.readAsText(file);
}
_useReport(xmlString) {
const xmlParser = new Parser();
xmlParser.parseString(xmlString, (err, result) => this.setState({ report: result.report }));
}
_renderError() {
return (
<span>
Something went wrong while rendering the report.
Are the provided files valid?
</span>
);
}
_renderReport() {
return this.state.hasError ? this._renderError(): (<Report report={this.state.report} />);
}
render() {
return (
<div className="App">
<h1>JaCoCo Report Viewer</h1>
<div>
<label htmlFor="reportFile">XML report: </label>
<input id="reportFile" type="file" accept=".xml" onChange={event => this._useReportFile(event.target.files[0])} />
</div>
<div>
<label htmlFor="sourceJar">Source JAR: </label>
<input id="sourceJar" type="file" accept=".jar" onChange={event => null} />
</div>
<hr />
{this._renderReport()}
</div>
);
}
}
class Report extends Component {
_renderNone() {
return (<span>Please provide a JaCoCo XML report file to visualise.</span>);
}
_renderReport() {
return (
<div>
<h2>Viewing report: "{this.props.report.$.name}"</h2>
<section>
<h3>Session info</h3>
<SessionInfo data={this.props.report.sessioninfo} />
</section>
<section>
<h3>Global coverage</h3>
<Counters data={this.props.report.counter} />
</section>
<section>
<h3>Details</h3>
<PackagesCoverage packages={this.props.report.package} />
</section>
</div>
);
}
render() {
return this.props.report ? this._renderReport() : this._renderNone();
}
}
export default App;
|