From 1223ac7108c6a8ba08ca4e760b12afd92eafb898 Mon Sep 17 00:00:00 2001 From: panpanini Date: Thu, 14 Jan 2016 09:16:34 +1300 Subject: [PATCH] Replace Simple JSON with Gson Simple-JSON was throwing NoClassDefError at runtime when attempting to parse the RCov JSON file - this looks to be because maven wasn't bundling it as a dependancy for whatever reason. Replacing with Gson seems to have fixed the issue. --- .../SimpleCovRcovJsonParserImpl.java | 26 ++++++++++++------- 1 file changed, 17 insertions(+), 9 deletions(-) diff --git a/src/main/java/com/godaddy/sonar/ruby/simplecovrcov/SimpleCovRcovJsonParserImpl.java b/src/main/java/com/godaddy/sonar/ruby/simplecovrcov/SimpleCovRcovJsonParserImpl.java index 16e198e..b8b4673 100755 --- a/src/main/java/com/godaddy/sonar/ruby/simplecovrcov/SimpleCovRcovJsonParserImpl.java +++ b/src/main/java/com/godaddy/sonar/ruby/simplecovrcov/SimpleCovRcovJsonParserImpl.java @@ -4,10 +4,11 @@ import java.io.IOException; import java.util.Map; +import com.google.gson.JsonArray; +import com.google.gson.JsonObject; +import com.google.gson.JsonParser; import org.apache.commons.io.FileUtils; -import org.json.simple.JSONArray; -import org.json.simple.JSONObject; -import org.json.simple.JSONValue; + import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.sonar.api.measures.CoverageMeasuresBuilder; @@ -27,23 +28,30 @@ public Map parse(File file) throws IOException String fileString = FileUtils.readFileToString(fileToFindCoverage, "UTF-8"); - JSONObject resultJsonObject = (JSONObject) JSONValue.parse(fileString); - JSONObject coverageJsonObj = (JSONObject) ((JSONObject) resultJsonObject.get("RSpec")).get("coverage"); + JsonParser parser = new JsonParser(); + + JsonObject resultJsonObject = parser.parse(fileString).getAsJsonObject(); + JsonObject coverageJsonObj = resultJsonObject.get("RSpec").getAsJsonObject().get("coverage").getAsJsonObject(); + // for each file in the coverage report - for (int j = 0; j < coverageJsonObj.keySet().size(); j++) + for (int j = 0; j < coverageJsonObj.entrySet().size(); j++) { CoverageMeasuresBuilder fileCoverage = CoverageMeasuresBuilder.create(); - String filePath = coverageJsonObj.keySet().toArray()[j].toString(); + String filePath = ((Map.Entry)coverageJsonObj.entrySet().toArray()[j]).getKey().toString(); LOG.debug("filePath " + filePath); - JSONArray coverageArray = (JSONArray) coverageJsonObj.get(coverageJsonObj.keySet().toArray()[j]); + JsonArray coverageArray = coverageJsonObj.get(filePath).getAsJsonArray(); // for each line in the coverage array for (int i = 0; i < coverageArray.size(); i++) { - Long line = (Long) coverageArray.toArray()[i]; + Long line = null; + + if (!coverageArray.get(i).isJsonNull()) { + line = coverageArray.get(i).getAsLong(); + } Integer intLine = 0; int lineNumber = i + 1; if (line != null)