Convert DeleteReviewer to use BatchUpdate

Change-Id: I31d71fd8cb44554c43bb3f0f06dee5a0f08ea807
Signed-off-by: Edwin Kempin <ekempin@google.com>
This commit is contained in:
Edwin Kempin
2016-02-15 15:31:18 +01:00
parent 88951509a6
commit f8fc548fb8

View File

@@ -21,10 +21,11 @@ import com.google.gerrit.common.TimeUtil;
import com.google.gerrit.extensions.restapi.AuthException; import com.google.gerrit.extensions.restapi.AuthException;
import com.google.gerrit.extensions.restapi.ResourceNotFoundException; import com.google.gerrit.extensions.restapi.ResourceNotFoundException;
import com.google.gerrit.extensions.restapi.Response; import com.google.gerrit.extensions.restapi.Response;
import com.google.gerrit.extensions.restapi.RestApiException;
import com.google.gerrit.extensions.restapi.RestModifyView; import com.google.gerrit.extensions.restapi.RestModifyView;
import com.google.gerrit.reviewdb.client.Account; import com.google.gerrit.reviewdb.client.Account;
import com.google.gerrit.reviewdb.client.Change;
import com.google.gerrit.reviewdb.client.ChangeMessage; import com.google.gerrit.reviewdb.client.ChangeMessage;
import com.google.gerrit.reviewdb.client.PatchSet;
import com.google.gerrit.reviewdb.client.PatchSetApproval; import com.google.gerrit.reviewdb.client.PatchSetApproval;
import com.google.gerrit.reviewdb.server.ReviewDb; import com.google.gerrit.reviewdb.server.ReviewDb;
import com.google.gerrit.server.ApprovalsUtil; import com.google.gerrit.server.ApprovalsUtil;
@@ -32,15 +33,15 @@ import com.google.gerrit.server.ChangeMessagesUtil;
import com.google.gerrit.server.ChangeUtil; import com.google.gerrit.server.ChangeUtil;
import com.google.gerrit.server.IdentifiedUser; import com.google.gerrit.server.IdentifiedUser;
import com.google.gerrit.server.change.DeleteReviewer.Input; import com.google.gerrit.server.change.DeleteReviewer.Input;
import com.google.gerrit.server.index.ChangeIndexer; import com.google.gerrit.server.git.BatchUpdate;
import com.google.gerrit.server.git.BatchUpdate.ChangeContext;
import com.google.gerrit.server.git.UpdateException;
import com.google.gerrit.server.notedb.ChangeUpdate; import com.google.gerrit.server.notedb.ChangeUpdate;
import com.google.gerrit.server.project.ChangeControl;
import com.google.gwtorm.server.OrmException; import com.google.gwtorm.server.OrmException;
import com.google.inject.Inject; import com.google.inject.Inject;
import com.google.inject.Provider; import com.google.inject.Provider;
import com.google.inject.Singleton; import com.google.inject.Singleton;
import java.io.IOException;
import java.util.List; import java.util.List;
@Singleton @Singleton
@@ -49,44 +50,55 @@ public class DeleteReviewer implements RestModifyView<ReviewerResource, Input> {
} }
private final Provider<ReviewDb> dbProvider; private final Provider<ReviewDb> dbProvider;
private final ChangeUpdate.Factory updateFactory;
private final ApprovalsUtil approvalsUtil; private final ApprovalsUtil approvalsUtil;
private final ChangeMessagesUtil cmUtil; private final ChangeMessagesUtil cmUtil;
private final ChangeIndexer indexer; private final BatchUpdate.Factory batchUpdateFactory;
private final IdentifiedUser.GenericFactory userFactory; private final IdentifiedUser.GenericFactory userFactory;
@Inject @Inject
DeleteReviewer(Provider<ReviewDb> dbProvider, DeleteReviewer(Provider<ReviewDb> dbProvider,
ChangeUpdate.Factory updateFactory,
ApprovalsUtil approvalsUtil, ApprovalsUtil approvalsUtil,
ChangeMessagesUtil cmUtil, ChangeMessagesUtil cmUtil,
ChangeIndexer indexer, BatchUpdate.Factory batchUpdateFactory,
IdentifiedUser.GenericFactory userFactory) { IdentifiedUser.GenericFactory userFactory) {
this.dbProvider = dbProvider; this.dbProvider = dbProvider;
this.updateFactory = updateFactory;
this.approvalsUtil = approvalsUtil; this.approvalsUtil = approvalsUtil;
this.cmUtil = cmUtil; this.cmUtil = cmUtil;
this.indexer = indexer; this.batchUpdateFactory = batchUpdateFactory;
this.userFactory = userFactory; this.userFactory = userFactory;
} }
@Override @Override
public Response<?> apply(ReviewerResource rsrc, Input input) public Response<?> apply(ReviewerResource rsrc, Input input)
throws AuthException, ResourceNotFoundException, OrmException, throws RestApiException, UpdateException {
IOException { try (BatchUpdate bu = batchUpdateFactory.create(dbProvider.get(),
ChangeControl control = rsrc.getControl(); rsrc.getChangeResource().getProject(),
Change.Id changeId = rsrc.getChangeId(); rsrc.getChangeResource().getUser(), TimeUtil.nowTs())) {
ReviewDb db = dbProvider.get(); Op op = new Op(rsrc.getReviewerUser().getAccountId());
ChangeUpdate update = updateFactory.create(rsrc.getControl()); bu.addOp(rsrc.getChange().getId(), op);
bu.execute();
}
return Response.none();
}
private class Op extends BatchUpdate.Op {
private final Account.Id reviewerId;
Op(Account.Id reviewerId) {
this.reviewerId = reviewerId;
}
@Override
public boolean updateChange(ChangeContext ctx)
throws AuthException, ResourceNotFoundException, OrmException {
PatchSet.Id currPs = ctx.getChange().currentPatchSetId();
StringBuilder msg = new StringBuilder(); StringBuilder msg = new StringBuilder();
db.changes().beginTransaction(changeId);
try {
List<PatchSetApproval> del = Lists.newArrayList(); List<PatchSetApproval> del = Lists.newArrayList();
for (PatchSetApproval a : approvals(db, rsrc)) { for (PatchSetApproval a : approvals(ctx, reviewerId)) {
if (control.canRemoveReviewer(a)) { if (ctx.getControl().canRemoveReviewer(a)) {
del.add(a); del.add(a);
if (a.getPatchSetId().equals(control.getChange().currentPatchSetId()) if (a.getPatchSetId().equals(currPs)
&& a.getValue() != 0) { && a.getValue() != 0) {
if (msg.length() == 0) { if (msg.length() == 0) {
msg.append("Removed the following votes:\n\n"); msg.append("Removed the following votes:\n\n");
@@ -103,48 +115,40 @@ public class DeleteReviewer implements RestModifyView<ReviewerResource, Input> {
if (del.isEmpty()) { if (del.isEmpty()) {
throw new ResourceNotFoundException(); throw new ResourceNotFoundException();
} }
ChangeUtil.bumpRowVersionNotLastUpdatedOn(rsrc.getChangeId(), db); ctx.getDb().patchSetApprovals().delete(del);
db.patchSetApprovals().delete(del); ChangeUpdate update = ctx.getUpdate(currPs);
update.removeReviewer(rsrc.getReviewerUser().getAccountId()); update.removeReviewer(reviewerId);
if (msg.length() > 0) { if (msg.length() > 0) {
ChangeMessage changeMessage = ChangeMessage changeMessage =
new ChangeMessage(new ChangeMessage.Key(rsrc.getChangeId(), new ChangeMessage(new ChangeMessage.Key(ctx.getChange().getId(),
ChangeUtil.messageUUID(db)), ChangeUtil.messageUUID(ctx.getDb())),
control.getUser().getAccountId(), ctx.getUser().getAccountId(),
TimeUtil.nowTs(), rsrc.getChange().currentPatchSetId()); TimeUtil.nowTs(), currPs);
changeMessage.setMessage(msg.toString()); changeMessage.setMessage(msg.toString());
cmUtil.addChangeMessage(db, update, changeMessage); cmUtil.addChangeMessage(ctx.getDb(), update, changeMessage);
}
return true;
} }
db.commit(); private Iterable<PatchSetApproval> approvals(ChangeContext ctx,
} finally { final Account.Id accountId) throws OrmException {
db.rollback(); return Iterables.filter(
approvalsUtil.byChange(ctx.getDb(), ctx.getNotes()).values(),
new Predicate<PatchSetApproval>() {
@Override
public boolean apply(PatchSetApproval input) {
return accountId.equals(input.getAccountId());
} }
update.commit(); });
indexer.index(db, rsrc.getChange());
return Response.none();
} }
private static String formatLabelValue(short value) { private String formatLabelValue(short value) {
if (value > 0) { if (value > 0) {
return "+" + value; return "+" + value;
} else { } else {
return Short.toString(value); return Short.toString(value);
} }
} }
private Iterable<PatchSetApproval> approvals(ReviewDb db,
ReviewerResource rsrc) throws OrmException {
final Account.Id user = rsrc.getReviewerUser().getAccountId();
return Iterables.filter(
approvalsUtil.byChange(db, rsrc.getChangeResource().getNotes())
.values(),
new Predicate<PatchSetApproval>() {
@Override
public boolean apply(PatchSetApproval input) {
return user.equals(input.getAccountId());
}
});
} }
} }