org.sonar.ce.taskprocessor.CeWorker Maven / Gradle / Ivy
The newest version!
/*
* SonarQube
* Copyright (C) 2009-2018 SonarSource SA
* mailto:info AT sonarsource DOT com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
package org.sonar.ce.taskprocessor;
import java.util.concurrent.Callable;
import javax.annotation.Nullable;
import org.sonar.ce.queue.CeQueue;
import org.sonar.ce.queue.CeTask;
import org.sonar.ce.queue.CeTaskResult;
import org.sonar.db.ce.CeActivityDto;
/**
* Marker interface of the runnable in charge of polling the {@link CeQueue} and executing {@link CeTask}.
* {@link Callable#call()} returns a Boolean which is {@code true} when some a {@link CeTask} was processed,
* {@code false} otherwise.
*/
public interface CeWorker extends Callable {
enum Result {
/** Worker is disabled */
DISABLED,
/** Worker found no task to process */
NO_TASK,
/** Worker found a task and processed it (either successfully or not) */
TASK_PROCESSED
}
/**
* Position of the current CeWorker among all the running workers, starts with 0.
*/
int getOrdinal();
/**
* UUID of the current CeWorker.
*/
String getUUID();
/**
* Classes implementing will be called a task start and finishes executing.
* All classes implementing this interface are guaranted to be called for each event, even if another implementation
* failed when called.
*/
interface ExecutionListener {
/**
* Called when starting executing a {@link CeTask} (which means: after it's been picked for processing, but before
* the execution of the task by the {@link CeTaskProcessor#process(CeTask)}).
*/
void onStart(CeTask ceTask);
/**
* Called when the processing of the task is finished (which means: after it's been moved to history).
*/
void onEnd(CeTask ceTask, CeActivityDto.Status status, @Nullable CeTaskResult taskResult, @Nullable Throwable error);
}
}