Merge "Comment: Expose when comment was parsed from legacy notes format"
This commit is contained in:
@@ -214,6 +214,12 @@ public class Comment {
|
|||||||
public String serverId;
|
public String serverId;
|
||||||
public boolean unresolved;
|
public boolean unresolved;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Whether the comment was parsed from a JSON representation (false) or the legacy custom notes
|
||||||
|
* format (true).
|
||||||
|
*/
|
||||||
|
public transient boolean legacyFormat;
|
||||||
|
|
||||||
public Comment(Comment c) {
|
public Comment(Comment c) {
|
||||||
this(
|
this(
|
||||||
new Key(c.key),
|
new Key(c.key),
|
||||||
|
@@ -80,7 +80,9 @@ class ChangeRevisionNote extends RevisionNote<Comment> {
|
|||||||
} else {
|
} else {
|
||||||
pushCert = null;
|
pushCert = null;
|
||||||
}
|
}
|
||||||
return noteUtil.parseNote(raw, p, changeId);
|
List<Comment> comments = noteUtil.parseNote(raw, p, changeId);
|
||||||
|
comments.forEach(c -> c.legacyFormat = true);
|
||||||
|
return comments;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean isJson(byte[] raw, int offset) {
|
private static boolean isJson(byte[] raw, int offset) {
|
||||||
|
@@ -16,6 +16,7 @@ package com.google.gerrit.acceptance.server.change;
|
|||||||
|
|
||||||
import static com.google.common.truth.Truth.assertThat;
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
import static com.google.common.truth.Truth8.assertThat;
|
import static com.google.common.truth.Truth8.assertThat;
|
||||||
|
import static com.google.common.truth.TruthJUnit.assume;
|
||||||
import static com.google.gerrit.acceptance.PushOneCommit.FILE_NAME;
|
import static com.google.gerrit.acceptance.PushOneCommit.FILE_NAME;
|
||||||
import static com.google.gerrit.acceptance.PushOneCommit.SUBJECT;
|
import static com.google.gerrit.acceptance.PushOneCommit.SUBJECT;
|
||||||
import static java.util.stream.Collectors.groupingBy;
|
import static java.util.stream.Collectors.groupingBy;
|
||||||
@@ -61,6 +62,7 @@ import java.io.IOException;
|
|||||||
import java.sql.Timestamp;
|
import java.sql.Timestamp;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
import java.util.Comparator;
|
import java.util.Comparator;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@@ -945,6 +947,23 @@ public class CommentsIT extends AbstractDaemonTest {
|
|||||||
assertThat(getChangeSortedComments(changeId)).hasSize(3);
|
assertThat(getChangeSortedComments(changeId)).hasSize(3);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void jsonCommentHasLegacyFormatFalse() throws Exception {
|
||||||
|
assume().that(notesMigration.readChanges()).isTrue();
|
||||||
|
assertThat(noteUtil.getWriteJson()).isTrue();
|
||||||
|
|
||||||
|
PushOneCommit.Result result = createChange();
|
||||||
|
Change.Id changeId = result.getChange().getId();
|
||||||
|
addComment(result.getChangeId(), "comment");
|
||||||
|
|
||||||
|
Collection<com.google.gerrit.reviewdb.client.Comment> comments =
|
||||||
|
notesFactory.createChecked(db, project, changeId).getComments().values();
|
||||||
|
assertThat(comments).hasSize(1);
|
||||||
|
com.google.gerrit.reviewdb.client.Comment comment = comments.iterator().next();
|
||||||
|
assertThat(comment.message).isEqualTo("comment");
|
||||||
|
assertThat(comment.legacyFormat).isFalse();
|
||||||
|
}
|
||||||
|
|
||||||
private List<CommentInfo> getChangeSortedComments(String changeId) throws Exception {
|
private List<CommentInfo> getChangeSortedComments(String changeId) throws Exception {
|
||||||
List<CommentInfo> comments = new ArrayList<>();
|
List<CommentInfo> comments = new ArrayList<>();
|
||||||
Map<String, List<CommentInfo>> commentsMap = getPublishedComments(changeId);
|
Map<String, List<CommentInfo>> commentsMap = getPublishedComments(changeId);
|
||||||
|
@@ -0,0 +1,76 @@
|
|||||||
|
// Copyright (C) 2017 The Android Open Source Project
|
||||||
|
//
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
package com.google.gerrit.acceptance.server.change;
|
||||||
|
|
||||||
|
import static com.google.common.truth.Truth.assertThat;
|
||||||
|
import static com.google.common.truth.TruthJUnit.assume;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableList;
|
||||||
|
import com.google.common.collect.ImmutableMap;
|
||||||
|
import com.google.gerrit.acceptance.AbstractDaemonTest;
|
||||||
|
import com.google.gerrit.acceptance.NoHttpd;
|
||||||
|
import com.google.gerrit.acceptance.PushOneCommit;
|
||||||
|
import com.google.gerrit.extensions.api.changes.ReviewInput;
|
||||||
|
import com.google.gerrit.extensions.api.changes.ReviewInput.CommentInput;
|
||||||
|
import com.google.gerrit.reviewdb.client.Change;
|
||||||
|
import com.google.gerrit.reviewdb.client.Comment;
|
||||||
|
import com.google.gerrit.server.notedb.ChangeNoteUtil;
|
||||||
|
import com.google.gerrit.testing.ConfigSuite;
|
||||||
|
import com.google.inject.Inject;
|
||||||
|
import java.util.Collection;
|
||||||
|
import org.eclipse.jgit.lib.Config;
|
||||||
|
import org.junit.Before;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@NoHttpd
|
||||||
|
public class LegacyCommentsIT extends AbstractDaemonTest {
|
||||||
|
@Inject private ChangeNoteUtil noteUtil;
|
||||||
|
|
||||||
|
@ConfigSuite.Default
|
||||||
|
public static Config writeJsonFalseConfig() {
|
||||||
|
Config c = new Config();
|
||||||
|
c.setBoolean("noteDb", null, "writeJson", false);
|
||||||
|
return c;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Before
|
||||||
|
public void setUp() {
|
||||||
|
setApiUser(user);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void legacyCommentHasLegacyFormatTrue() throws Exception {
|
||||||
|
assume().that(notesMigration.readChanges()).isTrue();
|
||||||
|
assertThat(noteUtil.getWriteJson()).isFalse();
|
||||||
|
|
||||||
|
PushOneCommit.Result result = createChange();
|
||||||
|
Change.Id changeId = result.getChange().getId();
|
||||||
|
|
||||||
|
CommentInput cin = new CommentInput();
|
||||||
|
cin.message = "comment";
|
||||||
|
cin.path = PushOneCommit.FILE_NAME;
|
||||||
|
|
||||||
|
ReviewInput rin = new ReviewInput();
|
||||||
|
rin.comments = ImmutableMap.of(cin.path, ImmutableList.of(cin));
|
||||||
|
gApi.changes().id(changeId.get()).current().review(rin);
|
||||||
|
|
||||||
|
Collection<Comment> comments =
|
||||||
|
notesFactory.createChecked(db, project, changeId).getComments().values();
|
||||||
|
assertThat(comments).hasSize(1);
|
||||||
|
Comment comment = comments.iterator().next();
|
||||||
|
assertThat(comment.message).isEqualTo("comment");
|
||||||
|
assertThat(comment.legacyFormat).isTrue();
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user