Merge "Add REST endpoint to kill a task"
This commit is contained in:
@@ -16,17 +16,18 @@ package com.google.gerrit.sshd.commands;
|
||||
|
||||
import com.google.gerrit.common.data.GlobalCapability;
|
||||
import com.google.gerrit.extensions.annotations.RequiresCapability;
|
||||
import com.google.gerrit.server.config.DeleteTask;
|
||||
import com.google.gerrit.server.config.TaskResource;
|
||||
import com.google.gerrit.server.git.WorkQueue;
|
||||
import com.google.gerrit.server.git.WorkQueue.Task;
|
||||
import com.google.gerrit.server.util.IdGenerator;
|
||||
import com.google.gerrit.sshd.AdminHighPriorityCommand;
|
||||
import com.google.gerrit.sshd.SshCommand;
|
||||
import com.google.inject.Inject;
|
||||
|
||||
import org.kohsuke.args4j.Argument;
|
||||
|
||||
import java.util.HashSet;
|
||||
import java.util.Set;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/** Kill a task in the work queue. */
|
||||
@AdminHighPriorityCommand
|
||||
@@ -35,25 +36,20 @@ final class KillCommand extends SshCommand {
|
||||
@Inject
|
||||
private WorkQueue workQueue;
|
||||
|
||||
private final Set<Integer> taskIds = new HashSet<>();
|
||||
@Inject
|
||||
private DeleteTask deleteTask;
|
||||
|
||||
@Argument(index = 0, multiValued = true, required = true, metaVar = "ID")
|
||||
void addTaskId(final String taskId) {
|
||||
int p = 0;
|
||||
while (p < taskId.length() - 1 && taskId.charAt(p) == '0') {
|
||||
p++;
|
||||
}
|
||||
taskIds.add((int) Long.parseLong(taskId.substring(p), 16));
|
||||
}
|
||||
private final List<String> taskIds = new ArrayList<>();
|
||||
|
||||
@Override
|
||||
protected void run() {
|
||||
for (final Integer id : taskIds) {
|
||||
final Task<?> task = workQueue.getTask(id);
|
||||
if (task != null) {
|
||||
task.cancel(true);
|
||||
} else {
|
||||
stderr.print("kill: " + IdGenerator.format(id) + ": No such task\n");
|
||||
for (String id : taskIds) {
|
||||
try {
|
||||
Task<?> task = workQueue.getTask((int) Long.parseLong(id, 16));
|
||||
deleteTask.apply(new TaskResource(task), null);
|
||||
} catch (NumberFormatException e) {
|
||||
stderr.print("kill: " + id + ": No such task\n");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user