ui: Ensure URLs for tabs change when selecting a different DC (#8397)

* ui: Add URLs to tabs to we can assert them

* Add dcs to the service show page, temporarily

There is an ongoing PR which removes the need to do this by adding a dcs
property to the navigation, hence temporary

* Add a step to assert on whether text _contains_ rather than exact match

* Test whether the URL of the instance tab changes when the user switches dcs using the main navigation menu

* Recompute href-to's on URL change, just like is-href
This commit is contained in:
John Cowen 2020-07-29 16:09:40 +02:00 committed by GitHub
parent fe0a835fd1
commit b8a8435643
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 84 additions and 11 deletions

View File

@ -1,4 +1,4 @@
import { is, clickable } from 'ember-cli-page-object'; import { is, clickable, attribute } from 'ember-cli-page-object';
import ucfirst from 'consul-ui/utils/ucfirst'; import ucfirst from 'consul-ui/utils/ucfirst';
export default function(name, items, blankKey = 'all') { export default function(name, items, blankKey = 'all') {
return items.reduce(function(prev, item, i, arr) { return items.reduce(function(prev, item, i, arr) {
@ -17,6 +17,7 @@ export default function(name, items, blankKey = 'all') {
...prev, ...prev,
...{ ...{
[`${key}IsSelected`]: is('.selected', `[data-test-tab="${name}_${item}"]`), [`${key}IsSelected`]: is('.selected', `[data-test-tab="${name}_${item}"]`),
[`${key}Url`]: attribute('href', `[data-test-tab="${name}_${item}"] a`),
[key]: clickable(`[data-test-tab="${name}_${item}"] a`), [key]: clickable(`[data-test-tab="${name}_${item}"] a`),
}, },
}; };

View File

@ -1,8 +1,11 @@
/*eslint ember/no-observers: "warn"*/
// TODO: Remove ^
// This helper requires `ember-href-to` for the moment at least // This helper requires `ember-href-to` for the moment at least
// It's similar code but allows us to check on the type of route // It's similar code but allows us to check on the type of route
// (dynamic or wildcard) and encode or not depending on the type // (dynamic or wildcard) and encode or not depending on the type
import { inject as service } from '@ember/service'; import { inject as service } from '@ember/service';
import Helper from '@ember/component/helper'; import Helper from '@ember/component/helper';
import { observer } from '@ember/object';
import { hrefTo as _hrefTo } from 'ember-href-to/helpers/href-to'; import { hrefTo as _hrefTo } from 'ember-href-to/helpers/href-to';
import wildcard from 'consul-ui/utils/routing/wildcard'; import wildcard from 'consul-ui/utils/routing/wildcard';
@ -39,4 +42,7 @@ export default Helper.extend({
compute(params, hash) { compute(params, hash) {
return hrefTo(this, this.router, params, hash); return hrefTo(this, this.router, params, hash);
}, },
onURLChange: observer('router.currentURL', function() {
this.recompute();
}),
}); });

View File

@ -0,0 +1,27 @@
@setupApplicationTest
Feature: dc / services / show / dc-switch : Switching Datacenters
Scenario: Seeing all services when switching datacenters
Given 2 datacenter models from yaml
---
- dc-1
- dc-2
---
And 1 node model
And 1 service model from yaml
---
- Service:
Service: consul
Kind: ~
---
When I visit the service page for yaml
---
dc: dc-1
service: consul
---
Then the url should be /dc-1/services/consul/instances
And I see instancesUrl on the tabs contains "/dc-1/services/consul/instances"
When I click dc on the navigation
And I click dcs.1.name
Then the url should be /dc-2/services/consul/instances
And I see instancesUrl on the tabs contains "/dc-2/services/consul/instances"

View File

@ -0,0 +1,10 @@
import steps from '../../../steps';
// step definitions that are shared between features should be moved to the
// tests/acceptance/steps/steps.js file
export default function(assert) {
return steps(assert).then('I should find a file', function() {
assert.ok(true, this.step);
});
}

View File

@ -150,7 +150,16 @@ export default {
) )
), ),
service: create( service: create(
service(visitable, attribute, collection, text, consulIntentionList, catalogToolbar, tabgroup) service(
visitable,
clickable,
attribute,
collection,
text,
consulIntentionList,
catalogToolbar,
tabgroup
)
), ),
instance: create(instance(visitable, attribute, collection, text, tabgroup)), instance: create(instance(visitable, attribute, collection, text, tabgroup)),
nodes: create(nodes(visitable, clickable, attribute, collection, catalogFilter)), nodes: create(nodes(visitable, clickable, attribute, collection, catalogFilter)),

View File

@ -1,4 +1,13 @@
export default function(visitable, attribute, collection, text, intentions, filter, tabs) { export default function(
visitable,
clickable,
attribute,
collection,
text,
intentions,
filter,
tabs
) {
const page = { const page = {
visit: visitable('/:dc/services/:service'), visit: visitable('/:dc/services/:service'),
externalSource: attribute('data-test-external-source', '[data-test-external-source]', { externalSource: attribute('data-test-external-source', '[data-test-external-source]', {
@ -17,6 +26,10 @@ export default function(visitable, attribute, collection, text, intentions, filt
]), ]),
filter: filter(), filter: filter(),
dcs: collection('[data-test-datacenter-picker]', {
name: clickable('a'),
}),
// TODO: These need to somehow move to subpages // TODO: These need to somehow move to subpages
instances: collection('.consul-service-instance-list > ul > li:not(:first-child)', { instances: collection('.consul-service-instance-list > ul > li:not(:first-child)', {
address: text('[data-test-address]'), address: text('[data-test-address]'),

View File

@ -159,10 +159,10 @@ export default function(scenario, assert, find, currentPage) {
}) })
.then( .then(
[ [
'I see $property on the $component like "$value"', `I see $property on the $component (contains|like) "$value"`,
"I see $property on the $component like '$value'", `I see $property on the $component (contains|like) '$value'`,
], ],
function(property, component, value) { function(property, component, containsLike, value) {
let target; let target;
try { try {
if (typeof component === 'string') { if (typeof component === 'string') {
@ -172,11 +172,18 @@ export default function(scenario, assert, find, currentPage) {
} catch (e) { } catch (e) {
throw e; throw e;
} }
assert.equal( if (containsLike === 'like') {
target, assert.equal(
value, target,
`Expected to see ${property} on ${component} as ${value}, was ${target}` value,
); `Expected to see ${property} on ${component} as ${value}, was ${target}`
);
} else {
assert.ok(
target.indexOf(value) !== -1,
`Expected to see ${property} on ${component} within ${value}, was ${target}`
);
}
} }
) )
.then(['I see $property like "$value"'], function(property, value) { .then(['I see $property like "$value"'], function(property, value) {