diff --git a/ui/app/controllers/allocations/allocation/index.js b/ui/app/controllers/allocations/allocation/index.js
index 4e156c69f5c..1131d6b7fab 100644
--- a/ui/app/controllers/allocations/allocation/index.js
+++ b/ui/app/controllers/allocations/allocation/index.js
@@ -1,6 +1,7 @@
import { alias } from '@ember/object/computed';
import Controller, { inject as controller } from '@ember/controller';
import Sortable from 'nomad-ui/mixins/sortable';
+import { lazyClick } from 'nomad-ui/helpers/lazy-click';
export default Controller.extend(Sortable, {
allocationController: controller('allocations.allocation'),
@@ -17,4 +18,14 @@ export default Controller.extend(Sortable, {
listToSort: alias('model.states'),
sortedStates: alias('listSorted'),
+
+ actions: {
+ gotoTask(allocation, task) {
+ this.transitionToRoute('allocations.allocation.task', task);
+ },
+
+ taskClick(allocation, task, event) {
+ lazyClick([() => this.send('gotoTask', allocation, task), event]);
+ },
+ },
});
diff --git a/ui/app/templates/allocations/allocation/index.hbs b/ui/app/templates/allocations/allocation/index.hbs
index d1c0375ed2b..9de41da3a05 100644
--- a/ui/app/templates/allocations/allocation/index.hbs
+++ b/ui/app/templates/allocations/allocation/index.hbs
@@ -48,7 +48,10 @@
Addresses |
{{/t.head}}
{{#t.body as |row|}}
-
+
{{#if (not row.model.driverStatus.healthy)}}
diff --git a/ui/tests/acceptance/allocation-detail-test.js b/ui/tests/acceptance/allocation-detail-test.js
index d612eb68838..0720fffa9f2 100644
--- a/ui/tests/acceptance/allocation-detail-test.js
+++ b/ui/tests/acceptance/allocation-detail-test.js
@@ -137,6 +137,36 @@ test('each task row should list high-level information for the task', function(a
});
});
+test('each task row should link to the task detail page', function(assert) {
+ const task = server.db.taskStates.where({ allocationId: allocation.id }).sortBy('name')[0];
+
+ click('[data-test-task-row] [data-test-name] a');
+
+ andThen(() => {
+ assert.equal(
+ currentURL(),
+ `/allocations/${allocation.id}/${task.name}`,
+ 'Task name in task row links to task detail'
+ );
+ });
+
+ andThen(() => {
+ visit(`/allocations/${allocation.id}`);
+ });
+
+ andThen(() => {
+ click('[data-test-task-row]');
+ });
+
+ andThen(() => {
+ assert.equal(
+ currentURL(),
+ `/allocations/${allocation.id}/${task.name}`,
+ 'Task row links to task detail'
+ );
+ });
+});
+
test('tasks with an unhealthy driver have a warning icon', function(assert) {
assert.ok(find('[data-test-task-row] [data-test-icon="unhealthy-driver"]'), 'Warning is shown');
});
|