Files
nomad/ui/tests/unit/models/task-test.js
Phil Renaud 859087640a [ui] Simplify times in task events (#18595)
* Regexy time simplification in task events

* Oops, dont assume these are all task restart messages

* Update mirage to provide displayMessage instead of message

* Have a few acceptance tests look for .displayMessage instead of .message for equality now
2023-09-27 17:01:34 -04:00

154 lines
3.8 KiB
JavaScript

/**
* Copyright (c) HashiCorp, Inc.
* SPDX-License-Identifier: BUSL-1.1
*/
import { module, test } from 'qunit';
import { setupTest } from 'ember-qunit';
import { run } from '@ember/runloop';
module('Unit | Model | task', function (hooks) {
setupTest(hooks);
test("should expose mergedMeta as merged with the job's and task groups's meta", function (assert) {
assert.expect(8);
const job = run(() =>
this.owner.lookup('service:store').createRecord('job', {
name: 'example',
taskGroups: [
{
name: 'one',
meta: { a: 'b' },
tasks: [
{
name: 'task-one',
meta: { c: 'd' },
},
{
name: 'task-two',
},
{
name: 'task-three',
meta: null,
},
{
name: 'task-four',
meta: {},
},
],
},
{
name: 'two',
tasks: [
{
name: 'task-one',
meta: { c: 'd' },
},
{
name: 'task-two',
},
{
name: 'task-three',
meta: null,
},
{
name: 'task-four',
meta: {},
},
],
},
],
})
);
let tg = job.get('taskGroups').objectAt(0);
let expected = [{ a: 'b', c: 'd' }, { a: 'b' }, { a: 'b' }, { a: 'b' }];
expected.forEach((exp, i) => {
assert.deepEqual(
tg.get('tasks').objectAt(i).get('mergedMeta'),
exp,
'mergedMeta is merged with task meta'
);
});
tg = job.get('taskGroups').objectAt(1);
expected = [{ c: 'd' }, {}, {}, {}];
expected.forEach((exp, i) => {
assert.deepEqual(
tg.get('tasks').objectAt(i).get('mergedMeta'),
exp,
'mergedMeta is merged with job meta'
);
});
});
// Test that message comes back with proper time formatting
test('displayMessage shows simplified time', function (assert) {
assert.expect(5);
const longTaskEvent = run(() =>
this.owner.lookup('service:store').createRecord('task-event', {
displayMessage: 'Task restarting in 1h2m3.456s',
})
);
assert.equal(
longTaskEvent.get('message'),
'Task restarting in 1h2m3s',
'hour-specific displayMessage is simplified'
);
const mediumTaskEvent = run(() =>
this.owner.lookup('service:store').createRecord('task-event', {
displayMessage: 'Task restarting in 1m2.345s',
})
);
assert.equal(
mediumTaskEvent.get('message'),
'Task restarting in 1m2s',
'minute-specific displayMessage is simplified'
);
const shortTaskEvent = run(() =>
this.owner.lookup('service:store').createRecord('task-event', {
displayMessage: 'Task restarting in 1.234s',
})
);
assert.equal(
shortTaskEvent.get('message'),
'Task restarting in 1s',
'second-specific displayMessage is simplified'
);
const roundedTaskEvent = run(() =>
this.owner.lookup('service:store').createRecord('task-event', {
displayMessage: 'I bet I can knock this out in about 1.999s',
})
);
assert.equal(
roundedTaskEvent.get('message'),
'I bet I can knock this out in about 2s',
'displayMessage is rounded'
);
const timelessTaskEvent = run(() =>
this.owner.lookup('service:store').createRecord('task-event', {
displayMessage: 'All 3000 tasks look great, no notes.',
})
);
assert.equal(
timelessTaskEvent.get('message'),
'All 3000 tasks look great, no notes.',
'displayMessage is unchanged'
);
});
});