mirror of
https://github.com/status-im/consul.git
synced 2025-01-12 06:44:41 +00:00
7bb35c4c78
ui: Repo layer integration tests for methods that touch the API Includes a `repo` test helper to make repetitive tasks easier, plus a injectable reporter for sending performance metrics to a centralized metrics system Also noticed somewhere in the ember models that I'd like to improve, but left for the moment to make sure I concentrate on one task at a time, more or less: The tests currently asserts against the existing JSON tree, which doesn't seem to be a very nice tree. The work at hand here is to refactor what is there, so test for the not nice tree to ensure we don't get any regression, and add a skipped test so I can come back here later
74 lines
1.8 KiB
JavaScript
74 lines
1.8 KiB
JavaScript
import { moduleFor, test } from 'ember-qunit';
|
|
import repo from 'consul-ui/tests/helpers/repo';
|
|
const NAME = 'node';
|
|
moduleFor(`service:${NAME}s`, `Integration | Service | ${NAME}s`, {
|
|
// Specify the other units that are required for this test.
|
|
needs: [
|
|
'service:settings',
|
|
'service:store',
|
|
`adapter:${NAME}`,
|
|
`serializer:${NAME}`,
|
|
`model:${NAME}`,
|
|
'service:coordinates',
|
|
'adapter:coordinate',
|
|
'serializer:coordinate',
|
|
'model:coordinate',
|
|
],
|
|
});
|
|
|
|
const dc = 'dc-1';
|
|
const id = 'token-name';
|
|
test('findByDatacenter returns the correct data for list endpoint', function(assert) {
|
|
return repo(
|
|
'Node',
|
|
'findAllByDatacenter',
|
|
this.subject(),
|
|
function retrieveStub(stub) {
|
|
return stub(`/v1/internal/ui/nodes?dc=${dc}`, {
|
|
CONSUL_NODE_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.ID}"]`,
|
|
})
|
|
);
|
|
})
|
|
);
|
|
}
|
|
);
|
|
});
|
|
test('findBySlug returns the correct data for item endpoint', function(assert) {
|
|
return repo(
|
|
'Node',
|
|
'findBySlug',
|
|
this.subject(),
|
|
function(stub) {
|
|
return stub(`/v1/internal/ui/node/${id}?dc=${dc}`);
|
|
},
|
|
function(service) {
|
|
return service.findBySlug(id, dc);
|
|
},
|
|
function(actual, expected) {
|
|
assert.deepEqual(
|
|
actual,
|
|
expected(function(payload) {
|
|
const item = payload;
|
|
return Object.assign({}, item, {
|
|
Datacenter: dc,
|
|
uid: `["${dc}","${item.ID}"]`,
|
|
});
|
|
})
|
|
);
|
|
}
|
|
);
|
|
});
|