Revision API: Implement methods to get / set review status
Change-Id: If68c43e94acdfcffd7b41e78179f5b2e3f83db48
This commit is contained in:
parent
3e740622b6
commit
0f126e562c
@ -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 {
|
||||||
|
@ -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())
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user