InlineEdit: Add POST /changes/<id>/publish_edit REST endpoint
Add REST endpoint to publish change edit. Change-Id: Ifd3203539b00ec2a7b60734d501b6ae0790e73f9
This commit is contained in:
@@ -1295,6 +1295,26 @@ specified file was deleted in the change edit "`204 No Content`" is returned.
|
|||||||
RnJvbSA3ZGFkY2MxNTNmZGVhMTdhYTg0ZmYzMmE2ZTI0NWRiYjY...
|
RnJvbSA3ZGFkY2MxNTNmZGVhMTdhYTg0ZmYzMmE2ZTI0NWRiYjY...
|
||||||
----
|
----
|
||||||
|
|
||||||
|
[[publish-edit]]
|
||||||
|
=== Publish Change Edit
|
||||||
|
--
|
||||||
|
'POST /changes/link:#change-id[\{change-id\}]/publish_edit
|
||||||
|
--
|
||||||
|
|
||||||
|
Promotes change edit to a regular patch set.
|
||||||
|
|
||||||
|
.Request
|
||||||
|
----
|
||||||
|
POST /changes/myProject~master~I8473b95934b5732ac55d26311a706c9c2bde9940/publish_edit HTTP/1.0
|
||||||
|
----
|
||||||
|
|
||||||
|
As response "`204 No Content`" is returned.
|
||||||
|
|
||||||
|
.Response
|
||||||
|
----
|
||||||
|
HTTP/1.1 204 No Content
|
||||||
|
----
|
||||||
|
|
||||||
[[reviewer-endpoints]]
|
[[reviewer-endpoints]]
|
||||||
== Reviewer Endpoints
|
== Reviewer Endpoints
|
||||||
|
|
||||||
|
|||||||
@@ -167,6 +167,27 @@ public class ChangeEditIT extends AbstractDaemonTest {
|
|||||||
assertFalse(editUtil.byChange(change).isPresent());
|
assertFalse(editUtil.byChange(change).isPresent());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void publishEditRest() throws Exception {
|
||||||
|
PatchSet oldCurrentPatchSet = getCurrentPatchSet(changeId);
|
||||||
|
assertEquals(RefUpdate.Result.NEW,
|
||||||
|
modifier.createEdit(
|
||||||
|
change,
|
||||||
|
oldCurrentPatchSet));
|
||||||
|
assertEquals(RefUpdate.Result.FORCED,
|
||||||
|
modifier.modifyFile(
|
||||||
|
editUtil.byChange(change).get(),
|
||||||
|
FILE_NAME,
|
||||||
|
CONTENT_NEW));
|
||||||
|
Optional<ChangeEdit> edit = editUtil.byChange(change);
|
||||||
|
RestResponse r = session.post(urlPublish());
|
||||||
|
assertEquals(SC_NO_CONTENT, r.getStatusCode());
|
||||||
|
edit = editUtil.byChange(change);
|
||||||
|
assertFalse(edit.isPresent());
|
||||||
|
PatchSet newCurrentPatchSet = getCurrentPatchSet(changeId);
|
||||||
|
assertFalse(oldCurrentPatchSet.getId().equals(newCurrentPatchSet.getId()));
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void rebaseEdit() throws Exception {
|
public void rebaseEdit() throws Exception {
|
||||||
assertEquals(RefUpdate.Result.NEW,
|
assertEquals(RefUpdate.Result.NEW,
|
||||||
@@ -585,6 +606,12 @@ public class ChangeEditIT extends AbstractDaemonTest {
|
|||||||
+ FILE_NAME;
|
+ FILE_NAME;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private String urlPublish() {
|
||||||
|
return "/changes/"
|
||||||
|
+ change.getChangeId()
|
||||||
|
+ "/publish_edit";
|
||||||
|
}
|
||||||
|
|
||||||
private EditInfo toEditInfo() throws IOException {
|
private EditInfo toEditInfo() throws IOException {
|
||||||
RestResponse r = session.get(urlEdit());
|
RestResponse r = session.get(urlEdit());
|
||||||
assertEquals(SC_OK, r.getStatusCode());
|
assertEquals(SC_OK, r.getStatusCode());
|
||||||
|
|||||||
@@ -102,6 +102,7 @@ public class Module extends RestApiModule {
|
|||||||
get(FILE_KIND, "diff").to(GetDiff.class);
|
get(FILE_KIND, "diff").to(GetDiff.class);
|
||||||
|
|
||||||
child(CHANGE_KIND, "edit").to(ChangeEdits.class);
|
child(CHANGE_KIND, "edit").to(ChangeEdits.class);
|
||||||
|
child(CHANGE_KIND, "publish_edit").to(PublishChangeEdit.class);
|
||||||
put(CHANGE_EDIT_KIND, "/").to(ChangeEdits.Put.class);
|
put(CHANGE_EDIT_KIND, "/").to(ChangeEdits.Put.class);
|
||||||
delete(CHANGE_EDIT_KIND).to(ChangeEdits.DeleteContent.class);
|
delete(CHANGE_EDIT_KIND).to(ChangeEdits.DeleteContent.class);
|
||||||
get(CHANGE_EDIT_KIND, "/").to(ChangeEdits.Get.class);
|
get(CHANGE_EDIT_KIND, "/").to(ChangeEdits.Get.class);
|
||||||
|
|||||||
@@ -0,0 +1,99 @@
|
|||||||
|
// Copyright (C) 2014 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.server.change;
|
||||||
|
|
||||||
|
import com.google.common.base.Optional;
|
||||||
|
import com.google.gerrit.extensions.registration.DynamicMap;
|
||||||
|
import com.google.gerrit.extensions.restapi.AcceptsPost;
|
||||||
|
import com.google.gerrit.extensions.restapi.AuthException;
|
||||||
|
import com.google.gerrit.extensions.restapi.ChildCollection;
|
||||||
|
import com.google.gerrit.extensions.restapi.IdString;
|
||||||
|
import com.google.gerrit.extensions.restapi.ResourceConflictException;
|
||||||
|
import com.google.gerrit.extensions.restapi.ResourceNotFoundException;
|
||||||
|
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.RestView;
|
||||||
|
import com.google.gerrit.server.edit.ChangeEdit;
|
||||||
|
import com.google.gerrit.server.edit.ChangeEditUtil;
|
||||||
|
import com.google.gerrit.server.project.InvalidChangeOperationException;
|
||||||
|
import com.google.gerrit.server.project.NoSuchChangeException;
|
||||||
|
import com.google.gwtorm.server.OrmException;
|
||||||
|
import com.google.inject.Inject;
|
||||||
|
import com.google.inject.Singleton;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
@Singleton
|
||||||
|
public class PublishChangeEdit implements
|
||||||
|
ChildCollection<ChangeResource, ChangeEditResource>,
|
||||||
|
AcceptsPost<ChangeResource> {
|
||||||
|
|
||||||
|
private final Publish publish;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
PublishChangeEdit(Publish publish) {
|
||||||
|
this.publish = publish;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public DynamicMap<RestView<ChangeEditResource>> views() {
|
||||||
|
throw new IllegalStateException("not yet implemented");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public RestView<ChangeResource> list() {
|
||||||
|
throw new IllegalStateException("not yet implemented");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ChangeEditResource parse(ChangeResource parent, IdString id)
|
||||||
|
throws ResourceNotFoundException, Exception {
|
||||||
|
throw new IllegalStateException("not yet implemented");
|
||||||
|
}
|
||||||
|
|
||||||
|
@SuppressWarnings("unchecked")
|
||||||
|
@Override
|
||||||
|
public Publish post(ChangeResource parent) throws RestApiException {
|
||||||
|
return publish;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Singleton
|
||||||
|
public static class Publish implements RestModifyView<ChangeResource, Publish.Input> {
|
||||||
|
public static class Input {
|
||||||
|
}
|
||||||
|
|
||||||
|
private final ChangeEditUtil editUtil;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
Publish(ChangeEditUtil editUtil) {
|
||||||
|
this.editUtil = editUtil;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Response<?> apply(ChangeResource rsrc, Publish.Input in)
|
||||||
|
throws AuthException, ResourceConflictException, NoSuchChangeException,
|
||||||
|
IOException, InvalidChangeOperationException, OrmException {
|
||||||
|
Optional<ChangeEdit> edit = editUtil.byChange(rsrc.getChange());
|
||||||
|
if (!edit.isPresent()) {
|
||||||
|
throw new ResourceConflictException(String.format(
|
||||||
|
"no edit exists for change %s",
|
||||||
|
rsrc.getChange().getChangeId()));
|
||||||
|
}
|
||||||
|
editUtil.publish(edit.get());
|
||||||
|
return Response.none();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user