From 785b79e1722dc5edabb6118776119476451cd71a Mon Sep 17 00:00:00 2001 From: Florian Eitel Date: Thu, 13 Feb 2020 12:32:47 -0800 Subject: [PATCH] Support services not specified in metadata.json The commit https://github.com/aws/aws-sdk-js/pull/3087 introduced passing a `serviceIdentifier` to the constructor which needs to be present in the `metadata.json`. For private models thats not the case and checking for `xmlNoDefaultLists` fails. --- lib/model/api.js | 2 +- test/model/api.spec.js | 6 ++++++ 2 files changed, 7 insertions(+), 1 deletion(-) diff --git a/lib/model/api.js b/lib/model/api.js index 621750c222..a7e6330f58 100644 --- a/lib/model/api.js +++ b/lib/model/api.js @@ -34,7 +34,7 @@ function Api(api, options) { property(this, 'abbreviation', api.metadata.serviceAbbreviation); property(this, 'fullName', api.metadata.serviceFullName); property(this, 'serviceId', api.metadata.serviceId); - if (serviceIdentifier) { + if (serviceIdentifier && metadata[serviceIdentifier]) { property(this, 'xmlNoDefaultLists', metadata[serviceIdentifier].xmlNoDefaultLists, false); } diff --git a/test/model/api.spec.js b/test/model/api.spec.js index b20f0003ff..61c5ad164f 100644 --- a/test/model/api.spec.js +++ b/test/model/api.spec.js @@ -46,6 +46,12 @@ }); }); + describe('serviceIdentifier', function() { + it('creates an API with passed serviceIdentifier', function() { + return expect(make({}, { serviceIdentifier: 'asdf' }).isApi).to.equal(true); + }); + }); + describe('className', function() { it('generates the correct class name from fullName', function() { var api;