mirror of
https://github.com/status-im/consul.git
synced 2025-01-28 14:34:59 +00:00
39c5b91272
* Refactor remaining `moduleFor`-tests `moduleFor*` will be removed from ember-qunit v5 * Upgrade ember-qunit to v5 * Update how we use ember-sinon-qunit With ember-qunit v5 we need to use ember-sinon-qunit differently. * Fix submit-blank test We can't click on disabled buttons with new test-helpers. We need to adapt the test accordingly. * Make sure we await fill-in with form yaml step We need to await `fill-in`. This changes the reducer function in the step to create a proper await chain. * Fix show-routing test We need to await a tick before visiting again. * Remove redundant `wait one tick`-step * remove unneeded "next Tick" promise from form step * Increase timeout show-routing feature * Comment on pause hack for show-routing test
96 lines
3.2 KiB
JavaScript
96 lines
3.2 KiB
JavaScript
import { module, skip, test } from 'qunit';
|
|
import { setupTest } from 'ember-qunit';
|
|
import { get } from '@ember/object';
|
|
import repo from 'consul-ui/tests/helpers/repo';
|
|
|
|
module(`Integration | Service | policy`, function(hooks) {
|
|
setupTest(hooks);
|
|
skip('translate returns the correct data for the translate endpoint');
|
|
const now = new Date().getTime();
|
|
const dc = 'dc-1';
|
|
const id = 'policy-name';
|
|
const undefinedNspace = 'default';
|
|
const undefinedPartition = 'default';
|
|
const partition = 'default';
|
|
[undefinedNspace, 'team-1', undefined].forEach(nspace => {
|
|
test(`findByDatacenter returns the correct data for list endpoint when nspace is ${nspace}`, function(assert) {
|
|
const subject = this.owner.lookup('service:repository/policy');
|
|
|
|
get(subject, 'store').serializerFor('policy').timestamp = function() {
|
|
return now;
|
|
};
|
|
return repo(
|
|
'Policy',
|
|
'findAllByDatacenter',
|
|
subject,
|
|
function retrieveStub(stub) {
|
|
return stub(
|
|
`/v1/acl/policies?dc=${dc}${typeof nspace !== 'undefined' ? `&ns=${nspace}` : ``}${
|
|
typeof partition !== 'undefined' ? `&partition=${partition}` : ``
|
|
}`,
|
|
{
|
|
CONSUL_POLICY_COUNT: '10',
|
|
}
|
|
);
|
|
},
|
|
function performTest(service) {
|
|
return service.findAllByDatacenter({
|
|
dc,
|
|
ns: nspace || undefinedNspace,
|
|
partition: partition || undefinedPartition,
|
|
});
|
|
},
|
|
function performAssertion(actual, expected) {
|
|
assert.deepEqual(
|
|
actual,
|
|
expected(function(payload) {
|
|
return payload.map(item =>
|
|
Object.assign({}, item, {
|
|
SyncTime: now,
|
|
Datacenter: dc,
|
|
Namespace: item.Namespace || undefinedNspace,
|
|
Partition: item.Partition || undefinedPartition,
|
|
uid: `["${item.Partition || undefinedPartition}","${item.Namespace ||
|
|
undefinedNspace}","${dc}","${item.ID}"]`,
|
|
})
|
|
);
|
|
})
|
|
);
|
|
}
|
|
);
|
|
});
|
|
test(`findBySlug returns the correct data for item endpoint when the nspace is ${nspace}`, function(assert) {
|
|
const subject = this.owner.lookup('service:repository/policy');
|
|
return repo(
|
|
'Policy',
|
|
'findBySlug',
|
|
subject,
|
|
function retrieveStub(stub) {
|
|
return stub(
|
|
`/v1/acl/policy/${id}?dc=${dc}${typeof nspace !== 'undefined' ? `&ns=${nspace}` : ``}${
|
|
typeof partition !== 'undefined' ? `&partition=${partition}` : ``
|
|
}`
|
|
);
|
|
},
|
|
function performTest(service) {
|
|
return service.findBySlug({
|
|
id,
|
|
dc,
|
|
ns: nspace || undefinedNspace,
|
|
partition: partition || undefinedPartition,
|
|
});
|
|
},
|
|
function performAssertion(actual, expected) {
|
|
assert.equal(
|
|
actual.uid,
|
|
`["${partition || undefinedPartition}","${nspace || undefinedNspace}","${dc}","${
|
|
actual.ID
|
|
}"]`
|
|
);
|
|
assert.equal(actual.Datacenter, dc);
|
|
}
|
|
);
|
|
});
|
|
});
|
|
});
|