Files
cloudron-box/src/routes/test/tasks-test.js
T

117 lines
4.4 KiB
JavaScript
Raw Normal View History

2018-12-10 21:42:03 -08:00
'use strict';
/* global it:false */
/* global describe:false */
/* global before:false */
/* global after:false */
2021-07-12 23:35:30 -07:00
const common = require('./common.js'),
2018-12-10 21:42:03 -08:00
expect = require('expect.js'),
superagent = require('superagent'),
tasks = require('../../tasks.js');
describe('Tasks API', function () {
2021-07-12 23:35:30 -07:00
const { setup, cleanup, serverUrl, owner } = common;
2018-12-10 21:42:03 -08:00
before(setup);
after(cleanup);
2021-07-12 23:35:30 -07:00
it('can get task', async function () {
const taskId = await tasks.add(tasks._TASK_IDENTITY, [ 'ping' ]);
return new Promise((resolve) => {
tasks.startTask(taskId, {}, async function () {
const response = await superagent.get(`${serverUrl}/api/v1/tasks/${taskId}`)
.query({ access_token: owner.token });
expect(response.statusCode).to.equal(200);
expect(response.body.percent).to.be(100);
expect(response.body.args).to.be(undefined);
expect(response.body.active).to.be(false); // finished
expect(response.body.success).to.be(true);
expect(response.body.result).to.be('ping');
expect(response.body.error).to.be(null);
resolve();
2019-08-27 22:39:59 -07:00
});
2018-12-10 21:42:03 -08:00
});
});
2021-07-12 23:35:30 -07:00
it('can get logs', async function () {
const taskId = await tasks.add(tasks._TASK_CRASH, [ 'ping' ]);
return new Promise((resolve) => {
tasks.startTask(taskId, {}, async function () {
const response = await superagent.get(`${serverUrl}/api/v1/tasks/${taskId}/logs`)
.query({ access_token: owner.token });
expect(response.statusCode).to.equal(200);
resolve();
2019-08-27 22:39:59 -07:00
});
2018-12-10 21:42:03 -08:00
});
});
2021-07-12 23:35:30 -07:00
it('cannot stop inactive task', async function () {
const taskId = await tasks.add(tasks._TASK_IDENTITY, [ 'ping' ]);
return new Promise((resolve) => {
tasks.startTask(taskId, {}, async function () {
const response = await superagent.post(`${serverUrl}/api/v1/tasks/${taskId}/stop`)
.query({ access_token: owner.token })
.ok(() => true);
expect(response.statusCode).to.equal(409);
resolve();
2019-08-27 22:39:59 -07:00
});
2018-12-10 21:42:03 -08:00
});
});
2021-07-12 23:35:30 -07:00
it('can stop task', async function () {
const taskId = await tasks.add(tasks._TASK_SLEEP, [ 10000 ]);
return new Promise((resolve) => {
tasks.startTask(taskId, {}, async function () {
const response = await superagent.get(`${serverUrl}/api/v1/tasks/${taskId}`)
.query({ access_token: owner.token });
expect(response.statusCode).to.equal(200);
expect(response.body.percent).to.be(100);
expect(response.body.active).to.be(false); // finished
expect(response.body.success).to.be(false);
expect(response.body.result).to.be(null);
expect(response.body.error.message).to.contain('stopped');
resolve();
2019-08-27 22:39:59 -07:00
});
2021-07-12 23:35:30 -07:00
setTimeout(async function () {
const response = await superagent.post(`${serverUrl}/api/v1/tasks/${taskId}/stop`)
.query({ access_token: owner.token });
expect(response.statusCode).to.equal(204);
2019-08-27 22:39:59 -07:00
}, 100);
2018-12-10 21:42:03 -08:00
});
});
2018-12-13 13:12:45 -08:00
2021-07-12 23:35:30 -07:00
it('can list tasks', async function () {
const taskId = await tasks.add(tasks._TASK_IDENTITY, [ 'ping' ]);
return new Promise((resolve) => {
tasks.startTask(taskId, {}, async function () {
const response = await superagent.get(`${serverUrl}/api/v1/tasks?type=${tasks._TASK_IDENTITY}`)
.query({ access_token: owner.token });
expect(response.statusCode).to.equal(200);
expect(response.body.tasks.length >= 1).to.be(true);
expect(response.body.tasks[0].id).to.be(taskId);
expect(response.body.tasks[0].percent).to.be(100);
expect(response.body.tasks[0].args).to.be(undefined);
expect(response.body.tasks[0].active).to.be(false); // finished
expect(response.body.tasks[0].success).to.be(true); // finished
expect(response.body.tasks[0].result).to.be('ping');
expect(response.body.tasks[0].error).to.be(null);
resolve();
2019-08-27 22:39:59 -07:00
});
2018-12-13 13:12:45 -08:00
});
});
2018-12-10 21:42:03 -08:00
});