aboutsummaryrefslogtreecommitdiffstats
path: root/sonar-batch-protocol
diff options
context:
space:
mode:
Diffstat (limited to 'sonar-batch-protocol')
-rw-r--r--sonar-batch-protocol/pom.xml111
-rw-r--r--sonar-batch-protocol/src/main/assembly/viewer.xml22
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/GsonHelper.java35
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/FileData.java44
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/GlobalRepositories.java73
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/Metric.java120
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/ProjectRepositories.java115
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/package-info.java24
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/BatchReportReader.java172
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/BatchReportWriter.java141
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/FileStructure.java78
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/package-info.java24
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/package-info.java24
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/TextLineNumber.java457
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/ViewerApplication.java388
-rw-r--r--sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/package-info.java24
-rw-r--r--sonar-batch-protocol/src/main/protobuf/batch_input.proto56
-rw-r--r--sonar-batch-protocol/src/main/protobuf/batch_report.proto213
-rw-r--r--sonar-batch-protocol/src/main/protobuf/constants.proto79
-rw-r--r--sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/input/GlobalRepositoriesTest.java65
-rw-r--r--sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/BatchReportReaderTest.java388
-rw-r--r--sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/BatchReportWriterTest.java306
-rw-r--r--sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/FileStructureTest.java74
-rw-r--r--sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/FileStreamTest/file.txt3
-rw-r--r--sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/GlobalRepositoriesTest/expected.json21
-rw-r--r--sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/ProjectRepositoriesTest/testToJson.json23
-rw-r--r--sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/RulesSearchTest/empty.json1
-rw-r--r--sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/RulesSearchTest/expected.json1
-rw-r--r--sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/output/component/ReportComponentsTest/expected.json43
29 files changed, 0 insertions, 3125 deletions
diff --git a/sonar-batch-protocol/pom.xml b/sonar-batch-protocol/pom.xml
deleted file mode 100644
index 76ed752bf1e..00000000000
--- a/sonar-batch-protocol/pom.xml
+++ /dev/null
@@ -1,111 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- <modelVersion>4.0.0</modelVersion>
- <parent>
- <groupId>org.sonarsource.sonarqube</groupId>
- <artifactId>sonarqube</artifactId>
- <version>5.5-SNAPSHOT</version>
- </parent>
-
- <artifactId>sonar-batch-protocol</artifactId>
- <name>SonarQube :: Batch :: Protocol</name>
-
- <description>Classes used for communication between batch and server</description>
-
- <properties>
- <!-- Viewer is for our internal use. This is not production code and mostly generated with Eclipse GUI builder -->
- <sonar.exclusions>target/generated-sources/**/*,src/main/java/org/sonar/batch/protocol/viewer/**</sonar.exclusions>
- <sonar.test.exclusions>target/generated-test-sources/**/*</sonar.test.exclusions>
- </properties>
-
- <dependencies>
- <dependency>
- <groupId>net.jpountz.lz4</groupId>
- <artifactId>lz4</artifactId>
- </dependency>
- <dependency>
- <groupId>com.google.protobuf</groupId>
- <artifactId>protobuf-java</artifactId>
- </dependency>
- <dependency>
- <groupId>com.google.code.gson</groupId>
- <artifactId>gson</artifactId>
- </dependency>
- <dependency>
- <groupId>com.google.code.findbugs</groupId>
- <artifactId>jsr305</artifactId>
- <scope>provided</scope>
- </dependency>
- <dependency>
- <groupId>commons-io</groupId>
- <artifactId>commons-io</artifactId>
- </dependency>
- <dependency>
- <groupId>${project.groupId}</groupId>
- <artifactId>sonar-core</artifactId>
- </dependency>
-
- <!-- unit tests -->
- <dependency>
- <groupId>junit</groupId>
- <artifactId>junit</artifactId>
- <scope>test</scope>
- </dependency>
- <dependency>
- <groupId>org.assertj</groupId>
- <artifactId>assertj-core</artifactId>
- <scope>test</scope>
- </dependency>
- <dependency>
- <groupId>org.mockito</groupId>
- <artifactId>mockito-core</artifactId>
- <scope>test</scope>
- </dependency>
- <dependency>
- <groupId>net.javacrumbs.json-unit</groupId>
- <artifactId>json-unit-assertj</artifactId>
- <version>0.0.15</version>
- <scope>test</scope>
- </dependency>
- <dependency>
- <groupId>com.google.guava</groupId>
- <artifactId>guava</artifactId>
- <scope>test</scope>
- </dependency>
- </dependencies>
-
- <build>
- <plugins>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-surefire-plugin</artifactId>
- <configuration>
- <skipTests>${skipBatchTests}</skipTests>
- </configuration>
- </plugin>
- <plugin>
- <artifactId>maven-assembly-plugin</artifactId>
- <configuration>
- <finalName>scanner-report-viewer-${project.version}</finalName>
- <archive>
- <manifest>
- <mainClass>org.sonar.batch.protocol.viewer.ViewerApplication</mainClass>
- </manifest>
- </archive>
- <descriptors>
- <descriptor>src/main/assembly/viewer.xml</descriptor>
- </descriptors>
- </configuration>
- <executions>
- <execution>
- <id>make-assembly</id>
- <phase>package</phase>
- <goals>
- <goal>single</goal>
- </goals>
- </execution>
- </executions>
- </plugin>
- </plugins>
- </build>
-</project>
diff --git a/sonar-batch-protocol/src/main/assembly/viewer.xml b/sonar-batch-protocol/src/main/assembly/viewer.xml
deleted file mode 100644
index dcb1ad07c78..00000000000
--- a/sonar-batch-protocol/src/main/assembly/viewer.xml
+++ /dev/null
@@ -1,22 +0,0 @@
-<assembly xmlns="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.3"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/plugins/maven-assembly-plugin/assembly/1.1.3 http://maven.apache.org/xsd/assembly-1.1.3.xsd">
- <id>full</id>
- <formats>
- <format>jar</format>
- </formats>
- <includeBaseDirectory>false</includeBaseDirectory>
- <dependencySets>
- <dependencySet>
- <outputDirectory>/</outputDirectory>
- <useProjectArtifact>true</useProjectArtifact>
- <unpack>true</unpack>
- <scope>runtime</scope>
- </dependencySet>
- </dependencySets>
- <fileSets>
- <fileSet>
- <directory>${project.build.outputDirectory}</directory>
- </fileSet>
- </fileSets>
-</assembly> \ No newline at end of file
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/GsonHelper.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/GsonHelper.java
deleted file mode 100644
index 8642a7d3120..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/GsonHelper.java
+++ /dev/null
@@ -1,35 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol;
-
-import com.google.gson.Gson;
-import com.google.gson.GsonBuilder;
-
-public class GsonHelper {
-
- private GsonHelper() {
- // Utility class
- }
-
- public static Gson create() {
- return new GsonBuilder().setDateFormat("yyyy-MM-dd'T'HH:mm:ssZ").setPrettyPrinting().create();
- }
-
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/FileData.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/FileData.java
deleted file mode 100644
index 20ccaf8dae4..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/FileData.java
+++ /dev/null
@@ -1,44 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.input;
-
-import javax.annotation.CheckForNull;
-import javax.annotation.Nullable;
-
-public class FileData {
-
- private final String hash;
- private final String revision;
-
- public FileData(@Nullable String hash, @Nullable String revision) {
- this.hash = hash;
- this.revision = revision;
- }
-
- @CheckForNull
- public String hash() {
- return hash;
- }
-
- @CheckForNull
- public String revision() {
- return revision;
- }
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/GlobalRepositories.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/GlobalRepositories.java
deleted file mode 100644
index c30032532a0..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/GlobalRepositories.java
+++ /dev/null
@@ -1,73 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.input;
-
-import org.sonar.batch.protocol.GsonHelper;
-
-import java.util.ArrayList;
-import java.util.Collection;
-import java.util.HashMap;
-import java.util.Map;
-
-/**
- * Container for all global data going from server to batch.
- * This is not an API since server and batch always share the same version.
- */
-public class GlobalRepositories {
-
- private long timestamp;
- private Collection<Metric> metrics = new ArrayList<>();
- private Map<String, String> globalSettings = new HashMap<>();
-
- public Map<String, String> globalSettings() {
- return globalSettings;
- }
-
- public GlobalRepositories addGlobalSetting(String key, String value) {
- globalSettings.put(key, value);
- return this;
- }
-
- public Collection<Metric> metrics() {
- return metrics;
- }
-
- public GlobalRepositories addMetric(Metric metric) {
- metrics.add(metric);
- return this;
- }
-
- public long timestamp() {
- return timestamp;
- }
-
- public void setTimestamp(long timestamp) {
- this.timestamp = timestamp;
- }
-
- public String toJson() {
- return GsonHelper.create().toJson(this);
- }
-
- public static GlobalRepositories fromJson(String json) {
- return GsonHelper.create().fromJson(json, GlobalRepositories.class);
- }
-
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/Metric.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/Metric.java
deleted file mode 100644
index 71619d9e593..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/Metric.java
+++ /dev/null
@@ -1,120 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.input;
-
-import javax.annotation.CheckForNull;
-import javax.annotation.Nullable;
-
-public class Metric {
-
- private final int id;
-
- private final String key;
-
- private final String valueType;
-
- private final String description;
-
- private final int direction;
-
- private final String name;
-
- private final boolean qualitative;
-
- private final boolean userManaged;
-
- private final Double worstValue;
-
- private final Double bestValue;
-
- private final boolean optimizedBestValue;
-
- public Metric(int id,
- String key,
- String valueType,
- @Nullable String description,
- int direction,
- String name,
- boolean qualitative,
- boolean userManaged,
- @Nullable Double worstValue,
- @Nullable Double bestValue,
- boolean optimizedBestValue) {
- this.id = id;
- this.key = key;
- this.valueType = valueType;
- this.description = description;
- this.direction = direction;
- this.name = name;
- this.qualitative = qualitative;
- this.userManaged = userManaged;
- this.worstValue = worstValue;
- this.bestValue = bestValue;
- this.optimizedBestValue = optimizedBestValue;
- }
-
- public int id() {
- return id;
- }
-
- public String key() {
- return key;
- }
-
- public String valueType() {
- return valueType;
- }
-
- @CheckForNull
- public String description() {
- return description;
- }
-
- public int direction() {
- return direction;
- }
-
- public String name() {
- return name;
- }
-
- public boolean isQualitative() {
- return qualitative;
- }
-
- public boolean isUserManaged() {
- return userManaged;
- }
-
- @CheckForNull
- public Double worstValue() {
- return worstValue;
- }
-
- @CheckForNull
- public Double bestValue() {
- return bestValue;
- }
-
- public boolean isOptimizedBestValue() {
- return optimizedBestValue;
- }
-
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/ProjectRepositories.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/ProjectRepositories.java
deleted file mode 100644
index e9d2c2f7771..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/ProjectRepositories.java
+++ /dev/null
@@ -1,115 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.input;
-
-import java.util.Collections;
-import java.util.Date;
-import java.util.HashMap;
-import java.util.Map;
-import javax.annotation.CheckForNull;
-import javax.annotation.Nullable;
-import org.sonar.batch.protocol.GsonHelper;
-
-/**
- * Container for all project data going from server to batch.
- * This is not an API since server and batch always share the same version.
- */
-public class ProjectRepositories {
-
- private long timestamp;
- private boolean exists;
- private Map<String, Map<String, String>> settingsByModule = new HashMap<>();
- private Map<String, Map<String, FileData>> fileDataByModuleAndPath = new HashMap<>();
- private Date lastAnalysisDate;
-
- public Map<String, String> settings(String moduleKey) {
- return settingsByModule.containsKey(moduleKey) ? settingsByModule.get(moduleKey) : Collections.<String, String>emptyMap();
- }
-
- public Map<String, Map<String, String>> settings() {
- return settingsByModule;
- }
-
- public ProjectRepositories addSettings(String moduleKey, Map<String, String> settings) {
- Map<String, String> existingSettings = settingsByModule.get(moduleKey);
- if (existingSettings == null) {
- existingSettings = new HashMap<>();
- settingsByModule.put(moduleKey, existingSettings);
- }
- existingSettings.putAll(settings);
- return this;
- }
-
- public boolean exists() {
- return exists;
- }
-
- public Map<String, Map<String, FileData>> fileDataByModuleAndPath() {
- return fileDataByModuleAndPath;
- }
-
- public Map<String, FileData> fileDataByPath(String moduleKey) {
- return fileDataByModuleAndPath.containsKey(moduleKey) ? fileDataByModuleAndPath.get(moduleKey) : Collections.<String, FileData>emptyMap();
- }
-
- public ProjectRepositories addFileData(String moduleKey, @Nullable String path, FileData fileData) {
- if (path == null || (fileData.hash() == null && fileData.revision() == null)) {
- return this;
- }
-
- Map<String, FileData> existingFileDataByPath = fileDataByModuleAndPath.get(moduleKey);
- if (existingFileDataByPath == null) {
- existingFileDataByPath = new HashMap<>();
- fileDataByModuleAndPath.put(moduleKey, existingFileDataByPath);
- }
- existingFileDataByPath.put(path, fileData);
- return this;
- }
-
- @CheckForNull
- public FileData fileData(String projectKey, String path) {
- return fileDataByPath(projectKey).get(path);
- }
-
- public long timestamp() {
- return timestamp;
- }
-
- public void setTimestamp(long timestamp) {
- this.timestamp = timestamp;
- }
-
- @CheckForNull
- public Date lastAnalysisDate() {
- return lastAnalysisDate;
- }
-
- public void setLastAnalysisDate(@Nullable Date lastAnalysisDate) {
- this.lastAnalysisDate = lastAnalysisDate;
- }
-
- public String toJson() {
- return GsonHelper.create().toJson(this);
- }
-
- public static ProjectRepositories fromJson(String json) {
- return GsonHelper.create().fromJson(json, ProjectRepositories.class);
- }
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/package-info.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/package-info.java
deleted file mode 100644
index d01715cd99d..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/input/package-info.java
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-@ParametersAreNonnullByDefault
-package org.sonar.batch.protocol.input;
-
-import javax.annotation.ParametersAreNonnullByDefault;
-
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/BatchReportReader.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/BatchReportReader.java
deleted file mode 100644
index 03aef1590ab..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/BatchReportReader.java
+++ /dev/null
@@ -1,172 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.output;
-
-import java.io.File;
-import javax.annotation.CheckForNull;
-import org.sonar.core.util.CloseableIterator;
-import org.sonar.core.util.Protobuf;
-
-import static org.sonar.core.util.CloseableIterator.emptyCloseableIterator;
-
-public class BatchReportReader {
-
- private final FileStructure fileStructure;
-
- public BatchReportReader(File dir) {
- this.fileStructure = new FileStructure(dir);
- }
-
- public BatchReport.Metadata readMetadata() {
- File file = fileStructure.metadataFile();
- if (!fileExists(file)) {
- throw new IllegalStateException("Metadata file is missing in analysis report: " + file);
- }
- return Protobuf.read(file, BatchReport.Metadata.PARSER);
- }
-
- public CloseableIterator<BatchReport.ActiveRule> readActiveRules() {
- File file = fileStructure.activeRules();
- if (!fileExists(file)) {
- return emptyCloseableIterator();
- }
- return Protobuf.readStream(file, BatchReport.ActiveRule.PARSER);
- }
-
- public CloseableIterator<BatchReport.Measure> readComponentMeasures(int componentRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.MEASURES, componentRef);
- if (fileExists(file)) {
- return Protobuf.readStream(file, BatchReport.Measure.PARSER);
- }
- return emptyCloseableIterator();
- }
-
- @CheckForNull
- public BatchReport.Changesets readChangesets(int componentRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.CHANGESETS, componentRef);
- if (fileExists(file)) {
- return Protobuf.read(file, BatchReport.Changesets.PARSER);
- }
- return null;
- }
-
- public BatchReport.Component readComponent(int componentRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.COMPONENT, componentRef);
- if (!fileExists(file)) {
- throw new IllegalStateException("Unable to find report for component #" + componentRef + ". File does not exist: " + file);
- }
- return Protobuf.read(file, BatchReport.Component.PARSER);
- }
-
- public CloseableIterator<BatchReport.Issue> readComponentIssues(int componentRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.ISSUES, componentRef);
- if (fileExists(file)) {
- return Protobuf.readStream(file, BatchReport.Issue.PARSER);
- }
- return emptyCloseableIterator();
- }
-
- public CloseableIterator<BatchReport.Duplication> readComponentDuplications(int componentRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.DUPLICATIONS, componentRef);
- if (fileExists(file)) {
- return Protobuf.readStream(file, BatchReport.Duplication.PARSER);
- }
- return emptyCloseableIterator();
- }
-
- public CloseableIterator<BatchReport.CpdTextBlock> readCpdTextBlocks(int componentRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.CPD_TEXT_BLOCKS, componentRef);
- if (fileExists(file)) {
- return Protobuf.readStream(file, BatchReport.CpdTextBlock.parser());
- }
- return emptyCloseableIterator();
- }
-
- public CloseableIterator<BatchReport.Symbol> readComponentSymbols(int componentRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.SYMBOLS, componentRef);
- if (fileExists(file)) {
- return Protobuf.readStream(file, BatchReport.Symbol.PARSER);
- }
- return emptyCloseableIterator();
- }
-
- public boolean hasSyntaxHighlighting(int componentRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.SYNTAX_HIGHLIGHTINGS, componentRef);
- return file.exists();
- }
-
- public CloseableIterator<BatchReport.SyntaxHighlighting> readComponentSyntaxHighlighting(int fileRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.SYNTAX_HIGHLIGHTINGS, fileRef);
- if (fileExists(file)) {
- return Protobuf.readStream(file, BatchReport.SyntaxHighlighting.PARSER);
- }
- return emptyCloseableIterator();
- }
-
- public boolean hasCoverage(int componentRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.COVERAGES, componentRef);
- return file.exists();
- }
-
- public CloseableIterator<BatchReport.Coverage> readComponentCoverage(int fileRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.COVERAGES, fileRef);
- if (fileExists(file)) {
- return Protobuf.readStream(file, BatchReport.Coverage.PARSER);
- }
- return emptyCloseableIterator();
- }
-
- @CheckForNull
- public File readFileSource(int fileRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.SOURCE, fileRef);
- if (fileExists(file)) {
- return file;
- }
- return null;
- }
-
- @CheckForNull
- public File readTests(int testFileRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.TESTS, testFileRef);
- if (fileExists(file)) {
- return file;
- }
-
- return null;
- }
-
- @CheckForNull
- public File readCoverageDetails(int testFileRef) {
- File file = fileStructure.fileFor(FileStructure.Domain.COVERAGE_DETAILS, testFileRef);
- if (fileExists(file)) {
- return file;
- }
-
- return null;
- }
-
- private static boolean fileExists(File file) {
- return file.exists() && file.isFile();
- }
-
- public FileStructure getFileStructure() {
- return fileStructure;
- }
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/BatchReportWriter.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/BatchReportWriter.java
deleted file mode 100644
index 709280683fa..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/BatchReportWriter.java
+++ /dev/null
@@ -1,141 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.output;
-
-import java.io.BufferedOutputStream;
-import java.io.File;
-import java.io.FileOutputStream;
-import java.io.OutputStream;
-import org.sonar.core.util.ContextException;
-import org.sonar.core.util.Protobuf;
-
-public class BatchReportWriter {
-
- private final FileStructure fileStructure;
-
- public BatchReportWriter(File dir) {
- if (!dir.exists() && !dir.mkdirs()) {
- throw new IllegalStateException("Unable to create directory: " + dir);
- }
- this.fileStructure = new FileStructure(dir);
- }
-
- public FileStructure getFileStructure() {
- return fileStructure;
- }
-
- public boolean hasComponentData(FileStructure.Domain domain, int componentRef) {
- File file = fileStructure.fileFor(domain, componentRef);
- return file.exists() && file.isFile();
- }
-
- /**
- * Metadata is mandatory
- */
- public File writeMetadata(BatchReport.Metadata metadata) {
- Protobuf.write(metadata, fileStructure.metadataFile());
- return fileStructure.metadataFile();
- }
-
- public File writeActiveRules(Iterable<BatchReport.ActiveRule> activeRules) {
- Protobuf.writeStream(activeRules, fileStructure.activeRules(), false);
- return fileStructure.metadataFile();
- }
-
- public File writeComponent(BatchReport.Component component) {
- File file = fileStructure.fileFor(FileStructure.Domain.COMPONENT, component.getRef());
- Protobuf.write(component, file);
- return file;
- }
-
- public File writeComponentIssues(int componentRef, Iterable<BatchReport.Issue> issues) {
- File file = fileStructure.fileFor(FileStructure.Domain.ISSUES, componentRef);
- Protobuf.writeStream(issues, file, false);
- return file;
- }
-
- public void appendComponentIssue(int componentRef, BatchReport.Issue issue) {
- File file = fileStructure.fileFor(FileStructure.Domain.ISSUES, componentRef);
- try (OutputStream out = new BufferedOutputStream(new FileOutputStream(file, true))) {
- issue.writeDelimitedTo(out);
- } catch (Exception e) {
- throw ContextException.of("Unable to write issue", e).addContext("file", file);
- }
- }
-
- public File writeComponentMeasures(int componentRef, Iterable<BatchReport.Measure> measures) {
- File file = fileStructure.fileFor(FileStructure.Domain.MEASURES, componentRef);
- Protobuf.writeStream(measures, file, false);
- return file;
- }
-
- public File writeComponentChangesets(BatchReport.Changesets changesets) {
- File file = fileStructure.fileFor(FileStructure.Domain.CHANGESETS, changesets.getComponentRef());
- Protobuf.write(changesets, file);
- return file;
- }
-
- public File writeComponentDuplications(int componentRef, Iterable<BatchReport.Duplication> duplications) {
- File file = fileStructure.fileFor(FileStructure.Domain.DUPLICATIONS, componentRef);
- Protobuf.writeStream(duplications, file, false);
- return file;
- }
-
- public File writeCpdTextBlocks(int componentRef, Iterable<BatchReport.CpdTextBlock> blocks) {
- File file = fileStructure.fileFor(FileStructure.Domain.CPD_TEXT_BLOCKS, componentRef);
- Protobuf.writeStream(blocks, file, false);
- return file;
- }
-
- public File writeComponentSymbols(int componentRef, Iterable<BatchReport.Symbol> symbols) {
- File file = fileStructure.fileFor(FileStructure.Domain.SYMBOLS, componentRef);
- Protobuf.writeStream(symbols, file, false);
- return file;
- }
-
- public File writeComponentSyntaxHighlighting(int componentRef, Iterable<BatchReport.SyntaxHighlighting> syntaxHighlightingRules) {
- File file = fileStructure.fileFor(FileStructure.Domain.SYNTAX_HIGHLIGHTINGS, componentRef);
- Protobuf.writeStream(syntaxHighlightingRules, file, false);
- return file;
- }
-
- public File writeComponentCoverage(int componentRef, Iterable<BatchReport.Coverage> coverageList) {
- File file = fileStructure.fileFor(FileStructure.Domain.COVERAGES, componentRef);
- Protobuf.writeStream(coverageList, file, false);
- return file;
- }
-
- public File writeTests(int componentRef, Iterable<BatchReport.Test> tests) {
- File file = fileStructure.fileFor(FileStructure.Domain.TESTS, componentRef);
- Protobuf.writeStream(tests, file, false);
- return file;
- }
-
- public File writeCoverageDetails(int componentRef, Iterable<BatchReport.CoverageDetail> tests) {
- File file = fileStructure.fileFor(FileStructure.Domain.COVERAGE_DETAILS, componentRef);
- Protobuf.writeStream(tests, file, false);
- return file;
- }
-
- public File getSourceFile(int componentRef) {
- return fileStructure.fileFor(FileStructure.Domain.SOURCE, componentRef);
- }
-
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/FileStructure.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/FileStructure.java
deleted file mode 100644
index 0314590cd66..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/FileStructure.java
+++ /dev/null
@@ -1,78 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.output;
-
-import java.io.File;
-
-/**
- * Structure of files in the zipped report
- */
-public class FileStructure {
-
- public enum Domain {
- ISSUES("issues-", Domain.PB),
- COMPONENT("component-", Domain.PB),
- MEASURES("measures-", Domain.PB),
- DUPLICATIONS("duplications-", Domain.PB),
- CPD_TEXT_BLOCKS("cpd-text-block-", Domain.PB),
- SYNTAX_HIGHLIGHTINGS("syntax-highlightings-", Domain.PB),
- CHANGESETS("changesets-", Domain.PB),
- SYMBOLS("symbols-", Domain.PB),
- COVERAGES("coverages-", Domain.PB),
- TESTS("tests-", Domain.PB),
- COVERAGE_DETAILS("coverage-details-", Domain.PB),
- SOURCE("source-", ".txt");
-
- private static final String PB = ".pb";
- private final String filePrefix;
- private final String fileSuffix;
-
- Domain(String filePrefix, String fileSuffix) {
- this.filePrefix = filePrefix;
- this.fileSuffix = fileSuffix;
- }
- }
-
- private final File dir;
-
- public FileStructure(File dir) {
- if (!dir.exists() || !dir.isDirectory()) {
- throw new IllegalArgumentException("Directory of analysis report does not exist: " + dir);
- }
- this.dir = dir;
- }
-
- public File metadataFile() {
- return new File(dir, "metadata.pb");
- }
-
- public File analysisLog() {
- return new File(dir, "analysis.log");
- }
-
- public File activeRules() {
- return new File(dir, "activerules.pb");
- }
-
- public File fileFor(Domain domain, int componentRef) {
- return new File(dir, domain.filePrefix + componentRef + domain.fileSuffix);
- }
-
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/package-info.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/package-info.java
deleted file mode 100644
index 1f3003c7445..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/output/package-info.java
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-@ParametersAreNonnullByDefault
-package org.sonar.batch.protocol.output;
-
-import javax.annotation.ParametersAreNonnullByDefault;
-
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/package-info.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/package-info.java
deleted file mode 100644
index 787f7c26865..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/package-info.java
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-@ParametersAreNonnullByDefault
-package org.sonar.batch.protocol;
-
-import javax.annotation.ParametersAreNonnullByDefault;
-
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/TextLineNumber.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/TextLineNumber.java
deleted file mode 100644
index a4bcfa48750..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/TextLineNumber.java
+++ /dev/null
@@ -1,457 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.viewer;
-
-import java.awt.Color;
-import java.awt.Dimension;
-import java.awt.Font;
-import java.awt.FontMetrics;
-import java.awt.Graphics;
-import java.awt.Insets;
-import java.awt.Point;
-import java.awt.Rectangle;
-import java.beans.PropertyChangeEvent;
-import java.beans.PropertyChangeListener;
-import java.util.HashMap;
-import javax.swing.JPanel;
-import javax.swing.SwingUtilities;
-import javax.swing.border.Border;
-import javax.swing.border.CompoundBorder;
-import javax.swing.border.EmptyBorder;
-import javax.swing.border.MatteBorder;
-import javax.swing.event.CaretEvent;
-import javax.swing.event.CaretListener;
-import javax.swing.event.DocumentEvent;
-import javax.swing.event.DocumentListener;
-import javax.swing.text.AttributeSet;
-import javax.swing.text.BadLocationException;
-import javax.swing.text.Element;
-import javax.swing.text.JTextComponent;
-import javax.swing.text.StyleConstants;
-import javax.swing.text.Utilities;
-
-/**
- * This class will display line numbers for a related text component. The text
- * component must use the same line height for each line. TextLineNumber
- * supports wrapped lines and will highlight the line number of the current
- * line in the text component.
- *
- * This class was designed to be used as a component added to the row header
- * of a JScrollPane.
- */
-public class TextLineNumber extends JPanel implements CaretListener, DocumentListener, PropertyChangeListener {
- public static final float LEFT = 0.0f;
- public static final float CENTER = 0.5f;
- public static final float RIGHT = 1.0f;
-
- private static final Border OUTER = new MatteBorder(0, 0, 0, 2, Color.GRAY);
-
- private static final int HEIGHT = Integer.MAX_VALUE - 1000000;
-
- // Text component this TextTextLineNumber component is in sync with
-
- private JTextComponent component;
-
- // Properties that can be changed
-
- private boolean updateFont;
- private int borderGap;
- private Color currentLineForeground;
- private float digitAlignment;
- private int minimumDisplayDigits;
-
- // Keep history information to reduce the number of times the component
- // needs to be repainted
-
- private int lastDigits;
- private int lastHeight;
- private int lastLine;
-
- private HashMap<String, FontMetrics> fonts;
-
- /**
- * Create a line number component for a text component. This minimum
- * display width will be based on 3 digits.
- *
- * @param component the related text component
- */
- public TextLineNumber(JTextComponent component) {
- this(component, 3);
- }
-
- /**
- * Create a line number component for a text component.
- *
- * @param component the related text component
- * @param minimumDisplayDigits the number of digits used to calculate
- * the minimum width of the component
- */
- public TextLineNumber(JTextComponent component, int minimumDisplayDigits) {
- this.component = component;
-
- setFont(component.getFont());
-
- setBorderGap(5);
- setCurrentLineForeground(Color.RED);
- setDigitAlignment(RIGHT);
- setMinimumDisplayDigits(minimumDisplayDigits);
-
- component.getDocument().addDocumentListener(this);
- component.addCaretListener(this);
- component.addPropertyChangeListener("font", this);
- }
-
- /**
- * Gets the update font property
- *
- * @return the update font property
- */
- public boolean getUpdateFont() {
- return updateFont;
- }
-
- /**
- * Set the update font property. Indicates whether this Font should be
- * updated automatically when the Font of the related text component
- * is changed.
- *
- * @param updateFont when true update the Font and repaint the line
- * numbers, otherwise just repaint the line numbers.
- */
- public void setUpdateFont(boolean updateFont) {
- this.updateFont = updateFont;
- }
-
- /**
- * Gets the border gap
- *
- * @return the border gap in pixels
- */
- public int getBorderGap() {
- return borderGap;
- }
-
- /**
- * The border gap is used in calculating the left and right insets of the
- * border. Default value is 5.
- *
- * @param borderGap the gap in pixels
- */
- public void setBorderGap(int borderGap) {
- this.borderGap = borderGap;
- Border inner = new EmptyBorder(0, borderGap, 0, borderGap);
- setBorder(new CompoundBorder(OUTER, inner));
- lastDigits = 0;
- setPreferredWidth();
- }
-
- /**
- * Gets the current line rendering Color
- *
- * @return the Color used to render the current line number
- */
- public Color getCurrentLineForeground() {
- return currentLineForeground == null ? getForeground() : currentLineForeground;
- }
-
- /**
- * The Color used to render the current line digits. Default is Coolor.RED.
- *
- * @param currentLineForeground the Color used to render the current line
- */
- public void setCurrentLineForeground(Color currentLineForeground) {
- this.currentLineForeground = currentLineForeground;
- }
-
- /**
- * Gets the digit alignment
- *
- * @return the alignment of the painted digits
- */
- public float getDigitAlignment() {
- return digitAlignment;
- }
-
- /**
- * Specify the horizontal alignment of the digits within the component.
- * Common values would be:
- * <ul>
- * <li>TextLineNumber.LEFT
- * <li>TextLineNumber.CENTER
- * <li>TextLineNumber.RIGHT (default)
- * </ul>
- * @param currentLineForeground the Color used to render the current line
- */
- public void setDigitAlignment(float digitAlignment) {
- this.digitAlignment = digitAlignment > 1.0f ? 1.0f : digitAlignment < 0.0f ? -1.0f : digitAlignment;
- }
-
- /**
- * Gets the minimum display digits
- *
- * @return the minimum display digits
- */
- public int getMinimumDisplayDigits() {
- return minimumDisplayDigits;
- }
-
- /**
- * Specify the mimimum number of digits used to calculate the preferred
- * width of the component. Default is 3.
- *
- * @param minimumDisplayDigits the number digits used in the preferred
- * width calculation
- */
- public void setMinimumDisplayDigits(int minimumDisplayDigits) {
- this.minimumDisplayDigits = minimumDisplayDigits;
- setPreferredWidth();
- }
-
- /**
- * Calculate the width needed to display the maximum line number
- */
- private void setPreferredWidth() {
- Element root = component.getDocument().getDefaultRootElement();
- int lines = root.getElementCount();
- int digits = Math.max(String.valueOf(lines).length(), minimumDisplayDigits);
-
- // Update sizes when number of digits in the line number changes
-
- if (lastDigits != digits) {
- lastDigits = digits;
- FontMetrics fontMetrics = getFontMetrics(getFont());
- int width = fontMetrics.charWidth('0') * digits;
- Insets insets = getInsets();
- int preferredWidth = insets.left + insets.right + width;
-
- Dimension d = getPreferredSize();
- d.setSize(preferredWidth, HEIGHT);
- setPreferredSize(d);
- setSize(d);
- }
- }
-
- /**
- * Draw the line numbers
- */
- @Override
- public void paintComponent(Graphics g) {
- super.paintComponent(g);
-
- // Determine the width of the space available to draw the line number
-
- FontMetrics fontMetrics = component.getFontMetrics(component.getFont());
- Insets insets = getInsets();
- int availableWidth = getSize().width - insets.left - insets.right;
-
- // Determine the rows to draw within the clipped bounds.
-
- Rectangle clip = g.getClipBounds();
- int rowStartOffset = component.viewToModel(new Point(0, clip.y));
- int endOffset = component.viewToModel(new Point(0, clip.y + clip.height));
-
- while (rowStartOffset <= endOffset) {
- try {
- if (isCurrentLine(rowStartOffset))
- g.setColor(getCurrentLineForeground());
- else
- g.setColor(getForeground());
-
- // Get the line number as a string and then determine the
- // "X" and "Y" offsets for drawing the string.
-
- String lineNumber = getTextLineNumber(rowStartOffset);
- int stringWidth = fontMetrics.stringWidth(lineNumber);
- int x = getOffsetX(availableWidth, stringWidth) + insets.left;
- int y = getOffsetY(rowStartOffset, fontMetrics);
- g.drawString(lineNumber, x, y);
-
- // Move to the next row
-
- rowStartOffset = Utilities.getRowEnd(component, rowStartOffset) + 1;
- } catch (Exception e) {
- break;
- }
- }
- }
-
- /*
- * We need to know if the caret is currently positioned on the line we
- * are about to paint so the line number can be highlighted.
- */
- private boolean isCurrentLine(int rowStartOffset) {
- int caretPosition = component.getCaretPosition();
- Element root = component.getDocument().getDefaultRootElement();
-
- return root.getElementIndex(rowStartOffset) == root.getElementIndex(caretPosition);
- }
-
- /*
- * Get the line number to be drawn. The empty string will be returned
- * when a line of text has wrapped.
- */
- protected String getTextLineNumber(int rowStartOffset) {
- Element root = component.getDocument().getDefaultRootElement();
- int index = root.getElementIndex(rowStartOffset);
- Element line = root.getElement(index);
-
- if (line.getStartOffset() == rowStartOffset)
- return String.valueOf(index + 1);
- else
- return "";
- }
-
- /*
- * Determine the X offset to properly align the line number when drawn
- */
- private int getOffsetX(int availableWidth, int stringWidth) {
- return (int) ((availableWidth - stringWidth) * digitAlignment);
- }
-
- /*
- * Determine the Y offset for the current row
- */
- private int getOffsetY(int rowStartOffset, FontMetrics fontMetrics)
- throws BadLocationException {
- // Get the bounding rectangle of the row
-
- Rectangle r = component.modelToView(rowStartOffset);
- int lineHeight = fontMetrics.getHeight();
- int y = r.y + r.height;
- int descent = 0;
-
- // The text needs to be positioned above the bottom of the bounding
- // rectangle based on the descent of the font(s) contained on the row.
-
- if (r.height == lineHeight) // default font is being used
- {
- descent = fontMetrics.getDescent();
- } else // We need to check all the attributes for font changes
- {
- if (fonts == null)
- fonts = new HashMap<>();
-
- Element root = component.getDocument().getDefaultRootElement();
- int index = root.getElementIndex(rowStartOffset);
- Element line = root.getElement(index);
-
- for (int i = 0; i < line.getElementCount(); i++) {
- Element child = line.getElement(i);
- AttributeSet as = child.getAttributes();
- String fontFamily = (String) as.getAttribute(StyleConstants.FontFamily);
- Integer fontSize = (Integer) as.getAttribute(StyleConstants.FontSize);
- String key = fontFamily + fontSize;
-
- FontMetrics fm = fonts.get(key);
-
- if (fm == null) {
- Font font = new Font(fontFamily, Font.PLAIN, fontSize);
- fm = component.getFontMetrics(font);
- fonts.put(key, fm);
- }
-
- descent = Math.max(descent, fm.getDescent());
- }
- }
-
- return y - descent;
- }
-
- //
- // Implement CaretListener interface
- //
- @Override
- public void caretUpdate(CaretEvent e) {
- // Get the line the caret is positioned on
-
- int caretPosition = component.getCaretPosition();
- Element root = component.getDocument().getDefaultRootElement();
- int currentLine = root.getElementIndex(caretPosition);
-
- // Need to repaint so the correct line number can be highlighted
-
- if (lastLine != currentLine) {
- repaint();
- lastLine = currentLine;
- }
- }
-
- //
- // Implement DocumentListener interface
- //
- @Override
- public void changedUpdate(DocumentEvent e) {
- documentChanged();
- }
-
- @Override
- public void insertUpdate(DocumentEvent e) {
- documentChanged();
- }
-
- @Override
- public void removeUpdate(DocumentEvent e) {
- documentChanged();
- }
-
- /*
- * A document change may affect the number of displayed lines of text.
- * Therefore the lines numbers will also change.
- */
- private void documentChanged() {
- // View of the component has not been updated at the time
- // the DocumentEvent is fired
-
- SwingUtilities.invokeLater(new Runnable() {
- @Override
- public void run() {
- try {
- int endPos = component.getDocument().getLength();
- Rectangle rect = component.modelToView(endPos);
-
- if (rect != null && rect.y != lastHeight) {
- setPreferredWidth();
- repaint();
- lastHeight = rect.y;
- }
- } catch (BadLocationException ex) {
- /* nothing to do */
- }
- }
- });
- }
-
- //
- // Implement PropertyChangeListener interface
- //
- @Override
- public void propertyChange(PropertyChangeEvent evt) {
- if (evt.getNewValue() instanceof Font) {
- if (updateFont) {
- Font newFont = (Font) evt.getNewValue();
- setFont(newFont);
- lastDigits = 0;
- setPreferredWidth();
- } else {
- repaint();
- }
- }
- }
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/ViewerApplication.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/ViewerApplication.java
deleted file mode 100644
index a3476adab4e..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/ViewerApplication.java
+++ /dev/null
@@ -1,388 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.viewer;
-
-import java.awt.BorderLayout;
-import java.awt.Cursor;
-import java.awt.Dimension;
-import java.awt.EventQueue;
-import java.io.File;
-import java.io.IOException;
-import java.io.PrintWriter;
-import java.io.StringWriter;
-import java.nio.charset.StandardCharsets;
-import java.sql.Date;
-import java.text.SimpleDateFormat;
-import java.util.Scanner;
-import javax.swing.JEditorPane;
-import javax.swing.JFileChooser;
-import javax.swing.JFrame;
-import javax.swing.JOptionPane;
-import javax.swing.JPanel;
-import javax.swing.JScrollPane;
-import javax.swing.JSplitPane;
-import javax.swing.JTabbedPane;
-import javax.swing.JTree;
-import javax.swing.UIManager;
-import javax.swing.UIManager.LookAndFeelInfo;
-import javax.swing.event.TreeSelectionEvent;
-import javax.swing.event.TreeSelectionListener;
-import javax.swing.tree.DefaultMutableTreeNode;
-import javax.swing.tree.DefaultTreeModel;
-import javax.swing.tree.TreeSelectionModel;
-import org.sonar.batch.protocol.output.BatchReport;
-import org.sonar.batch.protocol.output.BatchReport.Component;
-import org.sonar.batch.protocol.output.BatchReport.Metadata;
-import org.sonar.batch.protocol.output.BatchReportReader;
-import org.sonar.batch.protocol.output.FileStructure.Domain;
-import org.sonar.core.util.CloseableIterator;
-
-public class ViewerApplication {
-
- private JFrame frame;
- private BatchReportReader reader;
- private Metadata metadata;
- private SimpleDateFormat sdf = new SimpleDateFormat("dd/MM/yyyy HH:mm:ss");
- private JTree componentTree;
- private JSplitPane splitPane;
- private JTabbedPane tabbedPane;
- private JScrollPane treeScrollPane;
- private JScrollPane componentDetailsTab;
- private JScrollPane highlightingTab;
- private JScrollPane symbolTab;
- private JEditorPane componentEditor;
- private JEditorPane highlightingEditor;
- private JEditorPane symbolEditor;
- private JScrollPane sourceTab;
- private JEditorPane sourceEditor;
- private JScrollPane coverageTab;
- private JEditorPane coverageEditor;
- private TextLineNumber textLineNumber;
- private JScrollPane duplicationTab;
- private JEditorPane duplicationEditor;
-
- /**
- * Create the application.
- */
- public ViewerApplication() {
- initialize();
- }
-
- /**
- * Launch the application.
- */
- public static void main(String[] args) {
- EventQueue.invokeLater(new Runnable() {
- @Override
- public void run() {
- try {
- ViewerApplication window = new ViewerApplication();
- window.frame.setVisible(true);
-
- window.loadReport();
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
-
- });
- }
-
- private void loadReport() {
- final JFileChooser fc = new JFileChooser();
- fc.setDialogTitle("Choose scanner report directory");
- fc.setFileSelectionMode(JFileChooser.DIRECTORIES_ONLY);
- fc.setFileHidingEnabled(false);
- fc.setApproveButtonText("Open scanner report");
- int returnVal = fc.showOpenDialog(frame);
- if (returnVal == JFileChooser.APPROVE_OPTION) {
- File file = fc.getSelectedFile();
- try {
- loadReport(file);
- } catch (Exception e) {
- JOptionPane.showMessageDialog(frame, e.getMessage(), "Error", JOptionPane.ERROR_MESSAGE);
- exit();
- }
- } else {
- exit();
- }
-
- }
-
- private void exit() {
- frame.setVisible(false);
- frame.dispose();
- }
-
- private void loadReport(File file) {
- reader = new BatchReportReader(file);
- metadata = reader.readMetadata();
- updateTitle();
- loadComponents();
- }
-
- private void loadComponents() {
- int rootComponentRef = metadata.getRootComponentRef();
- Component component = reader.readComponent(rootComponentRef);
- DefaultMutableTreeNode project = createNode(component);
- loadChildren(component, project);
- getComponentTree().setModel(new DefaultTreeModel(project));
- }
-
- private static DefaultMutableTreeNode createNode(Component component) {
- return new DefaultMutableTreeNode(component) {
- @Override
- public String toString() {
- return getNodeName((Component) getUserObject());
- }
- };
- }
-
- private static String getNodeName(Component component) {
- switch (component.getType()) {
- case PROJECT:
- case MODULE:
- return component.getName();
- case DIRECTORY:
- case FILE:
- return component.getPath();
- default:
- throw new IllegalArgumentException("Unknow component type: " + component.getType());
- }
- }
-
- private void loadChildren(Component parentComponent, DefaultMutableTreeNode parentNode) {
- for (int ref : parentComponent.getChildRefList()) {
- Component child = reader.readComponent(ref);
- DefaultMutableTreeNode childNode = createNode(child);
- parentNode.add(childNode);
- loadChildren(child, childNode);
- }
-
- }
-
- private void updateTitle() {
- frame.setTitle(metadata.getProjectKey() + (metadata.hasBranch() ? (" (" + metadata.getBranch() + ")") : "") + " " + sdf.format(new Date(metadata.getAnalysisDate())));
- }
-
- private void updateDetails(Component component) {
- componentEditor.setText(component.toString());
- updateHighlighting(component);
- updateSymbols(component);
- updateSource(component);
- updateCoverage(component);
- updateDuplications(component);
- }
-
- private void updateDuplications(Component component) {
- duplicationEditor.setText("");
- if (reader.hasCoverage(component.getRef())) {
- try (CloseableIterator<BatchReport.Duplication> it = reader.readComponentDuplications(component.getRef())) {
- while (it.hasNext()) {
- BatchReport.Duplication dup = it.next();
- duplicationEditor.getDocument().insertString(duplicationEditor.getDocument().getEndPosition().getOffset(), dup.toString() + "\n", null);
- }
- } catch (Exception e) {
- throw new IllegalStateException("Can't read duplications for " + getNodeName(component), e);
- }
- }
- }
-
- private void updateCoverage(Component component) {
- coverageEditor.setText("");
- try (CloseableIterator<BatchReport.Coverage> it = reader.readComponentCoverage(component.getRef())) {
- while (it.hasNext()) {
- BatchReport.Coverage coverage = it.next();
- coverageEditor.getDocument().insertString(coverageEditor.getDocument().getEndPosition().getOffset(), coverage.toString() + "\n", null);
- }
- } catch (Exception e) {
- throw new IllegalStateException("Can't read code coverage for " + getNodeName(component), e);
- }
- }
-
- private void updateSource(Component component) {
- File sourceFile = reader.getFileStructure().fileFor(Domain.SOURCE, component.getRef());
- sourceEditor.setText("");
-
- if (sourceFile.exists()) {
- try (Scanner s = new Scanner(sourceFile, StandardCharsets.UTF_8.name()).useDelimiter("\\Z")) {
- if (s.hasNext()) {
- sourceEditor.setText(s.next());
- }
- } catch (IOException ex) {
- StringWriter errors = new StringWriter();
- ex.printStackTrace(new PrintWriter(errors));
- sourceEditor.setText(errors.toString());
- }
- }
- }
-
- private void updateHighlighting(Component component) {
- highlightingEditor.setText("");
- try (CloseableIterator<BatchReport.SyntaxHighlighting> it = reader.readComponentSyntaxHighlighting(component.getRef())) {
- while (it.hasNext()) {
- BatchReport.SyntaxHighlighting rule = it.next();
- highlightingEditor.getDocument().insertString(highlightingEditor.getDocument().getEndPosition().getOffset(), rule.toString() + "\n", null);
- }
- } catch (Exception e) {
- throw new IllegalStateException("Can't read syntax highlighting for " + getNodeName(component), e);
- }
- }
-
- private void updateSymbols(Component component) {
- symbolEditor.setText("");
- try (CloseableIterator<BatchReport.Symbol> it = reader.readComponentSymbols(component.getRef())) {
- while (it.hasNext()) {
- BatchReport.Symbol symbol = it.next();
- symbolEditor.getDocument().insertString(symbolEditor.getDocument().getEndPosition().getOffset(), symbol.toString() + "\n", null);
- }
- } catch (Exception e) {
- throw new IllegalStateException("Can't read symbol references for " + getNodeName(component), e);
- }
- }
-
- /**
- * Initialize the contents of the frame.
- */
- private void initialize() {
- try {
- for (LookAndFeelInfo info : UIManager.getInstalledLookAndFeels()) {
- if ("Nimbus".equals(info.getName())) {
- UIManager.setLookAndFeel(info.getClassName());
- break;
- }
- }
- } catch (Exception e) {
- // If Nimbus is not available, you can set the GUI to another look and feel.
- }
- frame = new JFrame();
- frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
-
- splitPane = new JSplitPane();
- frame.getContentPane().add(splitPane, BorderLayout.CENTER);
-
- tabbedPane = new JTabbedPane(JTabbedPane.TOP);
- tabbedPane.setPreferredSize(new Dimension(500, 7));
- splitPane.setRightComponent(tabbedPane);
-
- componentDetailsTab = new JScrollPane();
- tabbedPane.addTab("Component details", null, componentDetailsTab, null);
-
- componentEditor = new JEditorPane();
- componentDetailsTab.setViewportView(componentEditor);
-
- sourceTab = new JScrollPane();
- tabbedPane.addTab("Source", null, sourceTab, null);
-
- sourceEditor = createSourceEditor();
- sourceEditor.setEditable(false);
- sourceTab.setViewportView(sourceEditor);
-
- textLineNumber = createTextLineNumber();
- sourceTab.setRowHeaderView(textLineNumber);
-
- highlightingTab = new JScrollPane();
- tabbedPane.addTab("Highlighting", null, highlightingTab, null);
-
- highlightingEditor = new JEditorPane();
- highlightingTab.setViewportView(highlightingEditor);
-
- symbolTab = new JScrollPane();
- tabbedPane.addTab("Symbol references", null, symbolTab, null);
-
- symbolEditor = new JEditorPane();
- symbolTab.setViewportView(symbolEditor);
-
- coverageTab = new JScrollPane();
- tabbedPane.addTab("Coverage", null, coverageTab, null);
-
- coverageEditor = new JEditorPane();
- coverageTab.setViewportView(coverageEditor);
-
- duplicationTab = new JScrollPane();
- tabbedPane.addTab("Duplications", null, duplicationTab, null);
-
- duplicationEditor = new JEditorPane();
- duplicationTab.setViewportView(duplicationEditor);
-
- treeScrollPane = new JScrollPane();
- treeScrollPane.setPreferredSize(new Dimension(200, 400));
- splitPane.setLeftComponent(treeScrollPane);
-
- componentTree = new JTree();
- componentTree.setModel(new DefaultTreeModel(
- new DefaultMutableTreeNode("empty") {
- {
- }
- }));
- treeScrollPane.setViewportView(componentTree);
- componentTree.getSelectionModel().setSelectionMode(TreeSelectionModel.SINGLE_TREE_SELECTION);
- componentTree.addTreeSelectionListener(new TreeSelectionListener() {
- @Override
- public void valueChanged(TreeSelectionEvent e) {
- DefaultMutableTreeNode node = (DefaultMutableTreeNode) componentTree.getLastSelectedPathComponent();
-
- if (node == null) {
- // Nothing is selected.
- return;
- }
-
- frame.setCursor(new Cursor(Cursor.WAIT_CURSOR));
- updateDetails((Component) node.getUserObject());
- frame.setCursor(new Cursor(Cursor.DEFAULT_CURSOR));
-
- }
-
- });
- frame.pack();
- }
-
- public JTree getComponentTree() {
- return componentTree;
- }
-
- /**
- * @wbp.factory
- */
- public static JPanel createComponentPanel() {
- JPanel panel = new JPanel();
- return panel;
- }
-
- protected JEditorPane getComponentEditor() {
- return componentEditor;
- }
-
- /**
- * @wbp.factory
- */
- public static JEditorPane createSourceEditor() {
- JEditorPane editorPane = new JEditorPane();
- return editorPane;
- }
-
- /**
- * @wbp.factory
- */
- public TextLineNumber createTextLineNumber() {
- TextLineNumber textLineNumber = new TextLineNumber(sourceEditor);
- return textLineNumber;
- }
-}
diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/package-info.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/package-info.java
deleted file mode 100644
index f518f9be464..00000000000
--- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/viewer/package-info.java
+++ /dev/null
@@ -1,24 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-@ParametersAreNonnullByDefault
-package org.sonar.batch.protocol.viewer;
-
-import javax.annotation.ParametersAreNonnullByDefault;
-
diff --git a/sonar-batch-protocol/src/main/protobuf/batch_input.proto b/sonar-batch-protocol/src/main/protobuf/batch_input.proto
deleted file mode 100644
index 06edb314b5e..00000000000
--- a/sonar-batch-protocol/src/main/protobuf/batch_input.proto
+++ /dev/null
@@ -1,56 +0,0 @@
-// SonarQube, open source software quality management tool.
-// Copyright (C) 2008-2015 SonarSource
-// mailto:contact AT sonarsource DOT com
-//
-// SonarQube is free software; you can redistribute it and/or
-// modify it under the terms of the GNU Lesser General Public
-// License as published by the Free Software Foundation; either
-// version 3 of the License, or (at your option) any later version.
-//
-// SonarQube 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
-// Lesser General Public License for more details.
-//
-// You should have received a copy of the GNU Lesser General Public License
-// along with this program; if not, write to the Free Software Foundation,
-// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-
-/*
-Notes
-
- - "required" fields are not used as recommended by Google to keep forward-compatibility:
- https://developers.google.com/protocol-buffers/docs/proto#simple
-
- - this is beta version of specification. It will evolve during next releases and is
- not forward-compatible yet.
-*/
-
-syntax = "proto2";
-
-import "constants.proto";
-
-option java_package = "org.sonar.batch.protocol.input";
-option optimize_for = SPEED;
-
-message ServerIssue {
- optional string key = 1;
- optional string module_key = 2;
- optional string path = 3;
- optional string rule_repository = 4;
- optional string rule_key = 5;
- optional int32 line = 6;
- optional string msg = 7;
- optional Severity severity = 8;
- optional bool manual_severity = 9;
- optional string resolution = 10;
- optional string status = 11;
- optional string checksum = 12;
- optional string assignee_login = 13;
- optional int64 creation_date = 14;
-}
-
-message User {
- optional string login = 1;
- optional string name = 2;
-}
diff --git a/sonar-batch-protocol/src/main/protobuf/batch_report.proto b/sonar-batch-protocol/src/main/protobuf/batch_report.proto
deleted file mode 100644
index 2abebf20e00..00000000000
--- a/sonar-batch-protocol/src/main/protobuf/batch_report.proto
+++ /dev/null
@@ -1,213 +0,0 @@
-// SonarQube, open source software quality management tool.
-// Copyright (C) 2008-2015 SonarSource
-// mailto:contact AT sonarsource DOT com
-//
-// SonarQube is free software; you can redistribute it and/or
-// modify it under the terms of the GNU Lesser General Public
-// License as published by the Free Software Foundation; either
-// version 3 of the License, or (at your option) any later version.
-//
-// SonarQube 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
-// Lesser General Public License for more details.
-//
-// You should have received a copy of the GNU Lesser General Public License
-// along with this program; if not, write to the Free Software Foundation,
-// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-
-/*
-Notes
-
- - "required" fields are not used as recommended by Google to keep forward-compatibility:
- https://developers.google.com/protocol-buffers/docs/proto#simple
-
- - this is beta version of specification. It will evolve during next releases and is
- not forward-compatible yet.
-*/
-
-syntax = "proto2";
-
-import "constants.proto";
-
-option java_package = "org.sonar.batch.protocol.output";
-
-option optimize_for = SPEED;
-
-message Metadata {
- optional int64 analysis_date = 1;
- // TODO should we keep this project_key here or not ? Because it's a duplication of Component.key
- optional string project_key = 2;
- optional string branch = 3;
- optional int32 root_component_ref = 4;
- optional bool cross_project_duplication_activated = 5;
-}
-
-message ActiveRule {
- optional string rule_repository = 1;
- optional string rule_key = 2;
- optional Severity severity = 3;
- repeated ActiveRuleParam param = 4;
-
- // TODO replace by map
- message ActiveRuleParam {
- optional string key = 1;
- optional string value = 2;
- }
-}
-
-message ComponentLink {
- optional ComponentLinkType type = 1;
- optional string href = 2;
-}
-
-message Component {
- optional int32 ref = 1;
- optional string path = 2;
- optional string name = 3;
- optional ComponentType type = 4;
- optional bool is_test = 5;
- optional string language = 6;
- repeated int32 child_ref = 7 [packed = true];
- repeated ComponentLink link = 8;
- // Only available on PROJECT and MODULE types
- optional string version = 9;
- // Only available on PROJECT and MODULE types
- // TODO rename this property -> batchKey ? moduleKey ?
- optional string key = 10;
- // Only available on FILE type
- optional int32 lines = 11;
- // Only available on PROJECT and MODULE types
- optional string description = 12;
-}
-
-message Measure {
- optional MeasureValueType value_type = 1;
- // all values may be unset for "new_xxx" measures (only variations are populated)
- optional bool boolean_value = 2;
- optional int32 int_value = 3;
- optional int64 long_value = 4;
- optional double double_value = 5;
- optional string string_value = 6;
- optional string metric_key = 7;
-}
-
-message Issue {
- optional string rule_repository = 1;
- optional string rule_key = 2;
- // Only when issue component is a file. Can also be empty for a file if this is an issue global to the file.
- //TODO To be removed. Use first line of text_range instead
- optional int32 line = 3;
- optional string msg = 4;
- optional Severity severity = 5;
- optional double gap = 6;
- // Only when issue component is a file. Can also be empty for a file if this is an issue global to the file.
- optional TextRange text_range = 7;
- repeated Flow flow = 8;
-}
-
-message IssueLocation {
- optional int32 component_ref = 1;
- // Only when component is a file. Can be empty for a file if this is an issue global to the file.
- optional TextRange text_range = 2;
- optional string msg = 3;
-}
-
-message Flow {
- repeated IssueLocation location = 1;
-}
-
-message Changesets {
- optional int32 component_ref = 1;
- repeated Changeset changeset = 2;
- // if changesetIndexByLine[5] = 2 then it means that changeset[2] is the last one on line 6
- repeated int32 changesetIndexByLine = 3 [packed = true];
-
- message Changeset {
- optional string revision = 1;
- optional string author = 2;
- optional int64 date = 3;
- }
-}
-
-message Duplicate {
- // Will be null when duplicate is in the same file
- optional int32 other_file_ref = 1;
- optional TextRange range = 2;
-}
-
-message Duplication {
- // Origin position in current file
- optional TextRange origin_position = 1;
- repeated Duplicate duplicate = 2;
-}
-
-// Used for cross project duplication
-message CpdTextBlock {
- optional string hash = 1;
- optional int32 start_line = 2;
- optional int32 end_line = 3;
- optional int32 start_token_index = 4;
- optional int32 end_token_index = 5;
-}
-
-// Lines start at 1 and line offsets start at 0
-message TextRange {
- // Should never be null
- optional int32 start_line = 1;
- // End line (inclusive)
- optional int32 end_line = 2;
- // If null it means range starts at the first offset of start line
- optional int32 start_offset = 3;
- // If null it means range ends at the last offset of end line
- optional int32 end_offset = 4;
-}
-
-message Symbol {
- optional TextRange declaration = 1;
- repeated TextRange reference = 2;
-}
-
-// Only FILE component has coverage information, and only executable lines should contains this information.
-// TODO rename it LineCoverage ?
-message Coverage {
- optional int32 line = 1;
-
- // Number of conditions to cover (if set, the value must be greater than 0)
- optional int32 conditions = 2;
- // Is the line has been touched by a unit test ? Returning false means that no test has touched this executable line.
- optional bool ut_hits = 3;
- // Is the line has been touched by a integration test ? Returning false means that no test has touched this executable line.
- optional bool it_hits = 4;
- // Number of conditions covered by unit tests
- optional int32 ut_covered_conditions = 5;
- // Number of conditions covered by integration tests
- optional int32 it_covered_conditions = 6;
- // Number of conditions covered by overall tests
- optional int32 overall_covered_conditions = 7;
-}
-
-// Must be sorted by line and start offset
-// TODO rename it SyntaxHighlightingRule ?
-message SyntaxHighlighting {
- optional TextRange range = 1;
- optional HighlightingType type = 2;
-}
-
-message Test {
- optional string name = 1;
- optional TestStatus status = 2;
- optional int64 duration_in_ms = 3;
- optional string stacktrace = 4;
- optional string msg = 5;
-}
-
-message CoverageDetail {
- optional string test_name = 1;
- repeated CoveredFile covered_file = 2;
-
- message CoveredFile {
- optional int32 file_ref = 1;
- repeated int32 covered_line = 2 [packed = true];
- }
-}
diff --git a/sonar-batch-protocol/src/main/protobuf/constants.proto b/sonar-batch-protocol/src/main/protobuf/constants.proto
deleted file mode 100644
index c0825ffefae..00000000000
--- a/sonar-batch-protocol/src/main/protobuf/constants.proto
+++ /dev/null
@@ -1,79 +0,0 @@
-// SonarQube, open source software quality management tool.
-// Copyright (C) 2008-2015 SonarSource
-// mailto:contact AT sonarsource DOT com
-//
-// SonarQube is free software; you can redistribute it and/or
-// modify it under the terms of the GNU Lesser General Public
-// License as published by the Free Software Foundation; either
-// version 3 of the License, or (at your option) any later version.
-//
-// SonarQube 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
-// Lesser General Public License for more details.
-//
-// You should have received a copy of the GNU Lesser General Public License
-// along with this program; if not, write to the Free Software Foundation,
-// Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
-
-syntax = "proto2";
-
-option java_package = "org.sonar.batch.protocol";
-
-option optimize_for = SPEED;
-
-enum Severity {
- INFO = 0;
- MINOR = 1;
- MAJOR = 2;
- CRITICAL = 3;
- BLOCKER = 4;
-}
-
-enum ComponentType {
- PROJECT = 0;
- MODULE = 1;
- DIRECTORY = 2;
- FILE = 3;
-}
-
-enum MeasureValueType {
- INT = 0;
- LONG = 1;
- DOUBLE = 2;
- BOOLEAN = 3;
- STRING = 4;
-}
-
-// temporary enum during development of computation stack
-enum EventCategory {
- ALERT = 0;
- PROFILE = 1;
-}
-
-enum ComponentLinkType {
- HOME = 0;
- SCM = 1;
- SCM_DEV = 2;
- ISSUE = 3;
- CI = 4;
-}
-
-enum HighlightingType {
- ANNOTATION = 0;
- CONSTANT = 1;
- COMMENT = 2;
- CPP_DOC = 3;
- STRUCTURED_COMMENT = 4;
- KEYWORD = 5;
- HIGHLIGHTING_STRING = 6;
- KEYWORD_LIGHT = 7;
- PREPROCESS_DIRECTIVE = 8;
-}
-
-enum TestStatus {
- OK = 1;
- FAILURE = 2;
- ERROR = 3;
- SKIPPED = 4;
-}
diff --git a/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/input/GlobalRepositoriesTest.java b/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/input/GlobalRepositoriesTest.java
deleted file mode 100644
index fe0643b5c45..00000000000
--- a/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/input/GlobalRepositoriesTest.java
+++ /dev/null
@@ -1,65 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.input;
-
-import org.apache.commons.io.IOUtils;
-import org.junit.Test;
-
-import static net.javacrumbs.jsonunit.assertj.JsonAssert.assertThatJson;
-import static org.assertj.core.api.Assertions.assertThat;
-
-public class GlobalRepositoriesTest {
-
- @Test
- public void to_json() throws Exception {
- GlobalRepositories ref = new GlobalRepositories();
- ref.addMetric(new Metric(1, "ncloc", "INT", "Description", -1, "NCLOC", true, false, 2.0, 1.0, true));
- ref.addGlobalSetting("prop", "value");
- ref.setTimestamp(10);
-
- assertThatJson(ref.toJson())
- .isEqualTo(IOUtils.toString(getClass().getResource("GlobalRepositoriesTest/expected.json")));
- }
-
- @Test
- public void from_json() {
- GlobalRepositories ref = GlobalRepositories
- .fromJson(
- "{timestamp:1,"
- + "metrics:[{id:1,key:ncloc,valueType:DATA,description:Description,direction:-1,name:NCLOC,qualitative:true,userManaged:false,worstValue:2.0,bestValue:1.0,optimizedBestValue:true}],"
- + "globalSettings:{prop:value}}");
-
- assertThat(ref.timestamp()).isEqualTo(1);
- Metric metric = ref.metrics().iterator().next();
- assertThat(metric.id()).isEqualTo(1);
- assertThat(metric.key()).isEqualTo("ncloc");
- assertThat(metric.valueType()).isEqualTo("DATA");
- assertThat(metric.description()).isEqualTo("Description");
- assertThat(metric.direction()).isEqualTo(-1);
- assertThat(metric.name()).isEqualTo("NCLOC");
- assertThat(metric.isQualitative()).isTrue();
- assertThat(metric.isUserManaged()).isFalse();
- assertThat(metric.worstValue()).isEqualTo(2.0);
- assertThat(metric.bestValue()).isEqualTo(1.0);
- assertThat(metric.isOptimizedBestValue()).isTrue();
-
- assertThat(ref.globalSettings()).containsEntry("prop", "value");
- }
-}
diff --git a/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/BatchReportReaderTest.java b/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/BatchReportReaderTest.java
deleted file mode 100644
index 540bfbe4c53..00000000000
--- a/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/BatchReportReaderTest.java
+++ /dev/null
@@ -1,388 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.output;
-
-import com.google.common.collect.Lists;
-import java.io.File;
-import java.io.FileOutputStream;
-import java.io.InputStream;
-import org.apache.commons.io.FileUtils;
-import org.apache.commons.io.IOUtils;
-import org.junit.Before;
-import org.junit.Rule;
-import org.junit.Test;
-import org.junit.rules.TemporaryFolder;
-import org.sonar.batch.protocol.Constants;
-import org.sonar.core.util.CloseableIterator;
-
-import static java.util.Arrays.asList;
-import static java.util.Collections.singletonList;
-import static org.assertj.core.api.Assertions.assertThat;
-
-public class BatchReportReaderTest {
-
- private static int UNKNOWN_COMPONENT_REF = 123;
-
- @Rule
- public TemporaryFolder temp = new TemporaryFolder();
-
- File dir;
-
- BatchReportReader underTest;
-
- @Before
- public void setUp() throws Exception {
- dir = temp.newFolder();
- underTest = new BatchReportReader(dir);
- }
-
- @Test
- public void read_metadata() {
- BatchReportWriter writer = new BatchReportWriter(dir);
- BatchReport.Metadata.Builder metadata = BatchReport.Metadata.newBuilder()
- .setAnalysisDate(15000000L)
- .setProjectKey("PROJECT_A")
- .setRootComponentRef(1)
- .setCrossProjectDuplicationActivated(true);
- writer.writeMetadata(metadata.build());
-
- BatchReport.Metadata readMetadata = underTest.readMetadata();
- assertThat(readMetadata.getAnalysisDate()).isEqualTo(15000000L);
- assertThat(readMetadata.getProjectKey()).isEqualTo("PROJECT_A");
- assertThat(readMetadata.getRootComponentRef()).isEqualTo(1);
- assertThat(readMetadata.getCrossProjectDuplicationActivated()).isTrue();
- }
-
- @Test(expected = IllegalStateException.class)
- public void fail_if_missing_metadata_file() {
- underTest.readMetadata();
- }
-
- @Test
- public void read_components() {
- BatchReportWriter writer = new BatchReportWriter(dir);
- BatchReport.Component.Builder component = BatchReport.Component.newBuilder()
- .setRef(1)
- .setPath("src/main/java/Foo.java");
- writer.writeComponent(component.build());
-
- assertThat(underTest.readComponent(1).getPath()).isEqualTo("src/main/java/Foo.java");
- }
-
- @Test(expected = IllegalStateException.class)
- public void fail_if_missing_file_on_component() {
- underTest.readComponent(UNKNOWN_COMPONENT_REF);
- }
-
- @Test
- public void read_issues() {
- BatchReportWriter writer = new BatchReportWriter(dir);
- BatchReport.Issue issue = BatchReport.Issue.newBuilder()
- .setLine(50)
- .build();
- writer.writeComponentIssues(1, asList(issue));
-
- assertThat(underTest.readComponentIssues(1)).hasSize(1);
- assertThat(underTest.readComponentIssues(200)).isEmpty();
- }
-
- @Test
- public void empty_list_if_no_issue_found() {
- assertThat(underTest.readComponentIssues(UNKNOWN_COMPONENT_REF)).isEmpty();
- }
-
- @Test
- public void read_measures() {
- BatchReportWriter writer = new BatchReportWriter(dir);
- BatchReport.Measure.Builder measure = BatchReport.Measure.newBuilder()
- .setStringValue("value_a");
- writer.writeComponentMeasures(1, asList(measure.build()));
-
- assertThat(underTest.readComponentMeasures(1)).hasSize(1);
- }
-
- @Test
- public void empty_list_if_no_measure_found() {
- assertThat(underTest.readComponentMeasures(UNKNOWN_COMPONENT_REF)).isEmpty();
- }
-
- @Test
- public void read_changesets() {
- BatchReportWriter writer = new BatchReportWriter(dir);
- BatchReport.Changesets.Builder scm = BatchReport.Changesets.newBuilder()
- .setComponentRef(1)
- .addChangeset(BatchReport.Changesets.Changeset.newBuilder().setDate(123_456_789).setAuthor("jack.daniels").setRevision("123-456-789"));
- writer.writeComponentChangesets(scm.build());
-
- assertThat(underTest.readChangesets(1).getChangesetList()).hasSize(1);
- assertThat(underTest.readChangesets(1).getChangeset(0).getDate()).isEqualTo(123_456_789L);
- }
-
- @Test
- public void null_if_no_changeset_found() {
- assertThat(underTest.readChangesets(UNKNOWN_COMPONENT_REF)).isNull();
- }
-
- @Test
- public void read_duplications() {
- BatchReportWriter writer = new BatchReportWriter(dir);
- writer.writeMetadata(BatchReport.Metadata.newBuilder()
- .setRootComponentRef(1).build());
- writer.writeComponent(BatchReport.Component.newBuilder()
- .setRef(1).build());
-
- BatchReport.Duplication duplication = BatchReport.Duplication.newBuilder()
- .setOriginPosition(BatchReport.TextRange.newBuilder()
- .setStartLine(1)
- .setEndLine(5)
- .build())
- .addDuplicate(BatchReport.Duplicate.newBuilder()
- .setOtherFileRef(2)
- .setRange(BatchReport.TextRange.newBuilder()
- .setStartLine(6)
- .setEndLine(10)
- .build())
- .build())
- .build();
- writer.writeComponentDuplications(1, asList(duplication));
-
- BatchReportReader sut = new BatchReportReader(dir);
- assertThat(sut.readComponentDuplications(1)).hasSize(1);
- }
-
- @Test
- public void empty_list_if_no_duplication_found() {
- assertThat(underTest.readComponentDuplications(UNKNOWN_COMPONENT_REF)).isEmpty();
- }
-
- @Test
- public void read_duplication_blocks() {
- BatchReportWriter writer = new BatchReportWriter(dir);
- writer.writeMetadata(BatchReport.Metadata.newBuilder()
- .setRootComponentRef(1).build());
- writer.writeComponent(BatchReport.Component.newBuilder()
- .setRef(1).build());
-
- BatchReport.CpdTextBlock duplicationBlock = BatchReport.CpdTextBlock.newBuilder()
- .setHash("abcdefghijklmnop")
- .setStartLine(1)
- .setEndLine(2)
- .setStartTokenIndex(10)
- .setEndTokenIndex(15)
- .build();
- writer.writeCpdTextBlocks(1, singletonList(duplicationBlock));
-
- BatchReportReader sut = new BatchReportReader(dir);
- assertThat(sut.readCpdTextBlocks(1)).hasSize(1);
- }
-
- @Test
- public void empty_list_if_no_duplication_block_found() {
- assertThat(underTest.readComponentDuplications(UNKNOWN_COMPONENT_REF)).isEmpty();
- }
-
- @Test
- public void read_syntax_highlighting() throws Exception {
- BatchReportWriter writer = new BatchReportWriter(dir);
- writer.writeMetadata(BatchReport.Metadata.newBuilder()
- .setRootComponentRef(1)
- .build());
- writer.writeComponent(BatchReport.Component.newBuilder()
- .setRef(1).build());
-
- writer.writeComponentSyntaxHighlighting(1, asList(
- BatchReport.SyntaxHighlighting.newBuilder()
- .setRange(BatchReport.TextRange.newBuilder()
- .setStartLine(1)
- .setEndLine(10)
- .build())
- .setType(Constants.HighlightingType.ANNOTATION)
- .build()));
-
- try (CloseableIterator<BatchReport.SyntaxHighlighting> it = underTest.readComponentSyntaxHighlighting(1)) {
- BatchReport.SyntaxHighlighting syntaxHighlighting = it.next();
- assertThat(syntaxHighlighting.getRange()).isNotNull();
- assertThat(syntaxHighlighting.getRange().getStartLine()).isEqualTo(1);
- assertThat(syntaxHighlighting.getRange().getEndLine()).isEqualTo(10);
- assertThat(syntaxHighlighting.getType()).isEqualTo(Constants.HighlightingType.ANNOTATION);
- }
- }
-
- @Test
- public void return_empty_if_no_highlighting_found() {
- assertThat(underTest.readComponentSyntaxHighlighting(UNKNOWN_COMPONENT_REF)).isEmpty();
- }
-
- @Test
- public void read_symbols() {
- BatchReportWriter writer = new BatchReportWriter(dir);
- writer.writeMetadata(BatchReport.Metadata.newBuilder()
- .setRootComponentRef(1)
- .build());
- writer.writeComponent(BatchReport.Component.newBuilder()
- .setRef(1).build());
-
- writer.writeComponentSymbols(1, asList(BatchReport.Symbol.newBuilder()
- .setDeclaration(BatchReport.TextRange.newBuilder()
- .setStartLine(1)
- .setStartOffset(3)
- .setEndLine(1)
- .setEndOffset(5)
- .build())
- .addReference(BatchReport.TextRange.newBuilder()
- .setStartLine(10)
- .setStartOffset(15)
- .setEndLine(11)
- .setEndOffset(2)
- .build())
- .build()));
-
- underTest = new BatchReportReader(dir);
- assertThat(underTest.readComponentSymbols(1)).hasSize(1);
- }
-
- @Test
- public void empty_list_if_no_symbol_found() {
- assertThat(underTest.readComponentSymbols(UNKNOWN_COMPONENT_REF)).isEmpty();
- }
-
- @Test
- public void read_coverage() throws Exception {
- BatchReportWriter writer = new BatchReportWriter(dir);
- writer.writeMetadata(BatchReport.Metadata.newBuilder()
- .setRootComponentRef(1)
- .build());
- writer.writeComponent(BatchReport.Component.newBuilder()
- .setRef(1).build());
-
- writer.writeComponentCoverage(1, asList(
- BatchReport.Coverage.newBuilder()
- .setLine(1)
- .setConditions(1)
- .setUtHits(true)
- .setItHits(false)
- .setUtCoveredConditions(1)
- .setItCoveredConditions(1)
- .setOverallCoveredConditions(1)
- .build(),
- BatchReport.Coverage.newBuilder()
- .setLine(2)
- .setConditions(5)
- .setUtHits(false)
- .setItHits(false)
- .setUtCoveredConditions(4)
- .setItCoveredConditions(5)
- .setOverallCoveredConditions(5)
- .build()));
-
- underTest = new BatchReportReader(dir);
- try (CloseableIterator<BatchReport.Coverage> it = new BatchReportReader(dir).readComponentCoverage(1)) {
- BatchReport.Coverage coverage = it.next();
- assertThat(coverage.getLine()).isEqualTo(1);
- assertThat(coverage.getConditions()).isEqualTo(1);
- assertThat(coverage.getUtHits()).isTrue();
- assertThat(coverage.getItHits()).isFalse();
- assertThat(coverage.getUtCoveredConditions()).isEqualTo(1);
- assertThat(coverage.getItCoveredConditions()).isEqualTo(1);
- assertThat(coverage.getOverallCoveredConditions()).isEqualTo(1);
- }
- }
-
- @Test
- public void return_empty_iterator_if_no_coverage_found() {
- assertThat(underTest.readComponentCoverage(UNKNOWN_COMPONENT_REF)).isEmpty();
- }
-
- @Test
- public void read_source_lines() throws Exception {
- BatchReportWriter writer = new BatchReportWriter(dir);
- File file = writer.getFileStructure().fileFor(FileStructure.Domain.SOURCE, 1);
- FileUtils.writeLines(file, Lists.newArrayList("line1", "line2"));
-
- File sourceFile = new BatchReportReader(dir).readFileSource(1);
- assertThat(sourceFile).isEqualTo(file);
- }
-
- @Test
- public void read_tests() throws Exception {
- BatchReportWriter writer = new BatchReportWriter(dir);
- writer.writeTests(1, asList(
- BatchReport.Test.newBuilder()
- .setDurationInMs(60_000)
- .setStacktrace("stacktrace")
- .setMsg("message")
- .setStatus(Constants.TestStatus.OK)
- .build()));
-
- try (InputStream inputStream = FileUtils.openInputStream(underTest.readTests(1))) {
- BatchReport.Test testResult = BatchReport.Test.PARSER.parseDelimitedFrom(inputStream);
- assertThat(testResult.getDurationInMs()).isEqualTo(60_000);
- assertThat(testResult.getStacktrace()).isEqualTo("stacktrace");
- assertThat(testResult.getMsg()).isEqualTo("message");
- assertThat(testResult.getStatus()).isEqualTo(Constants.TestStatus.OK);
- }
- }
-
- @Test
- public void null_if_no_test_found() {
- assertThat(underTest.readTests(UNKNOWN_COMPONENT_REF)).isNull();
- }
-
- @Test
- public void read_coverage_details() throws Exception {
- BatchReportWriter writer = new BatchReportWriter(dir);
- writer.writeCoverageDetails(1, asList(
- BatchReport.CoverageDetail.newBuilder()
- .setTestName("test-name")
- .addCoveredFile(BatchReport.CoverageDetail.CoveredFile.newBuilder()
- .addAllCoveredLine(asList(1, 2, 3, 5, 7))
- .setFileRef(2))
- .build()));
-
- try (InputStream inputStream = FileUtils.openInputStream(underTest.readCoverageDetails(1))) {
- BatchReport.CoverageDetail coverageDetail = BatchReport.CoverageDetail.PARSER.parseDelimitedFrom(inputStream);
- assertThat(coverageDetail.getTestName()).isEqualTo("test-name");
- assertThat(coverageDetail.getCoveredFile(0).getFileRef()).isEqualTo(2);
- assertThat(coverageDetail.getCoveredFile(0).getCoveredLineList()).containsExactly(1, 2, 3, 5, 7);
- }
- }
-
- @Test
- public void null_if_no_coverage_detail_found() {
- assertThat(underTest.readCoverageDetails(UNKNOWN_COMPONENT_REF)).isNull();
- }
-
- @Test
- public void read_file_source() throws Exception {
- BatchReportWriter writer = new BatchReportWriter(dir);
- try (FileOutputStream outputStream = new FileOutputStream(writer.getSourceFile(1))) {
- IOUtils.write("line1\nline2", outputStream);
- }
-
- try (InputStream inputStream = FileUtils.openInputStream(underTest.readFileSource(1))) {
- assertThat(IOUtils.readLines(inputStream)).containsOnly("line1", "line2");
- }
- }
-
- @Test
- public void return_null_when_no_file_source() throws Exception {
- assertThat(underTest.readFileSource(UNKNOWN_COMPONENT_REF)).isNull();
- }
-}
diff --git a/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/BatchReportWriterTest.java b/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/BatchReportWriterTest.java
deleted file mode 100644
index fc594c00068..00000000000
--- a/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/BatchReportWriterTest.java
+++ /dev/null
@@ -1,306 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.output;
-
-import com.google.common.collect.Iterators;
-import java.io.File;
-import org.apache.commons.io.FileUtils;
-import org.junit.Before;
-import org.junit.Rule;
-import org.junit.Test;
-import org.junit.rules.TemporaryFolder;
-import org.sonar.batch.protocol.Constants;
-import org.sonar.core.util.CloseableIterator;
-import org.sonar.core.util.Protobuf;
-
-import static java.util.Arrays.asList;
-import static org.assertj.core.api.Assertions.assertThat;
-
-public class BatchReportWriterTest {
-
- @Rule
- public TemporaryFolder temp = new TemporaryFolder();
- File dir;
- BatchReportWriter underTest;
-
- @Before
- public void setUp() throws Exception {
- dir = temp.newFolder();
- underTest = new BatchReportWriter(dir);
- }
-
- @Test
- public void create_dir_if_does_not_exist() {
- FileUtils.deleteQuietly(dir);
- underTest = new BatchReportWriter(dir);
-
- assertThat(dir).isDirectory().exists();
- }
-
- @Test
- public void write_metadata() {
- BatchReport.Metadata.Builder metadata = BatchReport.Metadata.newBuilder()
- .setAnalysisDate(15000000L)
- .setProjectKey("PROJECT_A")
- .setRootComponentRef(1);
- underTest.writeMetadata(metadata.build());
-
- BatchReport.Metadata read = Protobuf.read(underTest.getFileStructure().metadataFile(), BatchReport.Metadata.PARSER);
- assertThat(read.getAnalysisDate()).isEqualTo(15000000L);
- assertThat(read.getProjectKey()).isEqualTo("PROJECT_A");
- assertThat(read.getRootComponentRef()).isEqualTo(1);
- }
-
- @Test
- public void write_component() {
- // no data yet
- assertThat(underTest.hasComponentData(FileStructure.Domain.COMPONENT, 1)).isFalse();
-
- // write data
- BatchReport.Component.Builder component = BatchReport.Component.newBuilder()
- .setRef(1)
- .setLanguage("java")
- .setPath("src/Foo.java")
- .setType(Constants.ComponentType.FILE)
- .setIsTest(false)
- .addChildRef(5)
- .addChildRef(42);
- underTest.writeComponent(component.build());
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.COMPONENT, 1)).isTrue();
- File file = underTest.getFileStructure().fileFor(FileStructure.Domain.COMPONENT, 1);
- assertThat(file).exists().isFile();
- BatchReport.Component read = Protobuf.read(file, BatchReport.Component.PARSER);
- assertThat(read.getRef()).isEqualTo(1);
- assertThat(read.getChildRefList()).containsOnly(5, 42);
- assertThat(read.hasName()).isFalse();
- assertThat(read.getIsTest()).isFalse();
- }
-
- @Test
- public void write_issues() {
- // no data yet
- assertThat(underTest.hasComponentData(FileStructure.Domain.ISSUES, 1)).isFalse();
-
- // write data
- BatchReport.Issue issue = BatchReport.Issue.newBuilder()
- .setLine(50)
- .setMsg("the message")
- .build();
-
- underTest.writeComponentIssues(1, asList(issue));
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.ISSUES, 1)).isTrue();
- File file = underTest.getFileStructure().fileFor(FileStructure.Domain.ISSUES, 1);
- assertThat(file).exists().isFile();
- try (CloseableIterator<BatchReport.Issue> read = Protobuf.readStream(file, BatchReport.Issue.PARSER)) {
- assertThat(Iterators.size(read)).isEqualTo(1);
- }
- }
-
- @Test
- public void write_measures() {
- assertThat(underTest.hasComponentData(FileStructure.Domain.MEASURES, 1)).isFalse();
-
- BatchReport.Measure measure = BatchReport.Measure.newBuilder()
- .setStringValue("text-value")
- .setDoubleValue(2.5d)
- .setValueType(Constants.MeasureValueType.DOUBLE)
- .build();
-
- underTest.writeComponentMeasures(1, asList(measure));
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.MEASURES, 1)).isTrue();
- File file = underTest.getFileStructure().fileFor(FileStructure.Domain.MEASURES, 1);
- assertThat(file).exists().isFile();
- try (CloseableIterator<BatchReport.Measure> read = Protobuf.readStream(file, BatchReport.Measure.PARSER)) {
- assertThat(Iterators.size(read)).isEqualTo(1);
- }
- }
-
- @Test
- public void write_scm() {
- assertThat(underTest.hasComponentData(FileStructure.Domain.CHANGESETS, 1)).isFalse();
-
- BatchReport.Changesets scm = BatchReport.Changesets.newBuilder()
- .setComponentRef(1)
- .addChangesetIndexByLine(0)
- .addChangeset(BatchReport.Changesets.Changeset.newBuilder()
- .setRevision("123-456-789")
- .setAuthor("author")
- .setDate(123_456_789L))
- .build();
-
- underTest.writeComponentChangesets(scm);
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.CHANGESETS, 1)).isTrue();
- File file = underTest.getFileStructure().fileFor(FileStructure.Domain.CHANGESETS, 1);
- assertThat(file).exists().isFile();
- BatchReport.Changesets read = Protobuf.read(file, BatchReport.Changesets.PARSER);
- assertThat(read.getComponentRef()).isEqualTo(1);
- assertThat(read.getChangesetCount()).isEqualTo(1);
- assertThat(read.getChangesetList()).hasSize(1);
- assertThat(read.getChangeset(0).getDate()).isEqualTo(123_456_789L);
- }
-
- @Test
- public void write_duplications() {
- assertThat(underTest.hasComponentData(FileStructure.Domain.DUPLICATIONS, 1)).isFalse();
-
- BatchReport.Duplication duplication = BatchReport.Duplication.newBuilder()
- .setOriginPosition(BatchReport.TextRange.newBuilder()
- .setStartLine(1)
- .setEndLine(5)
- .build())
- .addDuplicate(BatchReport.Duplicate.newBuilder()
- .setOtherFileRef(2)
- .setRange(BatchReport.TextRange.newBuilder()
- .setStartLine(6)
- .setEndLine(10)
- .build())
- .build())
- .build();
- underTest.writeComponentDuplications(1, asList(duplication));
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.DUPLICATIONS, 1)).isTrue();
- File file = underTest.getFileStructure().fileFor(FileStructure.Domain.DUPLICATIONS, 1);
- assertThat(file).exists().isFile();
- try (CloseableIterator<BatchReport.Duplication> duplications = Protobuf.readStream(file, BatchReport.Duplication.PARSER)) {
- BatchReport.Duplication dup = duplications.next();
- assertThat(dup.getOriginPosition()).isNotNull();
- assertThat(dup.getDuplicateList()).hasSize(1);
- }
- }
-
- @Test
- public void write_duplication_blocks() {
- assertThat(underTest.hasComponentData(FileStructure.Domain.CPD_TEXT_BLOCKS, 1)).isFalse();
-
- BatchReport.CpdTextBlock duplicationBlock = BatchReport.CpdTextBlock.newBuilder()
- .setHash("abcdefghijklmnop")
- .setStartLine(1)
- .setEndLine(2)
- .setStartTokenIndex(10)
- .setEndTokenIndex(15)
- .build();
- underTest.writeCpdTextBlocks(1, asList(duplicationBlock));
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.CPD_TEXT_BLOCKS, 1)).isTrue();
- File file = underTest.getFileStructure().fileFor(FileStructure.Domain.CPD_TEXT_BLOCKS, 1);
- assertThat(file).exists().isFile();
- try (CloseableIterator<BatchReport.CpdTextBlock> duplicationBlocks = Protobuf.readStream(file, BatchReport.CpdTextBlock.parser())) {
- BatchReport.CpdTextBlock duplicationBlockResult = duplicationBlocks.next();
- assertThat(duplicationBlockResult.getHash()).isEqualTo("abcdefghijklmnop");
- assertThat(duplicationBlockResult.getStartLine()).isEqualTo(1);
- assertThat(duplicationBlockResult.getEndLine()).isEqualTo(2);
- assertThat(duplicationBlockResult.getStartTokenIndex()).isEqualTo(10);
- assertThat(duplicationBlockResult.getEndTokenIndex()).isEqualTo(15);
- }
- }
-
- @Test
- public void write_symbols() {
- // no data yet
- assertThat(underTest.hasComponentData(FileStructure.Domain.SYMBOLS, 1)).isFalse();
-
- // write data
- BatchReport.Symbol symbol = BatchReport.Symbol.newBuilder()
- .setDeclaration(BatchReport.TextRange.newBuilder()
- .setStartLine(1)
- .setStartOffset(3)
- .setEndLine(1)
- .setEndOffset(5)
- .build())
- .addReference(BatchReport.TextRange.newBuilder()
- .setStartLine(10)
- .setStartOffset(15)
- .setEndLine(11)
- .setEndOffset(2)
- .build())
- .build();
-
- underTest.writeComponentSymbols(1, asList(symbol));
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.SYMBOLS, 1)).isTrue();
-
- File file = underTest.getFileStructure().fileFor(FileStructure.Domain.SYMBOLS, 1);
- assertThat(file).exists().isFile();
- try (CloseableIterator<BatchReport.Symbol> read = Protobuf.readStream(file, BatchReport.Symbol.PARSER)) {
- assertThat(read).hasSize(1);
- }
- }
-
- @Test
- public void write_syntax_highlighting() {
- // no data yet
- assertThat(underTest.hasComponentData(FileStructure.Domain.SYNTAX_HIGHLIGHTINGS, 1)).isFalse();
-
- underTest.writeComponentSyntaxHighlighting(1, asList(
- BatchReport.SyntaxHighlighting.newBuilder()
- .setRange(BatchReport.TextRange.newBuilder()
- .setStartLine(1)
- .setEndLine(1)
- .build())
- .setType(Constants.HighlightingType.ANNOTATION)
- .build()));
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.SYNTAX_HIGHLIGHTINGS, 1)).isTrue();
- }
-
- @Test
- public void write_coverage() {
- // no data yet
- assertThat(underTest.hasComponentData(FileStructure.Domain.COVERAGES, 1)).isFalse();
-
- underTest.writeComponentCoverage(1, asList(
- BatchReport.Coverage.newBuilder()
- .setLine(1)
- .setConditions(1)
- .setUtHits(true)
- .setItHits(false)
- .setUtCoveredConditions(1)
- .setItCoveredConditions(1)
- .setOverallCoveredConditions(1)
- .build()));
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.COVERAGES, 1)).isTrue();
- }
-
- @Test
- public void write_tests() {
- assertThat(underTest.hasComponentData(FileStructure.Domain.TESTS, 1)).isFalse();
-
- underTest.writeTests(1, asList(
- BatchReport.Test.getDefaultInstance()));
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.TESTS, 1)).isTrue();
-
- }
-
- @Test
- public void write_coverage_details() {
- assertThat(underTest.hasComponentData(FileStructure.Domain.COVERAGE_DETAILS, 1)).isFalse();
-
- underTest.writeCoverageDetails(1, asList(
- BatchReport.CoverageDetail.getDefaultInstance()));
-
- assertThat(underTest.hasComponentData(FileStructure.Domain.COVERAGE_DETAILS, 1)).isTrue();
- }
-}
diff --git a/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/FileStructureTest.java b/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/FileStructureTest.java
deleted file mode 100644
index 1692263a17c..00000000000
--- a/sonar-batch-protocol/src/test/java/org/sonar/batch/protocol/output/FileStructureTest.java
+++ /dev/null
@@ -1,74 +0,0 @@
-/*
- * SonarQube
- * Copyright (C) 2009-2016 SonarSource SA
- * mailto:contact AT sonarsource DOT com
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser 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
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write to the Free Software Foundation,
- * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
- */
-package org.sonar.batch.protocol.output;
-
-import org.apache.commons.io.FileUtils;
-import org.junit.Rule;
-import org.junit.Test;
-import org.junit.rules.TemporaryFolder;
-
-import java.io.File;
-
-import static org.assertj.core.api.Assertions.assertThat;
-import static org.junit.Assert.fail;
-
-public class FileStructureTest {
-
- @Rule
- public TemporaryFolder temp = new TemporaryFolder();
-
- @Test
- public void fail_if_dir_does_not_exist() throws Exception {
- File dir = temp.newFolder();
- FileUtils.deleteQuietly(dir);
- try {
- new FileStructure(dir);
- fail();
- } catch (IllegalArgumentException e) {
- assertThat(e).hasMessageContaining("Directory of analysis report does not exist");
- }
- }
-
- @Test
- public void fail_if_invalid_dir() throws Exception {
- // not a dir but a file
- File dir = temp.newFile();
- try {
- new FileStructure(dir);
- fail();
- } catch (IllegalArgumentException e) {
- assertThat(e).hasMessageContaining("Directory of analysis report does not exist");
- }
- }
-
- @Test
- public void locate_files() throws Exception {
- File dir = temp.newFolder();
- FileUtils.write(new File(dir, "metadata.pb"), "metadata content");
- FileUtils.write(new File(dir, "issues-3.pb"), "issues of component 3");
- FileUtils.write(new File(dir, "component-42.pb"), "details of component 42");
-
- FileStructure structure = new FileStructure(dir);
- assertThat(structure.metadataFile()).exists().isFile();
- assertThat(structure.fileFor(FileStructure.Domain.COMPONENT, 42)).exists().isFile();
- assertThat(structure.fileFor(FileStructure.Domain.ISSUES, 3)).exists().isFile();
- assertThat(structure.fileFor(FileStructure.Domain.ISSUES, 42)).doesNotExist();
- }
-}
diff --git a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/FileStreamTest/file.txt b/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/FileStreamTest/file.txt
deleted file mode 100644
index 83db48f84ec..00000000000
--- a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/FileStreamTest/file.txt
+++ /dev/null
@@ -1,3 +0,0 @@
-line1
-line2
-line3
diff --git a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/GlobalRepositoriesTest/expected.json b/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/GlobalRepositoriesTest/expected.json
deleted file mode 100644
index de38ae0cb18..00000000000
--- a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/GlobalRepositoriesTest/expected.json
+++ /dev/null
@@ -1,21 +0,0 @@
-{
- "timestamp": 10,
- "metrics": [
- {
- "id": 1,
- "key": "ncloc",
- "valueType": "INT",
- "description": "Description",
- "direction": -1,
- "name": "NCLOC",
- "qualitative": true,
- "userManaged": false,
- "worstValue": 2.0,
- "bestValue": 1.0,
- "optimizedBestValue": true
- }
- ],
- "globalSettings": {
- "prop": "value"
- }
-}
diff --git a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/ProjectRepositoriesTest/testToJson.json b/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/ProjectRepositoriesTest/testToJson.json
deleted file mode 100644
index ba7489143a6..00000000000
--- a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/ProjectRepositoriesTest/testToJson.json
+++ /dev/null
@@ -1,23 +0,0 @@
-{
- "timestamp": 10,
- "settingsByModule": {
- "foo": {
- "prop1": "value1",
- "prop2": "value2",
- "prop": "value"
- }
- },
- "fileDataByModuleAndPath": {
- "foo": {
- "src/main/java/Foo.java": {
- "hash": "xyz",
- "needBlame": true
- },
- "src/main/java/Foo2.java": {
- "hash": "xyz",
- "needBlame": false
- }
- }
- },
- "lastAnalysisDate": "2014-05-18T15:50:45+0100"
-}
diff --git a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/RulesSearchTest/empty.json b/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/RulesSearchTest/empty.json
deleted file mode 100644
index 055fe8b8d63..00000000000
--- a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/RulesSearchTest/empty.json
+++ /dev/null
@@ -1 +0,0 @@
-{"total":3225,"p":30,"ps":500,"rules":[]} \ No newline at end of file
diff --git a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/RulesSearchTest/expected.json b/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/RulesSearchTest/expected.json
deleted file mode 100644
index 89350a7e331..00000000000
--- a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/input/RulesSearchTest/expected.json
+++ /dev/null
@@ -1 +0,0 @@
-{"total":290,"p":1,"ps":2,"rules":[{"key":"squid:S1194","internalKey":"S1194","repo":"squid","name":"\"java.lang.Error\" should not be extended","severity":"MAJOR","lang":"java"},{"key":"squid:ObjectFinalizeOverridenCallsSuperFinalizeCheck","internalKey":"ObjectFinalizeOverridenCallsSuperFinalizeCheck","repo":"squid","name":"super.finalize() should be called at the end of Object.finalize() implementations","severity":"BLOCKER","lang":"java"}]} \ No newline at end of file
diff --git a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/output/component/ReportComponentsTest/expected.json b/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/output/component/ReportComponentsTest/expected.json
deleted file mode 100644
index 581bbc5ea23..00000000000
--- a/sonar-batch-protocol/src/test/resources/org/sonar/batch/protocol/output/component/ReportComponentsTest/expected.json
+++ /dev/null
@@ -1,43 +0,0 @@
-{
- "analysisDate": "2012-12-12T00:00:00+0100",
- "root": {
- "batchId": 1,
- "id": 11,
- "snapshotId": 111,
- "name": "Root project",
- "type": "PRJ",
- "children": [
- {
- "batchId": 2,
- "id": 22,
- "snapshotId": 222,
- "path": "module1",
- "name": "Module",
- "type": "MOD",
- "children": [
- {
- "batchId": 3,
- "id": 33,
- "snapshotId": 333,
- "path": "src",
- "name": "src",
- "type": "DIR",
- "children": [
- {
- "batchId": 4,
- "id": 44,
- "snapshotId": 444,
- "path": "Foo.java",
- "name": "Foo.java",
- "type": "FIL",
- "languageKey": "java",
- "isTest": true,
- "children": []
- }
- ]
- }
- ]
- }
- ]
- }
-} \ No newline at end of file