Moved serviceEndpoint() tests into abstract_serviceTest.

Also removed them from child classes.

Change-Id: I291e0d418a4a87ea21bf829712935cd0b1fb6530
This commit is contained in:
Michael Krotscheck 2016-09-16 06:48:16 -07:00
parent abfe901b5e
commit c8f7503f88
No known key found for this signature in database
GPG Key ID: 20E618D878DE38AB
4 changed files with 75 additions and 141 deletions

View File

@ -122,72 +122,6 @@ describe('Glance', () => {
});
});
describe("serviceEndpoint()", () => {
it("Should return a valid endpoint to the glance API.", (done) => {
const glance = new Glance(mockData.config);
fetchMock.mock(mockData.root());
glance.serviceEndpoint()
.then((endpoint) => {
expect(endpoint).toEqual('http://192.168.99.99:9292/v2/');
done();
})
.catch((error) => done.fail(error));
});
it("Should throw an exception if no endpoint is provided.", (done) => {
const glance = new Glance(mockData.config);
// Build an exception payload.
const mockOptions = mockData.root();
mockOptions.response.versions[0].links = [];
fetchMock.mock(mockOptions);
glance.serviceEndpoint()
.then((response) => done.fail(response))
.catch((error) => {
expect(error).not.toBeNull();
done();
});
});
it("Should throw an exception if no links array exists.", (done) => {
const glance = new Glance(mockData.config);
// Build an exception payload.
const mockOptions = mockData.root();
delete mockOptions.response.versions[0].links;
fetchMock.mock(mockOptions);
glance.serviceEndpoint()
.then((response) => done.fail(response))
.catch((error) => {
expect(error).not.toBeNull();
done();
});
});
it("Should cache its results", (done) => {
const glance = new Glance(mockData.config);
const mockOptions = mockData.root();
fetchMock.mock(mockOptions);
glance.serviceEndpoint()
.then(() => {
// Validate that the mock has only been invoked once
expect(fetchMock.calls(mockOptions.name).length).toEqual(1);
return glance.serviceEndpoint();
})
.then(() => {
expect(fetchMock.calls(mockOptions.name).length).toEqual(1);
done();
})
.catch((error) => done.fail(error));
});
});
describe("imageList()", () => {
let glance = null;

View File

@ -23,7 +23,7 @@
* URLs to match the test data below.
*/
const rootUrl = "http://example.com/";
const subUrl = `${rootUrl}/v1`;
const subUrl = `${rootUrl}v1`;
/**
* A mock list of supported versions for the below requests.
@ -50,7 +50,7 @@ function rootResponse() {
id: "v2.3",
links: [
{
href: `${rootUrl}/v2/`,
href: `${rootUrl}v2/`,
rel: "self"
}
]
@ -60,7 +60,7 @@ function rootResponse() {
id: "v2.2",
links: [
{
href: `${rootUrl}/v2/`,
href: `${rootUrl}v2/`,
rel: "self"
}
]
@ -70,7 +70,7 @@ function rootResponse() {
id: "v2.1",
links: [
{
href: `${rootUrl}/v2/`,
href: `${rootUrl}v2/`,
rel: "self"
}
]
@ -80,7 +80,7 @@ function rootResponse() {
id: "v2.0",
links: [
{
href: `${rootUrl}/v2/`,
href: `${rootUrl}v2/`,
rel: "self"
}
]
@ -90,7 +90,7 @@ function rootResponse() {
id: "v1.1",
links: [
{
href: `${rootUrl}/v1/`,
href: `${rootUrl}v1/`,
rel: "self"
}
]
@ -100,7 +100,7 @@ function rootResponse() {
id: "v1.0",
links: [
{
href: `${rootUrl}/v1/`,
href: `${rootUrl}v1/`,
rel: "self"
}
]

View File

@ -106,72 +106,6 @@ describe('Keystone', () => {
});
});
describe("serviceEndpoint()", () => {
it("Should return a valid endpoint to the keystone API.", (done) => {
const keystone = new Keystone(mockData.config);
fetchMock.mock(mockData.root());
keystone.serviceEndpoint()
.then((endpoint) => {
expect(endpoint).toEqual('http://192.168.99.99/identity_v2_admin/v3/');
done();
})
.catch((error) => done.fail(error));
});
it("Should throw an exception if no endpoint is provided.", (done) => {
const keystone = new Keystone(mockData.config);
// Build an exception payload.
const mockOptions = JSON.parse(JSON.stringify(mockData.root()));
mockOptions.response.versions.values[0].links = [];
fetchMock.mock(mockOptions);
keystone.serviceEndpoint()
.then((response) => done.fail(response))
.catch((error) => {
expect(error).not.toBeNull();
done();
});
});
it("Should throw an exception if no links array exists.", (done) => {
const keystone = new Keystone(mockData.config);
// Build an exception payload.
const mockOptions = JSON.parse(JSON.stringify(mockData.root()));
delete mockOptions.response.versions.values[0].links;
fetchMock.mock(mockOptions);
keystone.serviceEndpoint()
.then((response) => done.fail(response))
.catch((error) => {
expect(error).not.toBeNull();
done();
});
});
it("Should cache its results", (done) => {
const keystone = new Keystone(mockData.config);
const mockOptions = mockData.root();
fetchMock.mock(mockOptions);
keystone.serviceEndpoint()
.then(() => {
// Validate that the mock has only been invoked once
expect(fetchMock.calls(mockOptions.name).length).toEqual(1);
return keystone.serviceEndpoint();
})
.then(() => {
expect(fetchMock.calls(mockOptions.name).length).toEqual(1);
done();
})
.catch((error) => done.fail(error));
});
});
describe("tokenIssue()", () => {
it("should 'just work' by using provided credentials from the config.", (done) => {

View File

@ -15,8 +15,8 @@
*/
import AbstractService from "../../../src/util/abstract_service";
import * as mockData from '../helpers/data/versions'; // Might as well use keystone
import fetchMock from "fetch-mock";
import * as mockData from "../helpers/data/versions";
import fetchMock from "fetch-mock"; // Might as well use service
describe('AbstractService', () => {
@ -173,4 +173,70 @@ describe('AbstractService', () => {
.catch((error) => done.fail(error));
});
});
describe("serviceEndpoint()", () => {
it("Should return a valid endpoint to the API.", (done) => {
const service = new AbstractService(mockData.rootUrl, mockData.versions);
fetchMock.mock(mockData.rootResponse());
service.serviceEndpoint()
.then((endpoint) => {
expect(endpoint).toEqual('http://example.com/v2/');
done();
})
.catch((error) => done.fail(error));
});
it("Should throw an exception if no endpoint is provided.", (done) => {
const service = new AbstractService(mockData.rootUrl, mockData.versions);
// Build an exception payload.
const mockOptions = mockData.rootResponse();
mockOptions.response.versions[0].links = [];
fetchMock.mock(mockOptions);
service.serviceEndpoint()
.then((response) => done.fail(response))
.catch((error) => {
expect(error).not.toBeNull();
done();
});
});
it("Should throw an exception if no links array exists.", (done) => {
const service = new AbstractService(mockData.rootUrl, mockData.versions);
// Build an exception payload.
const mockOptions = mockData.rootResponse();
delete mockOptions.response.versions[0].links;
fetchMock.mock(mockOptions);
service.serviceEndpoint()
.then((response) => done.fail(response))
.catch((error) => {
expect(error).not.toBeNull();
done();
});
});
it("Should cache its results", (done) => {
const service = new AbstractService(mockData.rootUrl, mockData.versions);
const mockOptions = mockData.rootResponse();
fetchMock.mock(mockOptions);
service.serviceEndpoint()
.then(() => {
// Validate that the mock has only been invoked once
expect(fetchMock.calls(mockOptions.name).length).toEqual(1);
return service.serviceEndpoint();
})
.then(() => {
expect(fetchMock.calls(mockOptions.name).length).toEqual(1);
done();
})
.catch((error) => done.fail(error));
});
});
});