Merge "Determine submittability on the server side"

This commit is contained in:
David Pursehouse 2015-08-04 02:03:58 +00:00 committed by Gerrit Code Review
commit 33a904468d
5 changed files with 22 additions and 10 deletions

View File

@ -35,6 +35,7 @@ public class ChangeInfo {
public Boolean starred; public Boolean starred;
public Boolean reviewed; public Boolean reviewed;
public Boolean mergeable; public Boolean mergeable;
public Boolean submittable;
public Integer insertions; public Integer insertions;
public Integer deletions; public Integer deletions;

View File

@ -107,7 +107,6 @@ public class ChangeInfo extends JavaScriptObject {
public final native LabelInfo label(String n) /*-{ return this.labels[n]; }-*/; public final native LabelInfo label(String n) /*-{ return this.labels[n]; }-*/;
public final native String currentRevision() /*-{ return this.current_revision; }-*/; public final native String currentRevision() /*-{ return this.current_revision; }-*/;
public final native void setCurrentRevision(String r) /*-{ this.current_revision = r; }-*/; public final native void setCurrentRevision(String r) /*-{ this.current_revision = r; }-*/;
private final native void setSubmittable(boolean x) /*-{ this.submittable = x; }-*/;
public final native NativeMap<RevisionInfo> revisions() /*-{ return this.revisions; }-*/; public final native NativeMap<RevisionInfo> revisions() /*-{ return this.revisions; }-*/;
public final native RevisionInfo revision(String n) /*-{ return this.revisions[n]; }-*/; public final native RevisionInfo revision(String n) /*-{ return this.revisions[n]; }-*/;
public final native JsArray<MessageInfo> messages() /*-{ return this.messages; }-*/; public final native JsArray<MessageInfo> messages() /*-{ return this.messages; }-*/;
@ -135,7 +134,6 @@ public class ChangeInfo extends JavaScriptObject {
public final boolean submittable() { public final boolean submittable() {
init(); init();
getMissingLabelIndex();
return _submittable(); return _submittable();
} }
@ -143,8 +141,6 @@ public class ChangeInfo extends JavaScriptObject {
/*-{ return this.submittable ? true : false; }-*/; /*-{ return this.submittable ? true : false; }-*/;
/** /**
* As a side effect this.submittable is evaluated and set accordingly.
*
* @return the index of the missing label or -1 * @return the index of the missing label or -1
* if no label is missing, or if more than one label is missing. * if no label is missing, or if more than one label is missing.
*/ */
@ -168,7 +164,6 @@ public class ChangeInfo extends JavaScriptObject {
if (ret != -1) { if (ret != -1) {
// more than one label is missing, so it's unclear which to quick // more than one label is missing, so it's unclear which to quick
// approve, return -1 // approve, return -1
setSubmittable(false);
return -1; return -1;
} else { } else {
ret = i; ret = i;
@ -181,11 +176,9 @@ public class ChangeInfo extends JavaScriptObject {
case REJECT: // Submit cannot happen, do not quick approve. case REJECT: // Submit cannot happen, do not quick approve.
case IMPOSSIBLE: case IMPOSSIBLE:
setSubmittable(false);
return -1; return -1;
} }
} }
setSubmittable(ret == -1);
return ret; return ret;
} }

View File

@ -137,6 +137,7 @@ public class ChangeJson {
private final GitRepositoryManager repoManager; private final GitRepositoryManager repoManager;
private final ProjectCache projectCache; private final ProjectCache projectCache;
private final MergeUtil.Factory mergeUtilFactory; private final MergeUtil.Factory mergeUtilFactory;
private final Submit submit;
private final IdentifiedUser.GenericFactory userFactory; private final IdentifiedUser.GenericFactory userFactory;
private final ChangeData.Factory changeDataFactory; private final ChangeData.Factory changeDataFactory;
private final FileInfoJson fileInfoJson; private final FileInfoJson fileInfoJson;
@ -161,6 +162,7 @@ public class ChangeJson {
GitRepositoryManager repoManager, GitRepositoryManager repoManager,
ProjectCache projectCache, ProjectCache projectCache,
MergeUtil.Factory mergeUtilFactory, MergeUtil.Factory mergeUtilFactory,
Submit submit,
IdentifiedUser.GenericFactory uf, IdentifiedUser.GenericFactory uf,
ChangeData.Factory cdf, ChangeData.Factory cdf,
FileInfoJson fileInfoJson, FileInfoJson fileInfoJson,
@ -180,6 +182,7 @@ public class ChangeJson {
this.repoManager = repoManager; this.repoManager = repoManager;
this.userFactory = uf; this.userFactory = uf;
this.projectCache = projectCache; this.projectCache = projectCache;
this.submit = submit;
this.mergeUtilFactory = mergeUtilFactory; this.mergeUtilFactory = mergeUtilFactory;
this.fileInfoJson = fileInfoJson; this.fileInfoJson = fileInfoJson;
this.accountLoaderFactory = ailf; this.accountLoaderFactory = ailf;
@ -383,6 +386,7 @@ public class ChangeJson {
// the response and avoid making a request to /submit_type from the UI. // the response and avoid making a request to /submit_type from the UI.
out.mergeable = in.getStatus() == Change.Status.MERGED out.mergeable = in.getStatus() == Change.Status.MERGED
? null : cd.isMergeable(); ? null : cd.isMergeable();
out.submittable = submit.submittable(cd);
ChangedLines changedLines = cd.changedLines(); ChangedLines changedLines = cd.changedLines();
if (changedLines != null) { if (changedLines != null) {
out.insertions = changedLines.insertions; out.insertions = changedLines.insertions;

View File

@ -248,6 +248,22 @@ public class Submit implements RestModifyView<RevisionResource, SubmitInput>,
return null; return null;
} }
/**
* Check if there are any problems with the given change. It doesn't take
* any problems of related changes into account.
* <p>
* @param cd the change to check for submittability
* @return if the change has any problems for submission
*/
public boolean submittable(ChangeData cd) {
try {
MergeOp.checkSubmitRule(cd);
return true;
} catch (ResourceConflictException | OrmException e) {
return false;
}
}
@Override @Override
public UiAction.Description getDescription(RevisionResource resource) { public UiAction.Description getDescription(RevisionResource resource) {
PatchSet.Id current = resource.getChange().currentPatchSetId(); PatchSet.Id current = resource.getChange().currentPatchSetId();

View File

@ -64,9 +64,7 @@ public class SubmittedTogether implements RestReadView<ChangeResource> {
if (cs.ids().size() > 1) { if (cs.ids().size() > 1) {
return json.create(EnumSet.of( return json.create(EnumSet.of(
ListChangesOption.CURRENT_REVISION, ListChangesOption.CURRENT_REVISION,
ListChangesOption.CURRENT_COMMIT, ListChangesOption.CURRENT_COMMIT))
ListChangesOption.DETAILED_LABELS,
ListChangesOption.LABELS))
.format(cs.ids()); .format(cs.ids());
} else { } else {
return Collections.emptyList(); return Collections.emptyList();