mirror of
https://github.com/status-im/consul.git
synced 2025-01-15 00:04:47 +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
185 lines
6.5 KiB
JavaScript
185 lines
6.5 KiB
JavaScript
import { module, skip, test } from 'qunit';
|
|
import { setupTest } from 'ember-qunit';
|
|
import repo from 'consul-ui/tests/helpers/repo';
|
|
import { createPolicies } from 'consul-ui/tests/helpers/normalizers';
|
|
|
|
module(`Integration | Service | token`, function(hooks) {
|
|
setupTest(hooks);
|
|
skip('clone returns the correct data for the clone endpoint');
|
|
const dc = 'dc-1';
|
|
const id = 'token-id';
|
|
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/token');
|
|
return repo(
|
|
'Token',
|
|
'findAllByDatacenter',
|
|
subject,
|
|
function retrieveStub(stub) {
|
|
return stub(
|
|
`/v1/acl/tokens?dc=${dc}${typeof nspace !== 'undefined' ? `&ns=${nspace}` : ``}${
|
|
typeof partition !== 'undefined' ? `&partition=${partition}` : ``
|
|
}`,
|
|
{
|
|
CONSUL_TOKEN_COUNT: '100',
|
|
}
|
|
);
|
|
},
|
|
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(function(item) {
|
|
return Object.assign({}, item, {
|
|
Datacenter: dc,
|
|
CreateTime: new Date(item.CreateTime),
|
|
Namespace: item.Namespace || undefinedNspace,
|
|
Partition: item.Partition || undefinedPartition,
|
|
uid: `["${item.Partition || undefinedPartition}","${item.Namespace ||
|
|
undefinedNspace}","${dc}","${item.AccessorID}"]`,
|
|
Policies: createPolicies(item),
|
|
});
|
|
});
|
|
})
|
|
);
|
|
}
|
|
);
|
|
});
|
|
test(`findBySlug returns the correct data for item endpoint when nspace is ${nspace}`, function(assert) {
|
|
const subject = this.owner.lookup('service:repository/token');
|
|
return repo(
|
|
'Token',
|
|
'findBySlug',
|
|
subject,
|
|
function retrieveStub(stub) {
|
|
return stub(
|
|
`/v1/acl/token/${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) {
|
|
expected(function(item) {
|
|
assert.equal(
|
|
actual.uid,
|
|
`["${partition || undefinedPartition}","${nspace || undefinedNspace}","${dc}","${
|
|
item.AccessorID
|
|
}"]`
|
|
);
|
|
assert.equal(actual.Datacenter, dc);
|
|
assert.deepEqual(actual.Policies, createPolicies(item));
|
|
});
|
|
}
|
|
);
|
|
});
|
|
test(`findByPolicy returns the correct data when nspace is ${nspace}`, function(assert) {
|
|
const subject = this.owner.lookup('service:repository/token');
|
|
const policy = 'policy-1';
|
|
return repo(
|
|
'Token',
|
|
'findByPolicy',
|
|
subject,
|
|
function retrieveStub(stub) {
|
|
return stub(
|
|
`/v1/acl/tokens?dc=${dc}&policy=${policy}${
|
|
typeof nspace !== 'undefined' ? `&ns=${nspace}` : ``
|
|
}${typeof partition !== 'undefined' ? `&partition=${partition}` : ``}`,
|
|
{
|
|
CONSUL_TOKEN_COUNT: '100',
|
|
}
|
|
);
|
|
},
|
|
function performTest(service) {
|
|
return service.findByPolicy({
|
|
id: policy,
|
|
dc,
|
|
ns: nspace || undefinedNspace,
|
|
partition: partition || undefinedPartition,
|
|
});
|
|
},
|
|
function performAssertion(actual, expected) {
|
|
assert.deepEqual(
|
|
actual,
|
|
expected(function(payload) {
|
|
return payload.map(function(item) {
|
|
return Object.assign({}, item, {
|
|
Datacenter: dc,
|
|
CreateTime: new Date(item.CreateTime),
|
|
Namespace: item.Namespace || undefinedNspace,
|
|
Partition: item.Partition || undefinedPartition,
|
|
uid: `["${item.Partition || undefinedPartition}","${item.Namespace ||
|
|
undefinedNspace}","${dc}","${item.AccessorID}"]`,
|
|
Policies: createPolicies(item),
|
|
});
|
|
});
|
|
})
|
|
);
|
|
}
|
|
);
|
|
});
|
|
test(`findByRole returns the correct data when nspace is ${nspace}`, function(assert) {
|
|
const subject = this.owner.lookup('service:repository/token');
|
|
const role = 'role-1';
|
|
return repo(
|
|
'Token',
|
|
'findByPolicy',
|
|
subject,
|
|
function retrieveStub(stub) {
|
|
return stub(
|
|
`/v1/acl/tokens?dc=${dc}&role=${role}${
|
|
typeof nspace !== 'undefined' ? `&ns=${nspace}` : ``
|
|
}${typeof partition !== 'undefined' ? `&partition=${partition}` : ``}`,
|
|
{
|
|
CONSUL_TOKEN_COUNT: '100',
|
|
}
|
|
);
|
|
},
|
|
function performTest(service) {
|
|
return service.findByRole({
|
|
id: role,
|
|
dc,
|
|
ns: nspace || undefinedNspace,
|
|
partition: partition || undefinedPartition,
|
|
});
|
|
},
|
|
function performAssertion(actual, expected) {
|
|
assert.deepEqual(
|
|
actual,
|
|
expected(function(payload) {
|
|
return payload.map(function(item) {
|
|
return Object.assign({}, item, {
|
|
Datacenter: dc,
|
|
CreateTime: new Date(item.CreateTime),
|
|
Namespace: item.Namespace || undefinedNspace,
|
|
Partition: item.Partition || undefinedPartition,
|
|
uid: `["${item.Partition || undefinedPartition}","${item.Namespace ||
|
|
undefinedNspace}","${dc}","${item.AccessorID}"]`,
|
|
Policies: createPolicies(item),
|
|
});
|
|
});
|
|
})
|
|
);
|
|
}
|
|
);
|
|
});
|
|
});
|
|
});
|