eeb04ae436
* Add Partition to all our models * Add partitions into our serializers/fingerprinting * Make some amends to a few adapters ready for partitions * Amend blueprints to avoid linting error * Update all our repositories to include partitions, also Remove enabled/disable nspace repo and just use a nspace with conditionals * Ensure nspace and parition parameters always return '' no matter what * Ensure data-sink finds the model properly This will later be replaced by a @dataSink decorator but we are find kicking that can down the road a little more * Add all the new partition data layer * Add a way to set the title of the page from inside the route and make it accessibile via a route announcer * Make the Consul Route the default/basic one * Tweak nspace and partition abilities not to check the length * Thread partition through all the components that need it * Some ACL tweaks * Move the entire app to use partitions * Delete all the tests we no longer need * Update some Unit tests to use partition * Fix up KV title tests * Fix up a few more acceptance tests * Fixup and temporarily ignore some acceptance tests * Stop using ember-cli-page-objects fillable as it doesn't seem to work * Fix lint error * Remove old ACL related test * Add a tick after filling out forms * Fix token warning modal * Found some more places where we need a partition var * Fixup some more acceptance tests * Tokens still needs a repo service for CRUD * Remove acceptance tests we no longer need * Fixup and "FIXME ignore" a few tests * Remove an s * Disable blocking queries for KV to revert to previous release for now * Fixup adapter tests to follow async/function resolving interface * Fixup all the serializer integration tests * Fixup service/repo integration tests * Fixup deleting acceptance test * Fixup some ent tests * Make sure nspaces passes the dc through for when thats important * ...aaaand acceptance nspaces with the extra dc param
158 lines
5.3 KiB
JavaScript
158 lines
5.3 KiB
JavaScript
import { module, test } from 'qunit';
|
|
import { setupTest } from 'ember-qunit';
|
|
import { env } from '../../../env';
|
|
const shouldHaveNspace = function(nspace) {
|
|
return typeof nspace !== 'undefined' && env('CONSUL_NSPACES_ENABLED');
|
|
};
|
|
module('Integration | Adapter | kv', function(hooks) {
|
|
setupTest(hooks);
|
|
const dc = 'dc-1';
|
|
const id = 'key-name/here';
|
|
const undefinedNspace = 'default';
|
|
[undefinedNspace, 'team-1', undefined].forEach(nspace => {
|
|
test(`requestForQuery returns the correct url/method when nspace is ${nspace}`, async function(assert) {
|
|
const adapter = this.owner.lookup('adapter:kv');
|
|
const client = this.owner.lookup('service:client/http');
|
|
const request = function() {
|
|
return () => client.requestParams.bind(client)(...arguments);
|
|
};
|
|
const expected = `GET /v1/kv/${id}?keys&dc=${dc}${
|
|
shouldHaveNspace(nspace) ? `&ns=${nspace}` : ``
|
|
}`;
|
|
let actual = await adapter.requestForQuery(request, {
|
|
dc: dc,
|
|
id: id,
|
|
ns: nspace,
|
|
});
|
|
actual = actual();
|
|
assert.equal(`${actual.method} ${actual.url}`, expected);
|
|
});
|
|
test(`requestForQueryRecord returns the correct url/method when nspace is ${nspace}`, async function(assert) {
|
|
const adapter = this.owner.lookup('adapter:kv');
|
|
const client = this.owner.lookup('service:client/http');
|
|
const request = function() {
|
|
return () => client.requestParams.bind(client)(...arguments);
|
|
};
|
|
const expected = `GET /v1/kv/${id}?dc=${dc}${
|
|
shouldHaveNspace(nspace) ? `&ns=${nspace}` : ``
|
|
}`;
|
|
let actual = await adapter.requestForQueryRecord(request, {
|
|
dc: dc,
|
|
id: id,
|
|
ns: nspace,
|
|
});
|
|
actual = actual();
|
|
assert.equal(`${actual.method} ${actual.url}`, expected);
|
|
});
|
|
test(`requestForCreateRecord returns the correct url/method when nspace is ${nspace}`, function(assert) {
|
|
const adapter = this.owner.lookup('adapter:kv');
|
|
const client = this.owner.lookup('service:client/http');
|
|
const request = client.url.bind(client);
|
|
const expected = `PUT /v1/kv/${id}?dc=${dc}${
|
|
shouldHaveNspace(nspace) ? `&ns=${nspace}` : ``
|
|
}`;
|
|
let actual = adapter
|
|
.requestForCreateRecord(
|
|
request,
|
|
{},
|
|
{
|
|
Datacenter: dc,
|
|
Key: id,
|
|
Value: '',
|
|
Namespace: nspace,
|
|
}
|
|
)
|
|
.split('\n')
|
|
.shift();
|
|
assert.equal(actual, expected);
|
|
});
|
|
test(`requestForUpdateRecord returns the correct url/method when nspace is ${nspace}`, function(assert) {
|
|
const adapter = this.owner.lookup('adapter:kv');
|
|
const client = this.owner.lookup('service:client/http');
|
|
const request = client.url.bind(client);
|
|
const flags = 12;
|
|
const expected = `PUT /v1/kv/${id}?dc=${dc}${
|
|
shouldHaveNspace(nspace) ? `&ns=${nspace}` : ``
|
|
}&flags=${flags}`;
|
|
let actual = adapter
|
|
.requestForUpdateRecord(
|
|
request,
|
|
{},
|
|
{
|
|
Datacenter: dc,
|
|
Key: id,
|
|
Value: '',
|
|
Namespace: nspace,
|
|
Flags: flags,
|
|
}
|
|
)
|
|
.split('\n')
|
|
.shift();
|
|
assert.equal(actual, expected);
|
|
});
|
|
test(`requestForDeleteRecord returns the correct url/method when the nspace is ${nspace}`, function(assert) {
|
|
const adapter = this.owner.lookup('adapter:kv');
|
|
const client = this.owner.lookup('service:client/http');
|
|
const request = client.url.bind(client);
|
|
const expected = `DELETE /v1/kv/${id}?dc=${dc}${
|
|
shouldHaveNspace(nspace) ? `&ns=${nspace}` : ``
|
|
}`;
|
|
let actual = adapter
|
|
.requestForDeleteRecord(
|
|
request,
|
|
{},
|
|
{
|
|
Datacenter: dc,
|
|
Key: id,
|
|
Namespace: nspace,
|
|
}
|
|
)
|
|
.split('\n')
|
|
.shift();
|
|
assert.equal(actual, expected);
|
|
});
|
|
test(`requestForDeleteRecord returns the correct url/method for folders when nspace is ${nspace}`, function(assert) {
|
|
const adapter = this.owner.lookup('adapter:kv');
|
|
const client = this.owner.lookup('service:client/http');
|
|
const request = client.url.bind(client);
|
|
const folder = `${id}/`;
|
|
const expected = `DELETE /v1/kv/${folder}?dc=${dc}${
|
|
shouldHaveNspace(nspace) ? `&ns=${nspace}` : ``
|
|
}&recurse`;
|
|
let actual = adapter
|
|
.requestForDeleteRecord(
|
|
request,
|
|
{},
|
|
{
|
|
Datacenter: dc,
|
|
Key: folder,
|
|
Namespace: nspace,
|
|
}
|
|
)
|
|
.split('\n')
|
|
.shift();
|
|
assert.equal(actual, expected);
|
|
});
|
|
});
|
|
test("requestForQuery throws if you don't specify an id", function(assert) {
|
|
const adapter = this.owner.lookup('adapter:kv');
|
|
const client = this.owner.lookup('service:client/http');
|
|
const request = client.url.bind(client);
|
|
assert.rejects(
|
|
adapter.requestForQuery(request, {
|
|
dc: dc,
|
|
})
|
|
);
|
|
});
|
|
test("requestForQueryRecord throws if you don't specify an id", function(assert) {
|
|
const adapter = this.owner.lookup('adapter:kv');
|
|
const client = this.owner.lookup('service:client/http');
|
|
const request = client.url.bind(client);
|
|
assert.rejects(
|
|
adapter.requestForQueryRecord(request, {
|
|
dc: dc,
|
|
})
|
|
);
|
|
});
|
|
});
|