Revision API: Implement methods to get / set review status

Change-Id: If68c43e94acdfcffd7b41e78179f5b2e3f83db48
This commit is contained in:
David Ostrovsky 2014-05-29 22:31:35 +02:00 committed by David Ostrovsky
parent 3e740622b6
commit 0f126e562c
5 changed files with 92 additions and 7 deletions

View File

@ -56,7 +56,7 @@ import java.util.Set;
public class PushOneCommit { public class PushOneCommit {
public static final String SUBJECT = "test commit"; public static final String SUBJECT = "test commit";
static final String FILE_NAME = "a.txt"; public static final String FILE_NAME = "a.txt";
private static final String FILE_CONTENT = "some content"; private static final String FILE_CONTENT = "some content";
public interface Factory { public interface Factory {

View File

@ -14,9 +14,11 @@
package com.google.gerrit.acceptance.api.revision; package com.google.gerrit.acceptance.api.revision;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue; import static org.junit.Assert.assertTrue;
import com.google.common.collect.Iterables;
import com.google.gerrit.acceptance.AbstractDaemonTest; import com.google.gerrit.acceptance.AbstractDaemonTest;
import com.google.gerrit.acceptance.NoHttpd; import com.google.gerrit.acceptance.NoHttpd;
import com.google.gerrit.acceptance.PushOneCommit; import com.google.gerrit.acceptance.PushOneCommit;
@ -169,6 +171,36 @@ public class RevisionIT extends AbstractDaemonTest {
.canRebase()); .canRebase());
} }
@Test
public void setUnsetReviewedFlag() throws Exception {
PushOneCommit push = pushFactory.create(db, admin.getIdent());
PushOneCommit.Result r = push.to(git, "refs/for/master");
gApi.changes()
.id(r.getChangeId())
.current()
.setReviewed(PushOneCommit.FILE_NAME, true);
assertEquals(PushOneCommit.FILE_NAME,
Iterables.getOnlyElement(
gApi.changes()
.id(r.getChangeId())
.current()
.reviewed()));
gApi.changes()
.id(r.getChangeId())
.current()
.setReviewed(PushOneCommit.FILE_NAME, false);
assertTrue(
gApi.changes()
.id(r.getChangeId())
.current()
.reviewed()
.isEmpty());
}
protected RevisionApi revision(PushOneCommit.Result r) throws Exception { protected RevisionApi revision(PushOneCommit.Result r) throws Exception {
return gApi.changes() return gApi.changes()
.id(r.getChangeId()) .id(r.getChangeId())

View File

@ -14,6 +14,7 @@
package com.google.gerrit.server.api.changes; package com.google.gerrit.server.api.changes;
import com.google.common.collect.ImmutableSet;
import com.google.gerrit.common.errors.EmailException; import com.google.gerrit.common.errors.EmailException;
import com.google.gerrit.extensions.api.changes.ChangeApi; import com.google.gerrit.extensions.api.changes.ChangeApi;
import com.google.gerrit.extensions.api.changes.Changes; import com.google.gerrit.extensions.api.changes.Changes;
@ -21,12 +22,17 @@ import com.google.gerrit.extensions.api.changes.CherryPickInput;
import com.google.gerrit.extensions.api.changes.ReviewInput; import com.google.gerrit.extensions.api.changes.ReviewInput;
import com.google.gerrit.extensions.api.changes.RevisionApi; import com.google.gerrit.extensions.api.changes.RevisionApi;
import com.google.gerrit.extensions.api.changes.SubmitInput; import com.google.gerrit.extensions.api.changes.SubmitInput;
import com.google.gerrit.extensions.restapi.IdString;
import com.google.gerrit.extensions.restapi.RestApiException; import com.google.gerrit.extensions.restapi.RestApiException;
import com.google.gerrit.extensions.restapi.RestModifyView;
import com.google.gerrit.server.change.CherryPick; import com.google.gerrit.server.change.CherryPick;
import com.google.gerrit.server.change.DeleteDraftPatchSet; import com.google.gerrit.server.change.DeleteDraftPatchSet;
import com.google.gerrit.server.change.FileResource;
import com.google.gerrit.server.change.Files;
import com.google.gerrit.server.change.PostReview; import com.google.gerrit.server.change.PostReview;
import com.google.gerrit.server.change.Publish; import com.google.gerrit.server.change.Publish;
import com.google.gerrit.server.change.Rebase; import com.google.gerrit.server.change.Rebase;
import com.google.gerrit.server.change.Reviewed;
import com.google.gerrit.server.change.RevisionResource; import com.google.gerrit.server.change.RevisionResource;
import com.google.gerrit.server.change.Submit; import com.google.gerrit.server.change.Submit;
import com.google.gerrit.server.changedetail.RebaseChange; import com.google.gerrit.server.changedetail.RebaseChange;
@ -36,6 +42,7 @@ import com.google.inject.Provider;
import com.google.inject.assistedinject.Assisted; import com.google.inject.assistedinject.Assisted;
import java.io.IOException; import java.io.IOException;
import java.util.Set;
class RevisionApiImpl extends RevisionApi.NotImplemented implements RevisionApi { class RevisionApiImpl extends RevisionApi.NotImplemented implements RevisionApi {
interface Factory { interface Factory {
@ -49,7 +56,11 @@ class RevisionApiImpl extends RevisionApi.NotImplemented implements RevisionApi
private final RebaseChange rebaseChange; private final RebaseChange rebaseChange;
private final Submit submit; private final Submit submit;
private final Publish publish; private final Publish publish;
private final Reviewed.PutReviewed putReviewed;
private final Reviewed.DeleteReviewed deleteReviewed;
private final RevisionResource revision; private final RevisionResource revision;
private final Provider<Files> files;
private final Provider<Files.ListFiles> listFiles;
private final Provider<PostReview> review; private final Provider<PostReview> review;
@Inject @Inject
@ -60,6 +71,10 @@ class RevisionApiImpl extends RevisionApi.NotImplemented implements RevisionApi
RebaseChange rebaseChange, RebaseChange rebaseChange,
Submit submit, Submit submit,
Publish publish, Publish publish,
Reviewed.PutReviewed putReviewed,
Reviewed.DeleteReviewed deleteReviewed,
Provider<Files> files,
Provider<Files.ListFiles> listFiles,
Provider<PostReview> review, Provider<PostReview> review,
@Assisted RevisionResource r) { @Assisted RevisionResource r) {
this.changes = changes; this.changes = changes;
@ -70,6 +85,10 @@ class RevisionApiImpl extends RevisionApi.NotImplemented implements RevisionApi
this.review = review; this.review = review;
this.submit = submit; this.submit = submit;
this.publish = publish; this.publish = publish;
this.files = files;
this.putReviewed = putReviewed;
this.deleteReviewed = deleteReviewed;
this.listFiles = listFiles;
this.revision = r; this.revision = r;
} }
@ -138,4 +157,33 @@ class RevisionApiImpl extends RevisionApi.NotImplemented implements RevisionApi
throw new RestApiException("Cannot cherry pick", e); throw new RestApiException("Cannot cherry pick", e);
} }
} }
@Override
public void setReviewed(String path, boolean reviewed) throws RestApiException {
try {
RestModifyView<FileResource, Reviewed.Input> view;
if (reviewed) {
view = putReviewed;
} else {
view = deleteReviewed;
}
view.apply(
files.get().parse(revision, IdString.fromDecoded(path)),
new Reviewed.Input());
} catch (Exception e) {
throw new RestApiException("Cannot update reviewed flag", e);
}
}
@SuppressWarnings("unchecked")
@Override
public Set<String> reviewed() throws RestApiException {
try {
return ImmutableSet.copyOf((Iterable<String>) listFiles
.get().setReviewed(true)
.apply(revision).value());
} catch (OrmException e) {
throw new RestApiException("Cannot list reviewed files", e);
}
}
} }

