diff --git a/ui/packages/consul-ui/app/components/consul/health-check/list/pageobject.js b/ui/packages/consul-ui/app/components/consul/health-check/list/pageobject.js index 286933d4c5..d69dee72ef 100644 --- a/ui/packages/consul-ui/app/components/consul/health-check/list/pageobject.js +++ b/ui/packages/consul-ui/app/components/consul/health-check/list/pageobject.js @@ -1,11 +1,12 @@ export default (collection, text) => (scope = '.consul-health-check-list') => { - return { - scope, - item: collection('li', { - name: text('header h3'), - type: text('[data-health-check-type]'), - exposed: text('[data-test-exposed]'), - }), - }; + return collection({ + scope, + itemScope: 'li', + item: { + name: text('header h2'), + type: text('[data-health-check-type]'), + exposed: text('[data-test-exposed]'), + } + }); }; diff --git a/ui/packages/consul-ui/app/controllers/dc/services/instance/healthchecks.js b/ui/packages/consul-ui/app/controllers/dc/services/instance/healthchecks.js index 8d6270e823..3e80cc0cee 100644 --- a/ui/packages/consul-ui/app/controllers/dc/services/instance/healthchecks.js +++ b/ui/packages/consul-ui/app/controllers/dc/services/instance/healthchecks.js @@ -9,8 +9,6 @@ export default class HealthChecksController extends Controller { @action syntheticNodeHealthCheckFilter(item, healthcheck, index, list) { - console.log('List to be filtered: ', list); - console.log(healthcheck.Kind); return !(item.Node.Meta?.['synthetic-node'] && healthcheck?.Kind === 'node'); } } diff --git a/ui/packages/consul-ui/tests/acceptance/dc/services/instances/health-checks.feature b/ui/packages/consul-ui/tests/acceptance/dc/services/instances/health-checks.feature index ed1e2c9234..92f927a620 100644 --- a/ui/packages/consul-ui/tests/acceptance/dc/services/instances/health-checks.feature +++ b/ui/packages/consul-ui/tests/acceptance/dc/services/instances/health-checks.feature @@ -64,3 +64,68 @@ Feature: dc / services / instances / health-checks Then the url should be /dc1/services/service-0/instances/another-node/service-1-with-id/health-checks And I see healthChecksIsSelected on the tabs And I don't see criticalSerfNotice on the tabs.healthChecksTab + Scenario: Node health check should be hidden on agentless service instances + Given 1 instance model from yaml + --- + - Service: + ID: service-0-with-id + Node: + Node: another-node + Meta: + synthetic-node: true + Checks: + - Type: '' + Name: Node Health Check + CheckID: serfHealth + ServiceID: '' + Status: passing + Output: Agent alive and reachable + - Type: '' + Name: Serf Health Status + CheckID: serfHealth + Status: critical + Output: ouch + --- + When I visit the instance page for yaml + --- + dc: dc1 + service: service-0 + node: another-node + id: service-0-with-id + --- + Then the url should be /dc1/services/service-0/instances/another-node/service-0-with-id/health-checks + And I see healthChecksIsSelected on the tabs + And I see 1 healthCheck model on the tabs.healthChecksTab component + And I see 1 healthCheck model with the name "Serf Health Status" + Scenario: Node health checks should be visible on non-agentless service instances + Given 1 instance model from yaml + --- + - Service: + ID: service-0-with-id + Node: + Node: another-node + Checks: + - Type: '' + Name: Node Health Check + CheckID: serfHealth + ServiceID: '' + Status: passing + Output: Agent alive and reachable + - Type: '' + Name: Serf Health Status + CheckID: serfHealth + Status: critical + Output: ouch + --- + When I visit the instance page for yaml + --- + dc: dc1 + service: service-0 + node: another-node + id: service-0-with-id + --- + Then the url should be /dc1/services/service-0/instances/another-node/service-0-with-id/health-checks + And I see healthChecksIsSelected on the tabs + And I see 2 healthCheck models on the tabs.healthChecksTab component + And I see 1 healthCheck model with the name "Serf Health Status" + And I see 1 healthCheck model with the name "Node Health Check" diff --git a/ui/packages/consul-ui/tests/acceptance/dc/services/instances/show.feature b/ui/packages/consul-ui/tests/acceptance/dc/services/instances/show.feature index 55b87cedb1..87f8d4b496 100644 --- a/ui/packages/consul-ui/tests/acceptance/dc/services/instances/show.feature +++ b/ui/packages/consul-ui/tests/acceptance/dc/services/instances/show.feature @@ -75,7 +75,7 @@ Feature: dc / services / instances / show: Show Service Instance And I don't see upstreams on the tabs And I see healthChecksIsSelected on the tabs - And I see 6 of the checks object + And I see 6 healthCheck models When I click tags&Meta on the tabs And I see tags&MetaIsSelected on the tabs diff --git a/ui/packages/consul-ui/tests/steps/assertions/model.js b/ui/packages/consul-ui/tests/steps/assertions/model.js index abe0c35cfd..bc733d649e 100644 --- a/ui/packages/consul-ui/tests/steps/assertions/model.js +++ b/ui/packages/consul-ui/tests/steps/assertions/model.js @@ -1,8 +1,25 @@ export default function (scenario, assert, find, currentPage, pauseUntil, pluralize) { + function getModelItems(model, component) { + let obj; + if (component) { + obj = find(component); + } else { + obj = currentPage(); + } + + let found = obj[pluralize(model)]; + + if (typeof found === 'function') { + found = found(); + } + + return found; + } + scenario .then('pause until I see $number $model model[s]?', function (num, model) { return pauseUntil(function (resolve, reject, retry) { - const len = currentPage()[pluralize(model)].filter(function (item) { + const len = getModelItems(model).filter(function (item) { return item.isVisible; }).length; if (len === num) { @@ -15,8 +32,7 @@ export default function (scenario, assert, find, currentPage, pauseUntil, plural 'pause until I see $number $model model[s]? on the $component component', function (num, model, component) { return pauseUntil(function (resolve, reject, retry) { - const obj = find(component); - const len = obj[pluralize(model)].filter(function (item) { + const len = getModelItems(model, component).filter(function (item) { return item.isVisible; }).length; if (len === num) { @@ -27,7 +43,7 @@ export default function (scenario, assert, find, currentPage, pauseUntil, plural } ) .then(['I see $num $model model[s]?'], function (num, model) { - const len = currentPage()[pluralize(model)].filter(function (item) { + const len = getModelItems(model).filter(function (item) { return item.isVisible; }).length; assert.equal(len, num, `Expected ${num} ${pluralize(model)}, saw ${len}`); @@ -35,15 +51,13 @@ export default function (scenario, assert, find, currentPage, pauseUntil, plural .then( ['I see $num $model model[s]? on the $component component'], function (num, model, component) { - const obj = find(component); - const len = obj[pluralize(model)].filter(function (item) { + const len = getModelItems(model, component).filter(function (item) { return item.isVisible; }).length; assert.equal(len, num, `Expected ${num} ${pluralize(model)}, saw ${len}`); } ) - // TODO: I${ dont } see .then( [`I see $num $model model[s]? with the $property "$value"`], function ( @@ -53,7 +67,7 @@ export default function (scenario, assert, find, currentPage, pauseUntil, plural property, value ) { - const len = currentPage()[pluralize(model)].filter(function (item) { + const len = getModelItems(model).filter(function (item) { if (item.isVisible) { let prop = item[property]; // cope with pageObjects that can have a multiple: true