Allow running tasks to be cancelled
[MAILPOET-5755]
This commit is contained in:
committed by
Ján Mikláš
parent
b8ca544596
commit
ef2101ef46
@@ -51,7 +51,7 @@ class HelpTest extends \MailPoetTest {
|
||||
$response = $this->endpoint->cancelTask(['id' => $task->getId()]);
|
||||
verify($response)->instanceOf('\MailPoet\API\JSON\ErrorResponse');
|
||||
verify($response->status)->equals(400);
|
||||
verify($response->errors[0]['message'])->equals('Only scheduled tasks can be cancelled');
|
||||
verify($response->errors[0]['message'])->equals('Only scheduled and running tasks can be cancelled');
|
||||
}
|
||||
|
||||
public function testItReturnsErrorWhenReschedulingCompletedTask() {
|
||||
@@ -62,7 +62,7 @@ class HelpTest extends \MailPoetTest {
|
||||
verify($response->errors[0]['message'])->equals('Only cancelled tasks can be rescheduled');
|
||||
}
|
||||
|
||||
public function testItCanCancelTask() {
|
||||
public function testItCanCancelScheduledTask() {
|
||||
$task = (new ScheduledTaskFactory())->create('sending', ScheduledTaskEntity::STATUS_SCHEDULED, new \DateTime());
|
||||
$response = $this->endpoint->cancelTask(['id' => $task->getId()]);
|
||||
verify($response)->instanceOf(APIResponse::class);
|
||||
@@ -77,6 +77,21 @@ class HelpTest extends \MailPoetTest {
|
||||
}
|
||||
}
|
||||
|
||||
public function testItCanCancelRunningTask() {
|
||||
$task = (new ScheduledTaskFactory())->create('sending', null, new \DateTime());
|
||||
$response = $this->endpoint->cancelTask(['id' => $task->getId()]);
|
||||
verify($response)->instanceOf(APIResponse::class);
|
||||
verify($response->status)->equals(200);
|
||||
|
||||
$task = $this->scheduledTasksRepository->findOneById($task->getId());
|
||||
verify($task)->instanceOf(ScheduledTaskEntity::class);
|
||||
if ($task) {
|
||||
verify($task->getStatus())->equals(ScheduledTaskEntity::STATUS_CANCELLED);
|
||||
verify($task->getCancelledAt())->notNull();
|
||||
verify($task->getInProgress())->equals(0);
|
||||
}
|
||||
}
|
||||
|
||||
public function testItCanRescheduleTask() {
|
||||
$task = (new ScheduledTaskFactory())->create('sending', ScheduledTaskEntity::STATUS_CANCELLED, new \DateTime());
|
||||
$response = $this->endpoint->rescheduleTask(['id' => $task->getId()]);
|
||||
|
Reference in New Issue
Block a user