Refresh role table after editing role
By using the track-by feature of hz-resource-table. Closes-Bug: #1708444 Change-Id: I782aa4671f5f1bc23a1aa8535b86751ffe712c0b
This commit is contained in:
parent
d66c96269d
commit
a58aa26450
@ -1,4 +1,5 @@
|
||||
<hz-resource-panel resource-type-name="OS::Keystone::Role">
|
||||
<hz-resource-table resource-type-name="OS::Keystone::Role">
|
||||
<hz-resource-table resource-type-name="OS::Keystone::Role"
|
||||
track-by="trackBy">
|
||||
</hz-resource-table>
|
||||
</hz-resource-panel>
|
||||
|
@ -57,7 +57,20 @@
|
||||
});
|
||||
|
||||
function listFunction() {
|
||||
return keystone.getRoles();
|
||||
return keystone.getRoles().then(addTrackBy);
|
||||
}
|
||||
|
||||
// We need to modify the API's response by adding a composite value called
|
||||
// 'trackBy' to assist the display mechanism when updating rows.
|
||||
function addTrackBy(response) {
|
||||
return {data: {items: response.data.items.map(function(role) {
|
||||
role.trackBy = [
|
||||
role.id,
|
||||
role.domain_id,
|
||||
role.name
|
||||
].join('/');
|
||||
return role;
|
||||
})}};
|
||||
}
|
||||
|
||||
function roleProperties() {
|
||||
|
@ -23,18 +23,61 @@
|
||||
});
|
||||
|
||||
describe('horizon.dashboard.identity.roles.basePath constant', function() {
|
||||
var rolesBasePath, staticUrl;
|
||||
var q, rolesBasePath, staticUrl, registry, service, timeout;
|
||||
|
||||
beforeEach(module('horizon.app.core.openstack-service-api'));
|
||||
beforeEach(module('horizon.dashboard.identity'));
|
||||
beforeEach(module('horizon.framework'));
|
||||
beforeEach(inject(function($injector) {
|
||||
beforeEach(inject(function($q, $injector, $timeout) {
|
||||
q = $q;
|
||||
timeout = $timeout;
|
||||
rolesBasePath = $injector.get('horizon.dashboard.identity.roles.basePath');
|
||||
staticUrl = $injector.get('$window').STATIC_URL;
|
||||
registry = $injector.get('horizon.framework.conf.resource-type-registry.service');
|
||||
service = $injector.get('horizon.app.core.openstack-service-api.keystone');
|
||||
}));
|
||||
|
||||
it('should equal to "/static/dashboard/identity/roles"', function() {
|
||||
expect(rolesBasePath).toEqual(staticUrl + 'dashboard/identity/roles/');
|
||||
});
|
||||
|
||||
it('trackBy should change when role name changes', function() {
|
||||
var defer1 = q.defer();
|
||||
var defer2 = q.defer();
|
||||
spyOn(service, 'getRoles').and.returnValues(
|
||||
defer1.promise,
|
||||
defer2.promise
|
||||
);
|
||||
defer1.resolve(
|
||||
{data:
|
||||
{items:
|
||||
[{id: 'role-id',
|
||||
name: 'role-name-1',
|
||||
domain_id: null
|
||||
}]}});
|
||||
defer2.resolve(
|
||||
{data:
|
||||
{items:
|
||||
[{id: 'role-id',
|
||||
name: 'role-name-2',
|
||||
domain_id: null
|
||||
}]}});
|
||||
|
||||
var resource = registry.getResourceType('OS::Keystone::Role');
|
||||
q.all([
|
||||
resource.list(),
|
||||
resource.list()
|
||||
]).then(function(responses) {
|
||||
var trackBy1 = responses[0].data.items[0].trackBy;
|
||||
var trackBy2 = responses[1].data.items[0].trackBy;
|
||||
|
||||
expect(trackBy1).toBeDefined();
|
||||
expect(trackBy2).toBeDefined();
|
||||
expect(trackBy1).not.toEqual(trackBy2);
|
||||
});
|
||||
|
||||
timeout.flush();
|
||||
});
|
||||
|
||||
});
|
||||
})();
|
||||
|
Loading…
x
Reference in New Issue
Block a user