diff --git a/ui/app/templates/allocations/allocation/index.hbs b/ui/app/templates/allocations/allocation/index.hbs index 335d2cf5aac..9ea4f650dc5 100644 --- a/ui/app/templates/allocations/allocation/index.hbs +++ b/ui/app/templates/allocations/allocation/index.hbs @@ -37,29 +37,36 @@
Tasks
-
- {{#list-table - source=sortedStates - sortProperty=sortProperty - sortDescending=sortDescending - class="is-striped" as |t|}} - {{#t.head}} - - {{#t.sort-by prop="name"}}Name{{/t.sort-by}} - {{#t.sort-by prop="state"}}State{{/t.sort-by}} - Last Event - {{#t.sort-by prop="events.lastObject.time"}}Time{{/t.sort-by}} - Addresses - CPU - Memory - {{/t.head}} - {{#t.body as |row|}} - {{task-row - data-test-task-row=row.model.name - task=row.model - onClick=(action "taskClick" row.model.allocation row.model)}} - {{/t.body}} - {{/list-table}} +
+ {{#if sortedStates.length}} + {{#list-table + source=sortedStates + sortProperty=sortProperty + sortDescending=sortDescending + class="is-striped" as |t|}} + {{#t.head}} + + {{#t.sort-by prop="name"}}Name{{/t.sort-by}} + {{#t.sort-by prop="state"}}State{{/t.sort-by}} + Last Event + {{#t.sort-by prop="events.lastObject.time"}}Time{{/t.sort-by}} + Addresses + CPU + Memory + {{/t.head}} + {{#t.body as |row|}} + {{task-row + data-test-task-row=row.model.name + task=row.model + onClick=(action "taskClick" row.model.allocation row.model)}} + {{/t.body}} + {{/list-table}} + {{else}} +
+

No Tasks

+

Allocations will not have tasks until they are in a running state.

+
+ {{/if}}
diff --git a/ui/mirage/factories/allocation.js b/ui/mirage/factories/allocation.js index 3eeac22ca53..6c31749c738 100644 --- a/ui/mirage/factories/allocation.js +++ b/ui/mirage/factories/allocation.js @@ -156,9 +156,8 @@ export default Factory.extend({ namespace, jobId: job.id, nodeId: node.id, - taskStateIds: states.mapBy('id'), - task_state_ids: states.mapBy('id'), - taskResourcesIds: resources.mapBy('id'), + taskStateIds: allocation.clientStatus === 'pending' ? [] : states.mapBy('id'), + taskResourcesIds: allocation.clientStatus === 'pending' ? [] : resources.mapBy('id'), taskGroup: taskGroup.name, name: allocation.name || `${taskGroup.name}.[${faker.random.number(10)}]`, }); diff --git a/ui/tests/acceptance/allocation-detail-test.js b/ui/tests/acceptance/allocation-detail-test.js index 14447a14631..bb7854ac9e5 100644 --- a/ui/tests/acceptance/allocation-detail-test.js +++ b/ui/tests/acceptance/allocation-detail-test.js @@ -15,7 +15,7 @@ moduleForAcceptance('Acceptance | allocation detail', { node = server.create('node'); job = server.create('job', { groupsCount: 1, createAllocations: false }); - allocation = server.create('allocation', 'withTaskWithPorts'); + allocation = server.create('allocation', 'withTaskWithPorts', { clientStatus: 'running' }); // Make sure the node has an unhealthy driver node.update({ @@ -76,6 +76,7 @@ test('/allocation/:id should list all tasks for the allocation', function(assert server.db.taskStates.where({ allocationId: allocation.id }).length, 'Table lists all tasks' ); + assert.notOk(Allocation.isEmpty, 'Task table empty state is not shown'); }); test('each task row should list high-level information for the task', function(assert) { @@ -146,6 +147,16 @@ test('tasks with an unhealthy driver have a warning icon', function(assert) { assert.ok(Allocation.firstUnhealthyTask().hasUnhealthyDriver, 'Warning is shown'); }); +test('when there are no tasks, an empty state is shown', function(assert) { + // Make sure the allocation is pending in order to ensure there are no tasks + allocation = server.create('allocation', 'withTaskWithPorts', { clientStatus: 'pending' }); + Allocation.visit({ id: allocation.id }); + + andThen(() => { + assert.ok(Allocation.isEmpty, 'Task table empty state is shown'); + }); +}); + test('when the allocation has not been rescheduled, the reschedule events section is not rendered', function(assert) { assert.notOk(Allocation.hasRescheduleEvents, 'Reschedule Events section exists'); }); diff --git a/ui/tests/acceptance/task-detail-test.js b/ui/tests/acceptance/task-detail-test.js index 2f3b34480fb..efa3cc87729 100644 --- a/ui/tests/acceptance/task-detail-test.js +++ b/ui/tests/acceptance/task-detail-test.js @@ -12,7 +12,7 @@ moduleForAcceptance('Acceptance | task detail', { server.create('agent'); server.create('node'); server.create('job', { createAllocations: false }); - allocation = server.create('allocation', 'withTaskWithPorts'); + allocation = server.create('allocation', 'withTaskWithPorts', { clientStatus: 'running' }); task = server.db.taskStates.where({ allocationId: allocation.id })[0]; Task.visit({ id: allocation.id, name: task.name }); @@ -212,7 +212,7 @@ moduleForAcceptance('Acceptance | task detail (different namespace)', { server.create('namespace'); server.create('namespace', { id: 'other-namespace' }); server.create('job', { createAllocations: false, namespaceId: 'other-namespace' }); - allocation = server.create('allocation', 'withTaskWithPorts'); + allocation = server.create('allocation', 'withTaskWithPorts', { clientStatus: 'running' }); task = server.db.taskStates.where({ allocationId: allocation.id })[0]; Task.visit({ id: allocation.id, name: task.name }); diff --git a/ui/tests/acceptance/task-logs-test.js b/ui/tests/acceptance/task-logs-test.js index 91b55375e5a..69058792c3b 100644 --- a/ui/tests/acceptance/task-logs-test.js +++ b/ui/tests/acceptance/task-logs-test.js @@ -10,9 +10,9 @@ moduleForAcceptance('Acceptance | task logs', { beforeEach() { server.create('agent'); server.create('node', 'forceIPv4'); - const job = server.create('job'); + const job = server.create('job', { createAllocations: false }); - allocation = server.db.allocations.where({ jobId: job.id })[0]; + allocation = server.create('allocation', { jobId: job.id, clientStatus: 'running' }); task = server.db.taskStates.where({ allocationId: allocation.id })[0]; run.later(run, run.cancelTimers, 1000); diff --git a/ui/tests/pages/allocations/detail.js b/ui/tests/pages/allocations/detail.js index c824f961036..bc3bc165d4c 100644 --- a/ui/tests/pages/allocations/detail.js +++ b/ui/tests/pages/allocations/detail.js @@ -47,6 +47,8 @@ export default create({ hasRescheduleEvents: isPresent('[data-test-reschedule-events]'), + isEmpty: isPresent('[data-test-empty-tasks-list]'), + error: { isShown: isPresent('[data-test-error]'), title: text('[data-test-error-title]'),