From cf4106ffa318702ea4bf9cf62a3ae4a17261371c Mon Sep 17 00:00:00 2001 From: Julien Lancelot <julien.lancelot@sonarsource.com> Date: Tue, 31 Mar 2015 15:25:18 +0200 Subject: SONAR-6338 Stream reading / writing coverage message --- .../sonar/batch/protocol/output/BatchReport.java | 1426 +++++--------------- .../org/sonar/batch/protocol/ProtobufUtil.java | 72 +- .../batch/protocol/output/BatchReportReader.java | 8 +- .../batch/protocol/output/BatchReportWriter.java | 17 +- .../src/main/protobuf/batch_report.proto | 25 +- .../protocol/output/BatchReportReaderTest.java | 57 +- .../protocol/output/BatchReportWriterTest.java | 60 +- 7 files changed, 476 insertions(+), 1189 deletions(-) (limited to 'sonar-batch-protocol') diff --git a/sonar-batch-protocol/src/main/gen-java/org/sonar/batch/protocol/output/BatchReport.java b/sonar-batch-protocol/src/main/gen-java/org/sonar/batch/protocol/output/BatchReport.java index 9d49b73741c..f065690b54b 100644 --- a/sonar-batch-protocol/src/main/gen-java/org/sonar/batch/protocol/output/BatchReport.java +++ b/sonar-batch-protocol/src/main/gen-java/org/sonar/batch/protocol/output/BatchReport.java @@ -19464,174 +19464,82 @@ public final class BatchReport { com.google.protobuf.MessageOrBuilder { /** - * <code>optional int32 file_ref = 1;</code> - * - * <pre> - * Only FILE component has coverage information - * </pre> + * <code>optional int32 line = 1;</code> */ - boolean hasFileRef(); + boolean hasLine(); /** - * <code>optional int32 file_ref = 1;</code> - * - * <pre> - * Only FILE component has coverage information - * </pre> + * <code>optional int32 line = 1;</code> */ - int getFileRef(); + int getLine(); /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> - * - * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover - * </pre> - */ - java.util.List<java.lang.Integer> getConditionsByLineList(); - /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> + * <code>optional int32 conditions = 2;</code> * * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover + * Number of conditions to cover (never 0) * </pre> */ - int getConditionsByLineCount(); + boolean hasConditions(); /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> + * <code>optional int32 conditions = 2;</code> * * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover + * Number of conditions to cover (never 0) * </pre> */ - int getConditionsByLine(int index); + int getConditions(); /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> - */ - java.util.List<java.lang.Boolean> getUtHitsByLineList(); - /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> + * <code>optional bool ut_hits = 3;</code> */ - int getUtHitsByLineCount(); + boolean hasUtHits(); /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> + * <code>optional bool ut_hits = 3;</code> */ - boolean getUtHitsByLine(int index); + boolean getUtHits(); /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> - */ - java.util.List<java.lang.Boolean> getItHitsByLineList(); - /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> + * <code>optional bool it_hits = 4;</code> */ - int getItHitsByLineCount(); + boolean hasItHits(); /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> + * <code>optional bool it_hits = 4;</code> */ - boolean getItHitsByLine(int index); + boolean getItHits(); /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> - */ - java.util.List<java.lang.Integer> getUtCoveredConditionsByLineList(); - /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> + * <code>optional int32 ut_covered_conditions = 5;</code> */ - int getUtCoveredConditionsByLineCount(); + boolean hasUtCoveredConditions(); /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> + * <code>optional int32 ut_covered_conditions = 5;</code> */ - int getUtCoveredConditionsByLine(int index); + int getUtCoveredConditions(); /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> - */ - java.util.List<java.lang.Integer> getItCoveredConditionsByLineList(); - /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> + * <code>optional int32 it_covered_conditions = 6;</code> */ - int getItCoveredConditionsByLineCount(); + boolean hasItCoveredConditions(); /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> + * <code>optional int32 it_covered_conditions = 6;</code> */ - int getItCoveredConditionsByLine(int index); + int getItCoveredConditions(); /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> - */ - java.util.List<java.lang.Integer> getOverallCoveredConditionsByLineList(); - /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> + * <code>optional int32 overall_covered_conditions = 7;</code> */ - int getOverallCoveredConditionsByLineCount(); + boolean hasOverallCoveredConditions(); /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> + * <code>optional int32 overall_covered_conditions = 7;</code> */ - int getOverallCoveredConditionsByLine(int index); + int getOverallCoveredConditions(); } /** * Protobuf type {@code Coverage} + * + * <pre> + * Only FILE component has coverage information + * </pre> */ public static final class Coverage extends com.google.protobuf.GeneratedMessage implements @@ -19684,133 +19592,37 @@ public final class BatchReport { } case 8: { bitField0_ |= 0x00000001; - fileRef_ = input.readInt32(); + line_ = input.readInt32(); break; } case 16: { - if (!((mutable_bitField0_ & 0x00000002) == 0x00000002)) { - conditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(); - mutable_bitField0_ |= 0x00000002; - } - conditionsByLine_.add(input.readInt32()); - break; - } - case 18: { - int length = input.readRawVarint32(); - int limit = input.pushLimit(length); - if (!((mutable_bitField0_ & 0x00000002) == 0x00000002) && input.getBytesUntilLimit() > 0) { - conditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(); - mutable_bitField0_ |= 0x00000002; - } - while (input.getBytesUntilLimit() > 0) { - conditionsByLine_.add(input.readInt32()); - } - input.popLimit(limit); + bitField0_ |= 0x00000002; + conditions_ = input.readInt32(); break; } case 24: { - if (!((mutable_bitField0_ & 0x00000004) == 0x00000004)) { - utHitsByLine_ = new java.util.ArrayList<java.lang.Boolean>(); - mutable_bitField0_ |= 0x00000004; - } - utHitsByLine_.add(input.readBool()); - break; - } - case 26: { - int length = input.readRawVarint32(); - int limit = input.pushLimit(length); - if (!((mutable_bitField0_ & 0x00000004) == 0x00000004) && input.getBytesUntilLimit() > 0) { - utHitsByLine_ = new java.util.ArrayList<java.lang.Boolean>(); - mutable_bitField0_ |= 0x00000004; - } - while (input.getBytesUntilLimit() > 0) { - utHitsByLine_.add(input.readBool()); - } - input.popLimit(limit); + bitField0_ |= 0x00000004; + utHits_ = input.readBool(); break; } case 32: { - if (!((mutable_bitField0_ & 0x00000008) == 0x00000008)) { - itHitsByLine_ = new java.util.ArrayList<java.lang.Boolean>(); - mutable_bitField0_ |= 0x00000008; - } - itHitsByLine_.add(input.readBool()); - break; - } - case 34: { - int length = input.readRawVarint32(); - int limit = input.pushLimit(length); - if (!((mutable_bitField0_ & 0x00000008) == 0x00000008) && input.getBytesUntilLimit() > 0) { - itHitsByLine_ = new java.util.ArrayList<java.lang.Boolean>(); - mutable_bitField0_ |= 0x00000008; - } - while (input.getBytesUntilLimit() > 0) { - itHitsByLine_.add(input.readBool()); - } - input.popLimit(limit); + bitField0_ |= 0x00000008; + itHits_ = input.readBool(); break; } case 40: { - if (!((mutable_bitField0_ & 0x00000010) == 0x00000010)) { - utCoveredConditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(); - mutable_bitField0_ |= 0x00000010; - } - utCoveredConditionsByLine_.add(input.readInt32()); - break; - } - case 42: { - int length = input.readRawVarint32(); - int limit = input.pushLimit(length); - if (!((mutable_bitField0_ & 0x00000010) == 0x00000010) && input.getBytesUntilLimit() > 0) { - utCoveredConditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(); - mutable_bitField0_ |= 0x00000010; - } - while (input.getBytesUntilLimit() > 0) { - utCoveredConditionsByLine_.add(input.readInt32()); - } - input.popLimit(limit); + bitField0_ |= 0x00000010; + utCoveredConditions_ = input.readInt32(); break; } case 48: { - if (!((mutable_bitField0_ & 0x00000020) == 0x00000020)) { - itCoveredConditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(); - mutable_bitField0_ |= 0x00000020; - } - itCoveredConditionsByLine_.add(input.readInt32()); - break; - } - case 50: { - int length = input.readRawVarint32(); - int limit = input.pushLimit(length); - if (!((mutable_bitField0_ & 0x00000020) == 0x00000020) && input.getBytesUntilLimit() > 0) { - itCoveredConditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(); - mutable_bitField0_ |= 0x00000020; - } - while (input.getBytesUntilLimit() > 0) { - itCoveredConditionsByLine_.add(input.readInt32()); - } - input.popLimit(limit); + bitField0_ |= 0x00000020; + itCoveredConditions_ = input.readInt32(); break; } case 56: { - if (!((mutable_bitField0_ & 0x00000040) == 0x00000040)) { - overallCoveredConditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(); - mutable_bitField0_ |= 0x00000040; - } - overallCoveredConditionsByLine_.add(input.readInt32()); - break; - } - case 58: { - int length = input.readRawVarint32(); - int limit = input.pushLimit(length); - if (!((mutable_bitField0_ & 0x00000040) == 0x00000040) && input.getBytesUntilLimit() > 0) { - overallCoveredConditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(); - mutable_bitField0_ |= 0x00000040; - } - while (input.getBytesUntilLimit() > 0) { - overallCoveredConditionsByLine_.add(input.readInt32()); - } - input.popLimit(limit); + bitField0_ |= 0x00000040; + overallCoveredConditions_ = input.readInt32(); break; } } @@ -19821,24 +19633,6 @@ public final class BatchReport { throw new com.google.protobuf.InvalidProtocolBufferException( e.getMessage()).setUnfinishedMessage(this); } finally { - if (((mutable_bitField0_ & 0x00000002) == 0x00000002)) { - conditionsByLine_ = java.util.Collections.unmodifiableList(conditionsByLine_); - } - if (((mutable_bitField0_ & 0x00000004) == 0x00000004)) { - utHitsByLine_ = java.util.Collections.unmodifiableList(utHitsByLine_); - } - if (((mutable_bitField0_ & 0x00000008) == 0x00000008)) { - itHitsByLine_ = java.util.Collections.unmodifiableList(itHitsByLine_); - } - if (((mutable_bitField0_ & 0x00000010) == 0x00000010)) { - utCoveredConditionsByLine_ = java.util.Collections.unmodifiableList(utCoveredConditionsByLine_); - } - if (((mutable_bitField0_ & 0x00000020) == 0x00000020)) { - itCoveredConditionsByLine_ = java.util.Collections.unmodifiableList(itCoveredConditionsByLine_); - } - if (((mutable_bitField0_ & 0x00000040) == 0x00000040)) { - overallCoveredConditionsByLine_ = java.util.Collections.unmodifiableList(overallCoveredConditionsByLine_); - } this.unknownFields = unknownFields.build(); makeExtensionsImmutable(); } @@ -19871,247 +19665,127 @@ public final class BatchReport { } private int bitField0_; - public static final int FILE_REF_FIELD_NUMBER = 1; - private int fileRef_; + public static final int LINE_FIELD_NUMBER = 1; + private int line_; /** - * <code>optional int32 file_ref = 1;</code> - * - * <pre> - * Only FILE component has coverage information - * </pre> + * <code>optional int32 line = 1;</code> */ - public boolean hasFileRef() { + public boolean hasLine() { return ((bitField0_ & 0x00000001) == 0x00000001); } /** - * <code>optional int32 file_ref = 1;</code> - * - * <pre> - * Only FILE component has coverage information - * </pre> + * <code>optional int32 line = 1;</code> */ - public int getFileRef() { - return fileRef_; + public int getLine() { + return line_; } - public static final int CONDITIONS_BY_LINE_FIELD_NUMBER = 2; - private java.util.List<java.lang.Integer> conditionsByLine_; - /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> - * - * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover - * </pre> - */ - public java.util.List<java.lang.Integer> - getConditionsByLineList() { - return conditionsByLine_; - } + public static final int CONDITIONS_FIELD_NUMBER = 2; + private int conditions_; /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> + * <code>optional int32 conditions = 2;</code> * * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover + * Number of conditions to cover (never 0) * </pre> */ - public int getConditionsByLineCount() { - return conditionsByLine_.size(); + public boolean hasConditions() { + return ((bitField0_ & 0x00000002) == 0x00000002); } /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> + * <code>optional int32 conditions = 2;</code> * * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover + * Number of conditions to cover (never 0) * </pre> */ - public int getConditionsByLine(int index) { - return conditionsByLine_.get(index); + public int getConditions() { + return conditions_; } - private int conditionsByLineMemoizedSerializedSize = -1; - public static final int UT_HITS_BY_LINE_FIELD_NUMBER = 3; - private java.util.List<java.lang.Boolean> utHitsByLine_; - /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> - */ - public java.util.List<java.lang.Boolean> - getUtHitsByLineList() { - return utHitsByLine_; - } + public static final int UT_HITS_FIELD_NUMBER = 3; + private boolean utHits_; /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> + * <code>optional bool ut_hits = 3;</code> */ - public int getUtHitsByLineCount() { - return utHitsByLine_.size(); + public boolean hasUtHits() { + return ((bitField0_ & 0x00000004) == 0x00000004); } /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> + * <code>optional bool ut_hits = 3;</code> */ - public boolean getUtHitsByLine(int index) { - return utHitsByLine_.get(index); + public boolean getUtHits() { + return utHits_; } - private int utHitsByLineMemoizedSerializedSize = -1; - public static final int IT_HITS_BY_LINE_FIELD_NUMBER = 4; - private java.util.List<java.lang.Boolean> itHitsByLine_; - /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> - */ - public java.util.List<java.lang.Boolean> - getItHitsByLineList() { - return itHitsByLine_; - } + public static final int IT_HITS_FIELD_NUMBER = 4; + private boolean itHits_; /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> + * <code>optional bool it_hits = 4;</code> */ - public int getItHitsByLineCount() { - return itHitsByLine_.size(); + public boolean hasItHits() { + return ((bitField0_ & 0x00000008) == 0x00000008); } /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> + * <code>optional bool it_hits = 4;</code> */ - public boolean getItHitsByLine(int index) { - return itHitsByLine_.get(index); + public boolean getItHits() { + return itHits_; } - private int itHitsByLineMemoizedSerializedSize = -1; - public static final int UT_COVERED_CONDITIONS_BY_LINE_FIELD_NUMBER = 5; - private java.util.List<java.lang.Integer> utCoveredConditionsByLine_; + public static final int UT_COVERED_CONDITIONS_FIELD_NUMBER = 5; + private int utCoveredConditions_; /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> + * <code>optional int32 ut_covered_conditions = 5;</code> */ - public java.util.List<java.lang.Integer> - getUtCoveredConditionsByLineList() { - return utCoveredConditionsByLine_; + public boolean hasUtCoveredConditions() { + return ((bitField0_ & 0x00000010) == 0x00000010); } /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> + * <code>optional int32 ut_covered_conditions = 5;</code> */ - public int getUtCoveredConditionsByLineCount() { - return utCoveredConditionsByLine_.size(); + public int getUtCoveredConditions() { + return utCoveredConditions_; } + + public static final int IT_COVERED_CONDITIONS_FIELD_NUMBER = 6; + private int itCoveredConditions_; /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> + * <code>optional int32 it_covered_conditions = 6;</code> */ - public int getUtCoveredConditionsByLine(int index) { - return utCoveredConditionsByLine_.get(index); + public boolean hasItCoveredConditions() { + return ((bitField0_ & 0x00000020) == 0x00000020); } - private int utCoveredConditionsByLineMemoizedSerializedSize = -1; - - public static final int IT_COVERED_CONDITIONS_BY_LINE_FIELD_NUMBER = 6; - private java.util.List<java.lang.Integer> itCoveredConditionsByLine_; /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> + * <code>optional int32 it_covered_conditions = 6;</code> */ - public java.util.List<java.lang.Integer> - getItCoveredConditionsByLineList() { - return itCoveredConditionsByLine_; + public int getItCoveredConditions() { + return itCoveredConditions_; } + + public static final int OVERALL_COVERED_CONDITIONS_FIELD_NUMBER = 7; + private int overallCoveredConditions_; /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> + * <code>optional int32 overall_covered_conditions = 7;</code> */ - public int getItCoveredConditionsByLineCount() { - return itCoveredConditionsByLine_.size(); + public boolean hasOverallCoveredConditions() { + return ((bitField0_ & 0x00000040) == 0x00000040); } /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> + * <code>optional int32 overall_covered_conditions = 7;</code> */ - public int getItCoveredConditionsByLine(int index) { - return itCoveredConditionsByLine_.get(index); + public int getOverallCoveredConditions() { + return overallCoveredConditions_; } - private int itCoveredConditionsByLineMemoizedSerializedSize = -1; - public static final int OVERALL_COVERED_CONDITIONS_BY_LINE_FIELD_NUMBER = 7; - private java.util.List<java.lang.Integer> overallCoveredConditionsByLine_; - /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> - */ - public java.util.List<java.lang.Integer> - getOverallCoveredConditionsByLineList() { - return overallCoveredConditionsByLine_; - } - /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> - */ - public int getOverallCoveredConditionsByLineCount() { - return overallCoveredConditionsByLine_.size(); - } - /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> - */ - public int getOverallCoveredConditionsByLine(int index) { - return overallCoveredConditionsByLine_.get(index); - } - private int overallCoveredConditionsByLineMemoizedSerializedSize = -1; - - private void initFields() { - fileRef_ = 0; - conditionsByLine_ = java.util.Collections.emptyList(); - utHitsByLine_ = java.util.Collections.emptyList(); - itHitsByLine_ = java.util.Collections.emptyList(); - utCoveredConditionsByLine_ = java.util.Collections.emptyList(); - itCoveredConditionsByLine_ = java.util.Collections.emptyList(); - overallCoveredConditionsByLine_ = java.util.Collections.emptyList(); + private void initFields() { + line_ = 0; + conditions_ = 0; + utHits_ = false; + itHits_ = false; + utCoveredConditions_ = 0; + itCoveredConditions_ = 0; + overallCoveredConditions_ = 0; } private byte memoizedIsInitialized = -1; public final boolean isInitialized() { @@ -20127,49 +19801,25 @@ public final class BatchReport { throws java.io.IOException { getSerializedSize(); if (((bitField0_ & 0x00000001) == 0x00000001)) { - output.writeInt32(1, fileRef_); - } - if (getConditionsByLineList().size() > 0) { - output.writeRawVarint32(18); - output.writeRawVarint32(conditionsByLineMemoizedSerializedSize); - } - for (int i = 0; i < conditionsByLine_.size(); i++) { - output.writeInt32NoTag(conditionsByLine_.get(i)); - } - if (getUtHitsByLineList().size() > 0) { - output.writeRawVarint32(26); - output.writeRawVarint32(utHitsByLineMemoizedSerializedSize); + output.writeInt32(1, line_); } - for (int i = 0; i < utHitsByLine_.size(); i++) { - output.writeBoolNoTag(utHitsByLine_.get(i)); - } - if (getItHitsByLineList().size() > 0) { - output.writeRawVarint32(34); - output.writeRawVarint32(itHitsByLineMemoizedSerializedSize); - } - for (int i = 0; i < itHitsByLine_.size(); i++) { - output.writeBoolNoTag(itHitsByLine_.get(i)); - } - if (getUtCoveredConditionsByLineList().size() > 0) { - output.writeRawVarint32(42); - output.writeRawVarint32(utCoveredConditionsByLineMemoizedSerializedSize); + if (((bitField0_ & 0x00000002) == 0x00000002)) { + output.writeInt32(2, conditions_); } - for (int i = 0; i < utCoveredConditionsByLine_.size(); i++) { - output.writeInt32NoTag(utCoveredConditionsByLine_.get(i)); + if (((bitField0_ & 0x00000004) == 0x00000004)) { + output.writeBool(3, utHits_); } - if (getItCoveredConditionsByLineList().size() > 0) { - output.writeRawVarint32(50); - output.writeRawVarint32(itCoveredConditionsByLineMemoizedSerializedSize); + if (((bitField0_ & 0x00000008) == 0x00000008)) { + output.writeBool(4, itHits_); } - for (int i = 0; i < itCoveredConditionsByLine_.size(); i++) { - output.writeInt32NoTag(itCoveredConditionsByLine_.get(i)); + if (((bitField0_ & 0x00000010) == 0x00000010)) { + output.writeInt32(5, utCoveredConditions_); } - if (getOverallCoveredConditionsByLineList().size() > 0) { - output.writeRawVarint32(58); - output.writeRawVarint32(overallCoveredConditionsByLineMemoizedSerializedSize); + if (((bitField0_ & 0x00000020) == 0x00000020)) { + output.writeInt32(6, itCoveredConditions_); } - for (int i = 0; i < overallCoveredConditionsByLine_.size(); i++) { - output.writeInt32NoTag(overallCoveredConditionsByLine_.get(i)); + if (((bitField0_ & 0x00000040) == 0x00000040)) { + output.writeInt32(7, overallCoveredConditions_); } getUnknownFields().writeTo(output); } @@ -20182,85 +19832,31 @@ public final class BatchReport { size = 0; if (((bitField0_ & 0x00000001) == 0x00000001)) { size += com.google.protobuf.CodedOutputStream - .computeInt32Size(1, fileRef_); + .computeInt32Size(1, line_); } - { - int dataSize = 0; - for (int i = 0; i < conditionsByLine_.size(); i++) { - dataSize += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(conditionsByLine_.get(i)); - } - size += dataSize; - if (!getConditionsByLineList().isEmpty()) { - size += 1; - size += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(dataSize); - } - conditionsByLineMemoizedSerializedSize = dataSize; + if (((bitField0_ & 0x00000002) == 0x00000002)) { + size += com.google.protobuf.CodedOutputStream + .computeInt32Size(2, conditions_); } - { - int dataSize = 0; - dataSize = 1 * getUtHitsByLineList().size(); - size += dataSize; - if (!getUtHitsByLineList().isEmpty()) { - size += 1; - size += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(dataSize); - } - utHitsByLineMemoizedSerializedSize = dataSize; + if (((bitField0_ & 0x00000004) == 0x00000004)) { + size += com.google.protobuf.CodedOutputStream + .computeBoolSize(3, utHits_); } - { - int dataSize = 0; - dataSize = 1 * getItHitsByLineList().size(); - size += dataSize; - if (!getItHitsByLineList().isEmpty()) { - size += 1; - size += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(dataSize); - } - itHitsByLineMemoizedSerializedSize = dataSize; + if (((bitField0_ & 0x00000008) == 0x00000008)) { + size += com.google.protobuf.CodedOutputStream + .computeBoolSize(4, itHits_); } - { - int dataSize = 0; - for (int i = 0; i < utCoveredConditionsByLine_.size(); i++) { - dataSize += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(utCoveredConditionsByLine_.get(i)); - } - size += dataSize; - if (!getUtCoveredConditionsByLineList().isEmpty()) { - size += 1; - size += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(dataSize); - } - utCoveredConditionsByLineMemoizedSerializedSize = dataSize; + if (((bitField0_ & 0x00000010) == 0x00000010)) { + size += com.google.protobuf.CodedOutputStream + .computeInt32Size(5, utCoveredConditions_); } - { - int dataSize = 0; - for (int i = 0; i < itCoveredConditionsByLine_.size(); i++) { - dataSize += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(itCoveredConditionsByLine_.get(i)); - } - size += dataSize; - if (!getItCoveredConditionsByLineList().isEmpty()) { - size += 1; - size += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(dataSize); - } - itCoveredConditionsByLineMemoizedSerializedSize = dataSize; + if (((bitField0_ & 0x00000020) == 0x00000020)) { + size += com.google.protobuf.CodedOutputStream + .computeInt32Size(6, itCoveredConditions_); } - { - int dataSize = 0; - for (int i = 0; i < overallCoveredConditionsByLine_.size(); i++) { - dataSize += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(overallCoveredConditionsByLine_.get(i)); - } - size += dataSize; - if (!getOverallCoveredConditionsByLineList().isEmpty()) { - size += 1; - size += com.google.protobuf.CodedOutputStream - .computeInt32SizeNoTag(dataSize); - } - overallCoveredConditionsByLineMemoizedSerializedSize = dataSize; + if (((bitField0_ & 0x00000040) == 0x00000040)) { + size += com.google.protobuf.CodedOutputStream + .computeInt32Size(7, overallCoveredConditions_); } size += getUnknownFields().getSerializedSize(); memoizedSerializedSize = size; @@ -20342,6 +19938,10 @@ public final class BatchReport { } /** * Protobuf type {@code Coverage} + * + * <pre> + * Only FILE component has coverage information + * </pre> */ public static final class Builder extends com.google.protobuf.GeneratedMessage.Builder<Builder> implements @@ -20379,19 +19979,19 @@ public final class BatchReport { public Builder clear() { super.clear(); - fileRef_ = 0; + line_ = 0; bitField0_ = (bitField0_ & ~0x00000001); - conditionsByLine_ = java.util.Collections.emptyList(); + conditions_ = 0; bitField0_ = (bitField0_ & ~0x00000002); - utHitsByLine_ = java.util.Collections.emptyList(); + utHits_ = false; bitField0_ = (bitField0_ & ~0x00000004); - itHitsByLine_ = java.util.Collections.emptyList(); + itHits_ = false; bitField0_ = (bitField0_ & ~0x00000008); - utCoveredConditionsByLine_ = java.util.Collections.emptyList(); + utCoveredConditions_ = 0; bitField0_ = (bitField0_ & ~0x00000010); - itCoveredConditionsByLine_ = java.util.Collections.emptyList(); + itCoveredConditions_ = 0; bitField0_ = (bitField0_ & ~0x00000020); - overallCoveredConditionsByLine_ = java.util.Collections.emptyList(); + overallCoveredConditions_ = 0; bitField0_ = (bitField0_ & ~0x00000040); return this; } @@ -20424,37 +20024,31 @@ public final class BatchReport { if (((from_bitField0_ & 0x00000001) == 0x00000001)) { to_bitField0_ |= 0x00000001; } - result.fileRef_ = fileRef_; - if (((bitField0_ & 0x00000002) == 0x00000002)) { - conditionsByLine_ = java.util.Collections.unmodifiableList(conditionsByLine_); - bitField0_ = (bitField0_ & ~0x00000002); + result.line_ = line_; + if (((from_bitField0_ & 0x00000002) == 0x00000002)) { + to_bitField0_ |= 0x00000002; } - result.conditionsByLine_ = conditionsByLine_; - if (((bitField0_ & 0x00000004) == 0x00000004)) { - utHitsByLine_ = java.util.Collections.unmodifiableList(utHitsByLine_); - bitField0_ = (bitField0_ & ~0x00000004); + result.conditions_ = conditions_; + if (((from_bitField0_ & 0x00000004) == 0x00000004)) { + to_bitField0_ |= 0x00000004; } - result.utHitsByLine_ = utHitsByLine_; - if (((bitField0_ & 0x00000008) == 0x00000008)) { - itHitsByLine_ = java.util.Collections.unmodifiableList(itHitsByLine_); - bitField0_ = (bitField0_ & ~0x00000008); + result.utHits_ = utHits_; + if (((from_bitField0_ & 0x00000008) == 0x00000008)) { + to_bitField0_ |= 0x00000008; } - result.itHitsByLine_ = itHitsByLine_; - if (((bitField0_ & 0x00000010) == 0x00000010)) { - utCoveredConditionsByLine_ = java.util.Collections.unmodifiableList(utCoveredConditionsByLine_); - bitField0_ = (bitField0_ & ~0x00000010); + result.itHits_ = itHits_; + if (((from_bitField0_ & 0x00000010) == 0x00000010)) { + to_bitField0_ |= 0x00000010; } - result.utCoveredConditionsByLine_ = utCoveredConditionsByLine_; - if (((bitField0_ & 0x00000020) == 0x00000020)) { - itCoveredConditionsByLine_ = java.util.Collections.unmodifiableList(itCoveredConditionsByLine_); - bitField0_ = (bitField0_ & ~0x00000020); + result.utCoveredConditions_ = utCoveredConditions_; + if (((from_bitField0_ & 0x00000020) == 0x00000020)) { + to_bitField0_ |= 0x00000020; } - result.itCoveredConditionsByLine_ = itCoveredConditionsByLine_; - if (((bitField0_ & 0x00000040) == 0x00000040)) { - overallCoveredConditionsByLine_ = java.util.Collections.unmodifiableList(overallCoveredConditionsByLine_); - bitField0_ = (bitField0_ & ~0x00000040); + result.itCoveredConditions_ = itCoveredConditions_; + if (((from_bitField0_ & 0x00000040) == 0x00000040)) { + to_bitField0_ |= 0x00000040; } - result.overallCoveredConditionsByLine_ = overallCoveredConditionsByLine_; + result.overallCoveredConditions_ = overallCoveredConditions_; result.bitField0_ = to_bitField0_; onBuilt(); return result; @@ -20471,68 +20065,26 @@ public final class BatchReport { public Builder mergeFrom(org.sonar.batch.protocol.output.BatchReport.Coverage other) { if (other == org.sonar.batch.protocol.output.BatchReport.Coverage.getDefaultInstance()) return this; - if (other.hasFileRef()) { - setFileRef(other.getFileRef()); + if (other.hasLine()) { + setLine(other.getLine()); } - if (!other.conditionsByLine_.isEmpty()) { - if (conditionsByLine_.isEmpty()) { - conditionsByLine_ = other.conditionsByLine_; - bitField0_ = (bitField0_ & ~0x00000002); - } else { - ensureConditionsByLineIsMutable(); - conditionsByLine_.addAll(other.conditionsByLine_); - } - onChanged(); + if (other.hasConditions()) { + setConditions(other.getConditions()); } - if (!other.utHitsByLine_.isEmpty()) { - if (utHitsByLine_.isEmpty()) { - utHitsByLine_ = other.utHitsByLine_; - bitField0_ = (bitField0_ & ~0x00000004); - } else { - ensureUtHitsByLineIsMutable(); - utHitsByLine_.addAll(other.utHitsByLine_); - } - onChanged(); + if (other.hasUtHits()) { + setUtHits(other.getUtHits()); } - if (!other.itHitsByLine_.isEmpty()) { - if (itHitsByLine_.isEmpty()) { - itHitsByLine_ = other.itHitsByLine_; - bitField0_ = (bitField0_ & ~0x00000008); - } else { - ensureItHitsByLineIsMutable(); - itHitsByLine_.addAll(other.itHitsByLine_); - } - onChanged(); + if (other.hasItHits()) { + setItHits(other.getItHits()); } - if (!other.utCoveredConditionsByLine_.isEmpty()) { - if (utCoveredConditionsByLine_.isEmpty()) { - utCoveredConditionsByLine_ = other.utCoveredConditionsByLine_; - bitField0_ = (bitField0_ & ~0x00000010); - } else { - ensureUtCoveredConditionsByLineIsMutable(); - utCoveredConditionsByLine_.addAll(other.utCoveredConditionsByLine_); - } - onChanged(); + if (other.hasUtCoveredConditions()) { + setUtCoveredConditions(other.getUtCoveredConditions()); } - if (!other.itCoveredConditionsByLine_.isEmpty()) { - if (itCoveredConditionsByLine_.isEmpty()) { - itCoveredConditionsByLine_ = other.itCoveredConditionsByLine_; - bitField0_ = (bitField0_ & ~0x00000020); - } else { - ensureItCoveredConditionsByLineIsMutable(); - itCoveredConditionsByLine_.addAll(other.itCoveredConditionsByLine_); - } - onChanged(); + if (other.hasItCoveredConditions()) { + setItCoveredConditions(other.getItCoveredConditions()); } - if (!other.overallCoveredConditionsByLine_.isEmpty()) { - if (overallCoveredConditionsByLine_.isEmpty()) { - overallCoveredConditionsByLine_ = other.overallCoveredConditionsByLine_; - bitField0_ = (bitField0_ & ~0x00000040); - } else { - ensureOverallCoveredConditionsByLineIsMutable(); - overallCoveredConditionsByLine_.addAll(other.overallCoveredConditionsByLine_); - } - onChanged(); + if (other.hasOverallCoveredConditions()) { + setOverallCoveredConditions(other.getOverallCoveredConditions()); } this.mergeUnknownFields(other.getUnknownFields()); return this; @@ -20561,614 +20113,242 @@ public final class BatchReport { } private int bitField0_; - private int fileRef_ ; + private int line_ ; /** - * <code>optional int32 file_ref = 1;</code> - * - * <pre> - * Only FILE component has coverage information - * </pre> + * <code>optional int32 line = 1;</code> */ - public boolean hasFileRef() { + public boolean hasLine() { return ((bitField0_ & 0x00000001) == 0x00000001); } /** - * <code>optional int32 file_ref = 1;</code> - * - * <pre> - * Only FILE component has coverage information - * </pre> + * <code>optional int32 line = 1;</code> */ - public int getFileRef() { - return fileRef_; + public int getLine() { + return line_; } /** - * <code>optional int32 file_ref = 1;</code> - * - * <pre> - * Only FILE component has coverage information - * </pre> + * <code>optional int32 line = 1;</code> */ - public Builder setFileRef(int value) { + public Builder setLine(int value) { bitField0_ |= 0x00000001; - fileRef_ = value; + line_ = value; onChanged(); return this; } /** - * <code>optional int32 file_ref = 1;</code> - * - * <pre> - * Only FILE component has coverage information - * </pre> + * <code>optional int32 line = 1;</code> */ - public Builder clearFileRef() { + public Builder clearLine() { bitField0_ = (bitField0_ & ~0x00000001); - fileRef_ = 0; + line_ = 0; onChanged(); return this; } - private java.util.List<java.lang.Integer> conditionsByLine_ = java.util.Collections.emptyList(); - private void ensureConditionsByLineIsMutable() { - if (!((bitField0_ & 0x00000002) == 0x00000002)) { - conditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(conditionsByLine_); - bitField0_ |= 0x00000002; - } - } + private int conditions_ ; /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> + * <code>optional int32 conditions = 2;</code> * * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover + * Number of conditions to cover (never 0) * </pre> */ - public java.util.List<java.lang.Integer> - getConditionsByLineList() { - return java.util.Collections.unmodifiableList(conditionsByLine_); - } - /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> - * - * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover - * </pre> - */ - public int getConditionsByLineCount() { - return conditionsByLine_.size(); - } - /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> - * - * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover - * </pre> - */ - public int getConditionsByLine(int index) { - return conditionsByLine_.get(index); - } - /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> - * - * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover - * </pre> - */ - public Builder setConditionsByLine( - int index, int value) { - ensureConditionsByLineIsMutable(); - conditionsByLine_.set(index, value); - onChanged(); - return this; + public boolean hasConditions() { + return ((bitField0_ & 0x00000002) == 0x00000002); } /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> + * <code>optional int32 conditions = 2;</code> * * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover + * Number of conditions to cover (never 0) * </pre> */ - public Builder addConditionsByLine(int value) { - ensureConditionsByLineIsMutable(); - conditionsByLine_.add(value); - onChanged(); - return this; + public int getConditions() { + return conditions_; } /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> + * <code>optional int32 conditions = 2;</code> * * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover + * Number of conditions to cover (never 0) * </pre> */ - public Builder addAllConditionsByLine( - java.lang.Iterable<? extends java.lang.Integer> values) { - ensureConditionsByLineIsMutable(); - com.google.protobuf.AbstractMessageLite.Builder.addAll( - values, conditionsByLine_); + public Builder setConditions(int value) { + bitField0_ |= 0x00000002; + conditions_ = value; onChanged(); return this; } /** - * <code>repeated int32 conditions_by_line = 2 [packed = true];</code> + * <code>optional int32 conditions = 2;</code> * * <pre> - * List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover + * Number of conditions to cover (never 0) * </pre> */ - public Builder clearConditionsByLine() { - conditionsByLine_ = java.util.Collections.emptyList(); + public Builder clearConditions() { bitField0_ = (bitField0_ & ~0x00000002); + conditions_ = 0; onChanged(); return this; } - private java.util.List<java.lang.Boolean> utHitsByLine_ = java.util.Collections.emptyList(); - private void ensureUtHitsByLineIsMutable() { - if (!((bitField0_ & 0x00000004) == 0x00000004)) { - utHitsByLine_ = new java.util.ArrayList<java.lang.Boolean>(utHitsByLine_); - bitField0_ |= 0x00000004; - } - } - /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> - */ - public java.util.List<java.lang.Boolean> - getUtHitsByLineList() { - return java.util.Collections.unmodifiableList(utHitsByLine_); - } + private boolean utHits_ ; /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> + * <code>optional bool ut_hits = 3;</code> */ - public int getUtHitsByLineCount() { - return utHitsByLine_.size(); - } - /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> - */ - public boolean getUtHitsByLine(int index) { - return utHitsByLine_.get(index); - } - /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> - */ - public Builder setUtHitsByLine( - int index, boolean value) { - ensureUtHitsByLineIsMutable(); - utHitsByLine_.set(index, value); - onChanged(); - return this; + public boolean hasUtHits() { + return ((bitField0_ & 0x00000004) == 0x00000004); } /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> + * <code>optional bool ut_hits = 3;</code> */ - public Builder addUtHitsByLine(boolean value) { - ensureUtHitsByLineIsMutable(); - utHitsByLine_.add(value); - onChanged(); - return this; + public boolean getUtHits() { + return utHits_; } /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> + * <code>optional bool ut_hits = 3;</code> */ - public Builder addAllUtHitsByLine( - java.lang.Iterable<? extends java.lang.Boolean> values) { - ensureUtHitsByLineIsMutable(); - com.google.protobuf.AbstractMessageLite.Builder.addAll( - values, utHitsByLine_); + public Builder setUtHits(boolean value) { + bitField0_ |= 0x00000004; + utHits_ = value; onChanged(); return this; } /** - * <code>repeated bool ut_hits_by_line = 3 [packed = true];</code> - * - * <pre> - * List of unit test hits by line - * </pre> + * <code>optional bool ut_hits = 3;</code> */ - public Builder clearUtHitsByLine() { - utHitsByLine_ = java.util.Collections.emptyList(); + public Builder clearUtHits() { bitField0_ = (bitField0_ & ~0x00000004); + utHits_ = false; onChanged(); return this; } - private java.util.List<java.lang.Boolean> itHitsByLine_ = java.util.Collections.emptyList(); - private void ensureItHitsByLineIsMutable() { - if (!((bitField0_ & 0x00000008) == 0x00000008)) { - itHitsByLine_ = new java.util.ArrayList<java.lang.Boolean>(itHitsByLine_); - bitField0_ |= 0x00000008; - } - } - /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> - */ - public java.util.List<java.lang.Boolean> - getItHitsByLineList() { - return java.util.Collections.unmodifiableList(itHitsByLine_); - } - /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> - */ - public int getItHitsByLineCount() { - return itHitsByLine_.size(); - } + private boolean itHits_ ; /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> + * <code>optional bool it_hits = 4;</code> */ - public boolean getItHitsByLine(int index) { - return itHitsByLine_.get(index); + public boolean hasItHits() { + return ((bitField0_ & 0x00000008) == 0x00000008); } /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> + * <code>optional bool it_hits = 4;</code> */ - public Builder setItHitsByLine( - int index, boolean value) { - ensureItHitsByLineIsMutable(); - itHitsByLine_.set(index, value); - onChanged(); - return this; + public boolean getItHits() { + return itHits_; } /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> + * <code>optional bool it_hits = 4;</code> */ - public Builder addItHitsByLine(boolean value) { - ensureItHitsByLineIsMutable(); - itHitsByLine_.add(value); + public Builder setItHits(boolean value) { + bitField0_ |= 0x00000008; + itHits_ = value; onChanged(); return this; } /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> + * <code>optional bool it_hits = 4;</code> */ - public Builder addAllItHitsByLine( - java.lang.Iterable<? extends java.lang.Boolean> values) { - ensureItHitsByLineIsMutable(); - com.google.protobuf.AbstractMessageLite.Builder.addAll( - values, itHitsByLine_); - onChanged(); - return this; - } - /** - * <code>repeated bool it_hits_by_line = 4 [packed = true];</code> - * - * <pre> - * List of integration test hits by line - * </pre> - */ - public Builder clearItHitsByLine() { - itHitsByLine_ = java.util.Collections.emptyList(); + public Builder clearItHits() { bitField0_ = (bitField0_ & ~0x00000008); + itHits_ = false; onChanged(); return this; } - private java.util.List<java.lang.Integer> utCoveredConditionsByLine_ = java.util.Collections.emptyList(); - private void ensureUtCoveredConditionsByLineIsMutable() { - if (!((bitField0_ & 0x00000010) == 0x00000010)) { - utCoveredConditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(utCoveredConditionsByLine_); - bitField0_ |= 0x00000010; - } - } - /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> - */ - public java.util.List<java.lang.Integer> - getUtCoveredConditionsByLineList() { - return java.util.Collections.unmodifiableList(utCoveredConditionsByLine_); - } - /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> - */ - public int getUtCoveredConditionsByLineCount() { - return utCoveredConditionsByLine_.size(); - } + private int utCoveredConditions_ ; /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> - */ - public int getUtCoveredConditionsByLine(int index) { - return utCoveredConditionsByLine_.get(index); - } - /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> + * <code>optional int32 ut_covered_conditions = 5;</code> */ - public Builder setUtCoveredConditionsByLine( - int index, int value) { - ensureUtCoveredConditionsByLineIsMutable(); - utCoveredConditionsByLine_.set(index, value); - onChanged(); - return this; + public boolean hasUtCoveredConditions() { + return ((bitField0_ & 0x00000010) == 0x00000010); } /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> + * <code>optional int32 ut_covered_conditions = 5;</code> */ - public Builder addUtCoveredConditionsByLine(int value) { - ensureUtCoveredConditionsByLineIsMutable(); - utCoveredConditionsByLine_.add(value); - onChanged(); - return this; + public int getUtCoveredConditions() { + return utCoveredConditions_; } /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> + * <code>optional int32 ut_covered_conditions = 5;</code> */ - public Builder addAllUtCoveredConditionsByLine( - java.lang.Iterable<? extends java.lang.Integer> values) { - ensureUtCoveredConditionsByLineIsMutable(); - com.google.protobuf.AbstractMessageLite.Builder.addAll( - values, utCoveredConditionsByLine_); + public Builder setUtCoveredConditions(int value) { + bitField0_ |= 0x00000010; + utCoveredConditions_ = value; onChanged(); return this; } /** - * <code>repeated int32 ut_covered_conditions_by_line = 5 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by unit test by line - * </pre> + * <code>optional int32 ut_covered_conditions = 5;</code> */ - public Builder clearUtCoveredConditionsByLine() { - utCoveredConditionsByLine_ = java.util.Collections.emptyList(); + public Builder clearUtCoveredConditions() { bitField0_ = (bitField0_ & ~0x00000010); + utCoveredConditions_ = 0; onChanged(); return this; } - private java.util.List<java.lang.Integer> itCoveredConditionsByLine_ = java.util.Collections.emptyList(); - private void ensureItCoveredConditionsByLineIsMutable() { - if (!((bitField0_ & 0x00000020) == 0x00000020)) { - itCoveredConditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(itCoveredConditionsByLine_); - bitField0_ |= 0x00000020; - } - } + private int itCoveredConditions_ ; /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> + * <code>optional int32 it_covered_conditions = 6;</code> */ - public java.util.List<java.lang.Integer> - getItCoveredConditionsByLineList() { - return java.util.Collections.unmodifiableList(itCoveredConditionsByLine_); - } - /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> - */ - public int getItCoveredConditionsByLineCount() { - return itCoveredConditionsByLine_.size(); - } - /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> - */ - public int getItCoveredConditionsByLine(int index) { - return itCoveredConditionsByLine_.get(index); - } - /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> - */ - public Builder setItCoveredConditionsByLine( - int index, int value) { - ensureItCoveredConditionsByLineIsMutable(); - itCoveredConditionsByLine_.set(index, value); - onChanged(); - return this; + public boolean hasItCoveredConditions() { + return ((bitField0_ & 0x00000020) == 0x00000020); } /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> + * <code>optional int32 it_covered_conditions = 6;</code> */ - public Builder addItCoveredConditionsByLine(int value) { - ensureItCoveredConditionsByLineIsMutable(); - itCoveredConditionsByLine_.add(value); - onChanged(); - return this; + public int getItCoveredConditions() { + return itCoveredConditions_; } /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> + * <code>optional int32 it_covered_conditions = 6;</code> */ - public Builder addAllItCoveredConditionsByLine( - java.lang.Iterable<? extends java.lang.Integer> values) { - ensureItCoveredConditionsByLineIsMutable(); - com.google.protobuf.AbstractMessageLite.Builder.addAll( - values, itCoveredConditionsByLine_); + public Builder setItCoveredConditions(int value) { + bitField0_ |= 0x00000020; + itCoveredConditions_ = value; onChanged(); return this; } /** - * <code>repeated int32 it_covered_conditions_by_line = 6 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by integration test by line - * </pre> + * <code>optional int32 it_covered_conditions = 6;</code> */ - public Builder clearItCoveredConditionsByLine() { - itCoveredConditionsByLine_ = java.util.Collections.emptyList(); + public Builder clearItCoveredConditions() { bitField0_ = (bitField0_ & ~0x00000020); + itCoveredConditions_ = 0; onChanged(); return this; } - private java.util.List<java.lang.Integer> overallCoveredConditionsByLine_ = java.util.Collections.emptyList(); - private void ensureOverallCoveredConditionsByLineIsMutable() { - if (!((bitField0_ & 0x00000040) == 0x00000040)) { - overallCoveredConditionsByLine_ = new java.util.ArrayList<java.lang.Integer>(overallCoveredConditionsByLine_); - bitField0_ |= 0x00000040; - } - } + private int overallCoveredConditions_ ; /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> + * <code>optional int32 overall_covered_conditions = 7;</code> */ - public java.util.List<java.lang.Integer> - getOverallCoveredConditionsByLineList() { - return java.util.Collections.unmodifiableList(overallCoveredConditionsByLine_); - } - /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> - */ - public int getOverallCoveredConditionsByLineCount() { - return overallCoveredConditionsByLine_.size(); - } - /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> - */ - public int getOverallCoveredConditionsByLine(int index) { - return overallCoveredConditionsByLine_.get(index); - } - /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> - */ - public Builder setOverallCoveredConditionsByLine( - int index, int value) { - ensureOverallCoveredConditionsByLineIsMutable(); - overallCoveredConditionsByLine_.set(index, value); - onChanged(); - return this; + public boolean hasOverallCoveredConditions() { + return ((bitField0_ & 0x00000040) == 0x00000040); } /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> + * <code>optional int32 overall_covered_conditions = 7;</code> */ - public Builder addOverallCoveredConditionsByLine(int value) { - ensureOverallCoveredConditionsByLineIsMutable(); - overallCoveredConditionsByLine_.add(value); - onChanged(); - return this; + public int getOverallCoveredConditions() { + return overallCoveredConditions_; } /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> + * <code>optional int32 overall_covered_conditions = 7;</code> */ - public Builder addAllOverallCoveredConditionsByLine( - java.lang.Iterable<? extends java.lang.Integer> values) { - ensureOverallCoveredConditionsByLineIsMutable(); - com.google.protobuf.AbstractMessageLite.Builder.addAll( - values, overallCoveredConditionsByLine_); + public Builder setOverallCoveredConditions(int value) { + bitField0_ |= 0x00000040; + overallCoveredConditions_ = value; onChanged(); return this; } /** - * <code>repeated int32 overall_covered_conditions_by_line = 7 [packed = true];</code> - * - * <pre> - * List of number of conditions covered by overall test by line - * </pre> + * <code>optional int32 overall_covered_conditions = 7;</code> */ - public Builder clearOverallCoveredConditionsByLine() { - overallCoveredConditionsByLine_ = java.util.Collections.emptyList(); + public Builder clearOverallCoveredConditions() { bitField0_ = (bitField0_ & ~0x00000040); + overallCoveredConditions_ = 0; onChanged(); return this; } @@ -22812,19 +21992,17 @@ public final class BatchReport { " \001(\005\022\022\n\nend_offset\030\004 \001(\005\"~\n\007Symbols\022\020\n\010f" + "ile_ref\030\001 \001(\005\022\037\n\006symbol\030\002 \003(\0132\017.Symbols." + "Symbol\032@\n\006Symbol\022\033\n\013declaration\030\001 \001(\0132\006.", - "Range\022\031\n\treference\030\002 \003(\0132\006.Range\"\374\001\n\010Cov" + - "erage\022\020\n\010file_ref\030\001 \001(\005\022\036\n\022conditions_by" + - "_line\030\002 \003(\005B\002\020\001\022\033\n\017ut_hits_by_line\030\003 \003(\010" + - "B\002\020\001\022\033\n\017it_hits_by_line\030\004 \003(\010B\002\020\001\022)\n\035ut_" + - "covered_conditions_by_line\030\005 \003(\005B\002\020\001\022)\n\035" + - "it_covered_conditions_by_line\030\006 \003(\005B\002\020\001\022" + - ".\n\"overall_covered_conditions_by_line\030\007 " + - "\003(\005B\002\020\001\"\263\001\n\022SyntaxHighlighting\022\020\n\010file_r" + - "ef\030\001 \001(\005\022?\n\021highlighting_rule\030\002 \003(\0132$.Sy" + - "ntaxHighlighting.HighlightingRule\032J\n\020Hig", - "hlightingRule\022\025\n\005range\030\001 \001(\0132\006.Range\022\037\n\004" + - "type\030\002 \001(\0162\021.HighlightingTypeB#\n\037org.son" + - "ar.batch.protocol.outputH\001" + "Range\022\031\n\treference\030\002 \003(\0132\006.Range\"\260\001\n\010Cov" + + "erage\022\014\n\004line\030\001 \001(\005\022\022\n\nconditions\030\002 \001(\005\022" + + "\017\n\007ut_hits\030\003 \001(\010\022\017\n\007it_hits\030\004 \001(\010\022\035\n\025ut_" + + "covered_conditions\030\005 \001(\005\022\035\n\025it_covered_c" + + "onditions\030\006 \001(\005\022\"\n\032overall_covered_condi" + + "tions\030\007 \001(\005\"\263\001\n\022SyntaxHighlighting\022\020\n\010fi" + + "le_ref\030\001 \001(\005\022?\n\021highlighting_rule\030\002 \003(\0132" + + "$.SyntaxHighlighting.HighlightingRule\032J\n" + + "\020HighlightingRule\022\025\n\005range\030\001 \001(\0132\006.Range" + + "\022\037\n\004type\030\002 \001(\0162\021.HighlightingTypeB#\n\037org", + ".sonar.batch.protocol.outputH\001" }; com.google.protobuf.Descriptors.FileDescriptor.InternalDescriptorAssigner assigner = new com.google.protobuf.Descriptors.FileDescriptor. InternalDescriptorAssigner() { @@ -22940,7 +22118,7 @@ public final class BatchReport { internal_static_Coverage_fieldAccessorTable = new com.google.protobuf.GeneratedMessage.FieldAccessorTable( internal_static_Coverage_descriptor, - new java.lang.String[] { "FileRef", "ConditionsByLine", "UtHitsByLine", "ItHitsByLine", "UtCoveredConditionsByLine", "ItCoveredConditionsByLine", "OverallCoveredConditionsByLine", }); + new java.lang.String[] { "Line", "Conditions", "UtHits", "ItHits", "UtCoveredConditions", "ItCoveredConditions", "OverallCoveredConditions", }); internal_static_SyntaxHighlighting_descriptor = getDescriptor().getMessageTypes().get(15); internal_static_SyntaxHighlighting_fieldAccessorTable = new diff --git a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/ProtobufUtil.java b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/ProtobufUtil.java index 8d7d5a671d4..d8c2d8f838a 100644 --- a/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/ProtobufUtil.java +++ b/sonar-batch-protocol/src/main/java/org/sonar/batch/protocol/ProtobufUtil.java @@ -19,17 +19,13 @@ */ package org.sonar.batch.protocol; +import com.google.protobuf.InvalidProtocolBufferException; import com.google.protobuf.Message; import com.google.protobuf.Parser; -import java.io.BufferedInputStream; -import java.io.BufferedOutputStream; -import java.io.File; -import java.io.FileInputStream; -import java.io.FileOutputStream; -import java.io.IOException; -import java.io.InputStream; -import java.io.OutputStream; +import java.io.*; +import java.util.Iterator; +import java.util.NoSuchElementException; public class ProtobufUtil { private ProtobufUtil() { @@ -44,6 +40,55 @@ public class ProtobufUtil { } } + public static <M extends Message> Iterable<M> readFileMessages(final File file, final Parser<M> parser) { + return new Iterable<M>() { + @Override + public Iterator<M> iterator() { + try { + return new Iterator<M>() { + final InputStream inputStream = new BufferedInputStream(new FileInputStream(file)); + + private M currentMessage; + + @Override + public boolean hasNext() { + if (currentMessage == null) { + try { + currentMessage = parser.parseDelimitedFrom(inputStream); + if (currentMessage == null) { + inputStream.close(); + } + } catch (InvalidProtocolBufferException e) { + throw new IllegalStateException("Failed to read input stream", e); + } catch (IOException e) { + throw new IllegalStateException("Failed to close input stream", e); + } + } + return currentMessage != null; + } + + @Override + public M next() { + if (!hasNext()) { + throw new NoSuchElementException(); + } + M messageToReturn = currentMessage; + currentMessage = null; + return messageToReturn; + } + + @Override + public void remove() { + throw new UnsupportedOperationException(); + } + }; + } catch (FileNotFoundException e) { + throw new IllegalStateException("Unable to find file " + file, e); + } + } + }; + } + public static void writeToFile(Message message, File toFile) { try (OutputStream out = new BufferedOutputStream(new FileOutputStream(toFile, false))) { message.writeTo(out); @@ -51,4 +96,15 @@ public class ProtobufUtil { throw new IllegalStateException("Unable to write protocol buffer data to file " + toFile, e); } } + + public static <MESSAGE extends Message> void writeMessagesToFile(Iterable<MESSAGE> messages, File file) { + try (OutputStream out = new BufferedOutputStream(new FileOutputStream(file, true))) { + for (MESSAGE message : messages) { + message.writeDelimitedTo(out); + } + } catch (IOException e) { + throw new IllegalStateException("Failed to read file: " + file, e); + } + } + } 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 index 9621c208d8c..a35560839ce 100644 --- 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 @@ -23,6 +23,7 @@ import org.sonar.batch.protocol.ProtobufUtil; import org.sonar.batch.protocol.output.BatchReport.Issues; import javax.annotation.CheckForNull; + import java.io.File; import java.util.Collections; import java.util.List; @@ -119,13 +120,12 @@ public class BatchReportReader { return Collections.emptyList(); } - @CheckForNull - public BatchReport.Coverage readFileCoverage(int fileRef) { + public Iterable<BatchReport.Coverage> readFileCoverage(int fileRef) { File file = fileStructure.fileFor(FileStructure.Domain.COVERAGE, fileRef); if (doesFileExists(file)) { - return ProtobufUtil.readFile(file, BatchReport.Coverage.PARSER); + return ProtobufUtil.readFileMessages(file, BatchReport.Coverage.PARSER); } - return null; + return Collections.emptyList(); } private boolean doesFileExists(File file) { 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 index 30fa2919100..c08ed0e1156 100644 --- 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 @@ -21,7 +21,7 @@ package org.sonar.batch.protocol.output; import org.sonar.batch.protocol.ProtobufUtil; -import java.io.File; +import java.io.*; public class BatchReportWriter { @@ -113,9 +113,18 @@ public class BatchReportWriter { ProtobufUtil.writeToFile(builder.build(), file); } - public void writeFileCoverage(BatchReport.Coverage coverage) { - File file = fileStructure.fileFor(FileStructure.Domain.COVERAGE, coverage.getFileRef()); - ProtobufUtil.writeToFile(coverage, file); + public void writeFileCoverage(int componentRef, Iterable<BatchReport.Coverage> coverageList) { + File file = fileStructure.fileFor(FileStructure.Domain.COVERAGE, componentRef); + ProtobufUtil.writeMessagesToFile(coverageList, file); + } + + public OutputStream openCoverageOutputStream(int componentRef) { + File file = fileStructure.fileFor(FileStructure.Domain.COVERAGE, componentRef); + try { + return new BufferedOutputStream(new FileOutputStream(file, true)); + } catch (FileNotFoundException e) { + throw new IllegalStateException("Unable to find file " + file, e); + } } } diff --git a/sonar-batch-protocol/src/main/protobuf/batch_report.proto b/sonar-batch-protocol/src/main/protobuf/batch_report.proto index 39f1750400f..4f16fa760b7 100644 --- a/sonar-batch-protocol/src/main/protobuf/batch_report.proto +++ b/sonar-batch-protocol/src/main/protobuf/batch_report.proto @@ -210,22 +210,17 @@ message Symbols { } } +// Only FILE component has coverage information message Coverage { - // Only FILE component has coverage information - optional int32 file_ref = 1; - - // List of number of conditions by line : 0 => not to cover, 1+ => number of conditions to cover - repeated int32 conditions_by_line = 2 [packed = true]; - // List of unit test hits by line - repeated bool ut_hits_by_line = 3 [packed = true]; - // List of integration test hits by line - repeated bool it_hits_by_line = 4 [packed = true]; - // List of number of conditions covered by unit test by line - repeated int32 ut_covered_conditions_by_line = 5 [packed = true]; - // List of number of conditions covered by integration test by line - repeated int32 it_covered_conditions_by_line = 6 [packed = true]; - // List of number of conditions covered by overall test by line - repeated int32 overall_covered_conditions_by_line = 7 [packed = true]; + optional int32 line = 1; + + // Number of conditions to cover (never 0) + optional int32 conditions = 2; + optional bool ut_hits = 3; + optional bool it_hits = 4; + optional int32 ut_covered_conditions = 5; + optional int32 it_covered_conditions = 6; + optional int32 overall_covered_conditions = 7; } message SyntaxHighlighting { 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 index 1f7af3de105..817c0a6fd97 100644 --- 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 @@ -30,8 +30,10 @@ import org.sonar.batch.protocol.output.BatchReport.Range; import java.io.File; import java.util.Arrays; +import java.util.List; import static org.assertj.core.api.Assertions.assertThat; +import static org.assertj.core.util.Lists.newArrayList; public class BatchReportReaderTest { @@ -171,24 +173,47 @@ public class BatchReportReaderTest { writer.writeComponent(BatchReport.Component.newBuilder() .setRef(1).build()); - writer.writeFileCoverage(BatchReport.Coverage.newBuilder() - .setFileRef(1) - .addAllConditionsByLine(Arrays.asList(1, 5)) - .addAllUtHitsByLine(Arrays.asList(true, false)) - .addAllItHitsByLine(Arrays.asList(false, false)) - .addAllUtCoveredConditionsByLine(Arrays.asList(1, 4)) - .addAllItCoveredConditionsByLine(Arrays.asList(1, 5)) - .addAllOverallCoveredConditionsByLine(Arrays.asList(1, 5)) - .build()); + writer.writeFileCoverage(1, Arrays.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())); sut = new BatchReportReader(dir); - assertThat(sut.readFileCoverage(1).getFileRef()).isEqualTo(1); - assertThat(sut.readFileCoverage(1).getConditionsByLineList()).hasSize(2); - assertThat(sut.readFileCoverage(1).getUtHitsByLineList()).hasSize(2); - assertThat(sut.readFileCoverage(1).getItHitsByLineList()).hasSize(2); - assertThat(sut.readFileCoverage(1).getUtCoveredConditionsByLineList()).hasSize(2); - assertThat(sut.readFileCoverage(1).getItCoveredConditionsByLineList()).hasSize(2); - assertThat(sut.readFileCoverage(1).getOverallCoveredConditionsByLineList()).hasSize(2); + List<BatchReport.Coverage> coverageList = newArrayList(sut.readFileCoverage(1)); + assertThat(coverageList).hasSize(2); + + BatchReport.Coverage coverage = coverageList.get(0); + 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); + + coverage = coverageList.get(1); + assertThat(coverage.getLine()).isEqualTo(2); + assertThat(coverage.getConditions()).isEqualTo(5); + assertThat(coverage.getUtHits()).isFalse(); + assertThat(coverage.getItHits()).isFalse(); + assertThat(coverage.getUtCoveredConditions()).isEqualTo(4); + assertThat(coverage.getItCoveredConditions()).isEqualTo(5); + assertThat(coverage.getOverallCoveredConditions()).isEqualTo(5); } @Test(expected = IllegalStateException.class) 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 index d4475c1548c..d0bb79169ba 100644 --- 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 @@ -27,7 +27,10 @@ import org.sonar.batch.protocol.Constants; import org.sonar.batch.protocol.ProtobufUtil; import org.sonar.batch.protocol.output.BatchReport.Range; +import java.io.BufferedInputStream; import java.io.File; +import java.io.FileInputStream; +import java.io.InputStream; import java.util.Arrays; import static org.assertj.core.api.Assertions.assertThat; @@ -294,28 +297,49 @@ public class BatchReportWriterTest { // no data yet assertThat(writer.hasComponentData(FileStructure.Domain.COVERAGE, 1)).isFalse(); - // write data - writer.writeFileCoverage(BatchReport.Coverage.newBuilder() - .setFileRef(1) - .addAllConditionsByLine(Arrays.asList(1, 5)) - .addAllUtHitsByLine(Arrays.asList(true, false)) - .addAllItHitsByLine(Arrays.asList(false, false)) - .addAllUtCoveredConditionsByLine(Arrays.asList(1, 4)) - .addAllItCoveredConditionsByLine(Arrays.asList(1, 5)) - .addAllOverallCoveredConditionsByLine(Arrays.asList(1, 5)) - .build()); + writer.writeFileCoverage(1, Arrays.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() + )); assertThat(writer.hasComponentData(FileStructure.Domain.COVERAGE, 1)).isTrue(); File file = writer.getFileStructure().fileFor(FileStructure.Domain.COVERAGE, 1); assertThat(file).exists().isFile(); - BatchReport.Coverage read = ProtobufUtil.readFile(file, BatchReport.Coverage.PARSER); - assertThat(read.getFileRef()).isEqualTo(1); - assertThat(read.getConditionsByLineList()).hasSize(2); - assertThat(read.getUtHitsByLineList()).hasSize(2); - assertThat(read.getItHitsByLineList()).hasSize(2); - assertThat(read.getUtCoveredConditionsByLineList()).hasSize(2); - assertThat(read.getItCoveredConditionsByLineList()).hasSize(2); - assertThat(read.getOverallCoveredConditionsByLineList()).hasSize(2); + + InputStream inputStream = new BufferedInputStream(new FileInputStream(file)); + BatchReport.Coverage read = BatchReport.Coverage.PARSER.parseDelimitedFrom(inputStream); + assertThat(read.getLine()).isEqualTo(1); + assertThat(read.getConditions()).isEqualTo(1); + assertThat(read.getUtHits()).isTrue(); + assertThat(read.getItHits()).isFalse(); + assertThat(read.getUtCoveredConditions()).isEqualTo(1); + assertThat(read.getItCoveredConditions()).isEqualTo(1); + assertThat(read.getOverallCoveredConditions()).isEqualTo(1); + + read = BatchReport.Coverage.PARSER.parseDelimitedFrom(inputStream); + assertThat(read.getLine()).isEqualTo(2); + assertThat(read.getConditions()).isEqualTo(5); + assertThat(read.getUtHits()).isFalse(); + assertThat(read.getItHits()).isFalse(); + assertThat(read.getUtCoveredConditions()).isEqualTo(4); + assertThat(read.getItCoveredConditions()).isEqualTo(5); + assertThat(read.getOverallCoveredConditions()).isEqualTo(5); } } -- cgit v1.2.3