Merge "Comment: Expose when comment was parsed from legacy notes format"

This commit is contained in:
Dave Borowitz
2017-12-22 12:42:58 +00:00
committed by Gerrit Code Review
4 changed files with 104 additions and 1 deletions

View File

@@ -214,6 +214,12 @@ public class Comment {
public String serverId;
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) {
this(
new Key(c.key),

View File

@@ -80,7 +80,9 @@ class ChangeRevisionNote extends RevisionNote<Comment> {
} else {
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) {

View File

@@ -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.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.SUBJECT;
import static java.util.stream.Collectors.groupingBy;
@@ -61,6 +62,7 @@ import java.io.IOException;
import java.sql.Timestamp;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
@@ -945,6 +947,23 @@ public class CommentsIT extends AbstractDaemonTest {
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 {
List<CommentInfo> comments = new ArrayList<>();
Map<String, List<CommentInfo>> commentsMap = getPublishedComments(changeId);

View File

@@ -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();
}
}