View File

@ -59,7 +59,7 @@ import java.util.Set;
import java.util.SortedSet; import java.util.SortedSet;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
class Files implements ChildCollection<RevisionResource, FileResource> { public class Files implements ChildCollection<RevisionResource, FileResource> {
private final DynamicMap<RestView<FileResource>> views; private final DynamicMap<RestView<FileResource>> views;
private final Provider<ListFiles> list; private final Provider<ListFiles> list;
@ -85,7 +85,7 @@ class Files implements ChildCollection<RevisionResource, FileResource> {
return new FileResource(rev, id.get()); return new FileResource(rev, id.get());
} }
private static final class ListFiles implements RestReadView<RevisionResource> { public static final class ListFiles implements RestReadView<RevisionResource> {
private static final Logger log = LoggerFactory.getLogger(ListFiles.class); private static final Logger log = LoggerFactory.getLogger(ListFiles.class);
@Option(name = "--base", metaVar = "revision-id") @Option(name = "--base", metaVar = "revision-id")
@ -116,6 +116,11 @@ class Files implements ChildCollection<RevisionResource, FileResource> {
this.patchListCache = patchListCache; this.patchListCache = patchListCache;
} }
public ListFiles setReviewed(boolean r) {
this.reviewed = r;
return this;
}
@Override @Override
public Response<?> apply(RevisionResource resource) throws AuthException, public Response<?> apply(RevisionResource resource) throws AuthException,
BadRequestException, ResourceNotFoundException, OrmException { BadRequestException, ResourceNotFoundException, OrmException {

View File

@ -26,12 +26,12 @@ import com.google.inject.Singleton;
import java.util.Collections; import java.util.Collections;
class Reviewed { public class Reviewed {
static class Input { public static class Input {
} }
@Singleton @Singleton
static class PutReviewed implements RestModifyView<FileResource, Input> { public static class PutReviewed implements RestModifyView<FileResource, Input> {
private final Provider<ReviewDb> dbProvider; private final Provider<ReviewDb> dbProvider;
@Inject @Inject
@ -60,7 +60,7 @@ class Reviewed {
} }
@Singleton @Singleton
static class DeleteReviewed implements RestModifyView<FileResource, Input> { public static class DeleteReviewed implements RestModifyView<FileResource, Input> {
private final Provider<ReviewDb> dbProvider; private final Provider<ReviewDb> dbProvider;
@Inject @Inject