mirror of https://github.com/hashicorp/consul
83 lines
2.2 KiB
JavaScript
83 lines
2.2 KiB
JavaScript
|
import { moduleFor, test } from 'ember-qunit';
|
||
|
import { skip } from 'qunit';
|
||
|
import repo from 'consul-ui/tests/helpers/repo';
|
||
|
moduleFor('service:services', 'Integration | Service | services', {
|
||
|
// Specify the other units that are required for this test.
|
||
|
needs: [
|
||
|
'service:store',
|
||
|
'model:service',
|
||
|
'adapter:service',
|
||
|
'serializer:service',
|
||
|
'service:settings',
|
||
|
],
|
||
|
});
|
||
|
const dc = 'dc-1';
|
||
|
const id = 'token-name';
|
||
|
test('findByDatacenter returns the correct data for list endpoint', function(assert) {
|
||
|
return repo(
|
||
|
'Service',
|
||
|
'findAllByDatacenter',
|
||
|
this.subject(),
|
||
|
function retrieveStub(stub) {
|
||
|
return stub(`/v1/internal/ui/services?dc=${dc}`, {
|
||
|
CONSUL_SERVICE_COUNT: '100',
|
||
|
});
|
||
|
},
|
||
|
function performTest(service) {
|
||
|
return service.findAllByDatacenter(dc);
|
||
|
},
|
||
|
function performAssertion(actual, expected) {
|
||
|
assert.deepEqual(
|
||
|
actual,
|
||
|
expected(function(payload) {
|
||
|
return payload.map(item =>
|
||
|
Object.assign({}, item, {
|
||
|
Datacenter: dc,
|
||
|
uid: `["${dc}","${item.Name}"]`,
|
||
|
})
|
||
|
);
|
||
|
})
|
||
|
);
|
||
|
}
|
||
|
);
|
||
|
});
|
||
|
skip('findBySlug returns a sane tree');
|
||
|
test('findBySlug returns the correct data for item endpoint', function(assert) {
|
||
|
return repo(
|
||
|
'Service',
|
||
|
'findBySlug',
|
||
|
this.subject(),
|
||
|
function(stub) {
|
||
|
return stub(`/v1/health/service/${id}?dc=${dc}`, {
|
||
|
CONSUL_NODE_COUNT: 1,
|
||
|
});
|
||
|
},
|
||
|
function(service) {
|
||
|
return service.findBySlug(id, dc);
|
||
|
},
|
||
|
function(actual, expected) {
|
||
|
assert.deepEqual(
|
||
|
actual,
|
||
|
expected(function(payload) {
|
||
|
// TODO: So this tree is all 'wrong', it's not having any major impact
|
||
|
// this this tree needs revisting to something that makes more sense
|
||
|
payload = Object.assign(
|
||
|
{},
|
||
|
{ Nodes: payload },
|
||
|
{
|
||
|
Datacenter: dc,
|
||
|
uid: `["${dc}","${id}"]`,
|
||
|
}
|
||
|
);
|
||
|
const nodes = payload.Nodes;
|
||
|
const service = payload.Nodes[0];
|
||
|
service.Nodes = nodes;
|
||
|
service.Tags = payload.Nodes[0].Service.Tags;
|
||
|
|
||
|
return service;
|
||
|
})
|
||
|
);
|
||
|
}
|
||
|
);
|
||
|
});
|