John Cowen 482426b13e UI: ACL Roles (#5635)
Adds support for ACL Roles and Service Identities CRUD, along with necessary changes to Tokens, and the CSS improvements required.

Also includes refinements/improvements for easier testing of deeply nested components.

1. ember-data adapter/serializer/model triplet for Roles
2. repository, form/validations and searching filter for Roles
3. Moves potentially, repeated, or soon to to repeated functionality
into a mixin (mainly for 'many policy' relationships)
4. A few styling tweaks for little edge cases around roles
5. Router additions, Route, Controller and templates for Roles

Also see: 

* UI: ACL Roles cont. plus Service Identities (#5661 and #5720)
2019-05-01 18:22:37 +00:00

70 lines
2.0 KiB
JavaScript

import { moduleFor, test, skip } from 'ember-qunit';
import repo from 'consul-ui/tests/helpers/repo';
import { createPolicies } from 'consul-ui/tests/helpers/normalizers';
const NAME = 'token';
moduleFor(`service:repository/${NAME}`, `Integration | Service | ${NAME}`, {
// Specify the other units that are required for this test.
integration: true,
});
const dc = 'dc-1';
const id = 'token-id';
test('findByDatacenter returns the correct data for list endpoint', function(assert) {
return repo(
'Token',
'findAllByDatacenter',
this.subject(),
function retrieveStub(stub) {
return stub(`/v1/acl/tokens?dc=${dc}`, {
CONSUL_TOKEN_COUNT: '100',
});
},
function performTest(service) {
return service.findAllByDatacenter(dc);
},
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),
uid: `["${dc}","${item.AccessorID}"]`,
Policies: createPolicies(item),
});
});
})
);
}
);
});
test('findBySlug returns the correct data for item endpoint', function(assert) {
return repo(
'Token',
'findBySlug',
this.subject(),
function retrieveStub(stub) {
return stub(`/v1/acl/token/${id}?dc=${dc}`);
},
function performTest(service) {
return service.findBySlug(id, dc);
},
function performAssertion(actual, expected) {
assert.deepEqual(
actual,
expected(function(payload) {
const item = payload;
return Object.assign({}, item, {
Datacenter: dc,
CreateTime: new Date(item.CreateTime),
uid: `["${dc}","${item.AccessorID}"]`,
Policies: createPolicies(item),
});
})
);
}
);
});
skip('clone returns the correct data for the clone endpoint');