The openstack eslint package is just really not needed at this
point. Use standardjs and run --fix on it.
Switch away from using node 8 to run linters and tests.
Change-Id: I51f68d4ec30c8da5d1601ef00045e53f90d0554b
Update to babel v7 and webpack v4
Remove runtime depend on corejs-2 which is
unsupported. Just switch to runtime which requires polyfills be
provided by the end user.
Remove NSP - the service is being shut down and the important bits
are built in to npm now.
istanbul has been replaced by the nyc runner. Update karma
to latest.
Update yaml-loader and json-loader
Disable browser testing for now - we'll bring it back in a followup.
Change-Id: I45d1f77bb43e5d67f4154c5149fac77b853e3686
This follows removal of jobs from project-config. [1]
New jobs use newer node versions and new Zuul v3 format,
reusing devstack for deployment of OpenStack for functional
testing of jslib.
Version tests have been adapted to follow support logic
already in place instead of hardcoded supported versions.
Includes workaround (fixup) of devstack's bug. [2]
Move the functional test to experimental for now, because version
discovery doesn't work right and Firefox is generally grumpy.
We want to get the structural stuff in first.
[1] https://review.opendev.org/702030
[2] https://bugs.launchpad.net/devstack/+bug/1860287
Depends-on: https://review.opendev.org/704882
Depends-on: https://review.opendev.org/726547
Co-authored-by: Monty Taylor <mordred@inaugust.com>
Change-Id: I197eb2b59be7a49d168edf09d554b444bbcc29b2
This patch adds a more flexible selection of version in AbstractService.
A version will be selected if it's compatible with the 'supportedVersions'.
Example:
supportedVersions = ['v3.1'];
All minor versions above 3.1 will be compatible (3.1.2, 3.2, 3.3 etc)
However 4.x will not be compatible
Change-Id: Icd540449ebf6a09d9bb7e1d25a85e2dbe787c5a4
OpenStack wrapper will read the 'region_name' from config, and use
the correct endpoint matching this region
Change-Id: I01049f3bed227eb1e11f9a1f7d338177e95aef34
In Keystone API it's possible to provide both ids and names for
users, projects, user domains and project domains. This commit
adds support for this functionality.
Change-Id: I3268bd82cc92a150927c98e0827ebd105d91f5e3
This patch adds the networkList() method to the OpenStack wrapper
class. This method will initialize `Neutron` instance if needed and
cache it. As neutron needs the URL, `Keystone` instance is also
initialize and cache if needed.
Change-Id: If12af29a86b9856a145c1f91de25eb3473938de5
In some unit tests mockOptions.name was used instead of
mockOptions.matcher, and it was always undefined - this stopped
working with fetch-mock 5.5.0. This commit replaces
mockOptions.name with mockOptions.matcher where it is needed.
Change-Id: I367e1d957ce206c20c6b9d15c9f5ff1a2b285e33
This neutron service follows the same pattern as the glance service,
and provides both version negotiation and endpoint discovery.
Change-Id: Ia2f59213eedf6d7acbb02789ee921c13ff391d09
New linting rule to disable spaces after functions, before parens
Fixed all new linting errors
I suppose I'd like this to eventually get landed in official
`eslint-config-openstack` project, but for now it is here
Change-Id: I6c77524c5679117ce3b211db0bd9943c5ad5e646
This is required to make services provided by library accessible
this way:
import {Keystone} from 'openstack-lib';
instead of
import Keystone from 'openstack-lib/dist/keystone';
Also, Test class and dummy functional and unit tests for it were
removed since they aren't needed anymore.
Change-Id: I6bf0b6eebab095d6585d19d8398d9f2ac119cacc
This patch cleans up our constructor exception tests, and removes
old versions(), version(), and serviceEndpoint() tests that are
now handled in the parent class. Service specific tests have been
kept, and several tests to assert correct API behavior for specific
implementations have been added.
Change-Id: Ib42d94033ebb5613ee7e5c96654ab22f31fe4feb
We have no guarantees that the keystone service catalog will have the
root resource of any given service registered. As most versioned API
endpoints require tokens, we can reasonably assume that a 401 will
be encountered. This patch adds an extra check against the response
from the provided URL, and should a 401 be encountered, attempts
to resolve the versions from the root resource of the provided URL.
Change-Id: I655409f0eb9bfbd3489827db46faef026ede82f9
This glance service follows the same pattern as the keystone service,
and provides both version negotiation and endpoint discovery. Unlike
the keystone service, however, it is configured using an endpoint
configuration object as discovered from the Keystone service catalog.
Change-Id: I0fe2bc9690022688e2cb80b9ca1b10bcea86c13d
This patch adds loglevel back in as our logging framework, as
an assistatn for debugging the in/outbound HTTP requests.
Change-Id: I545e27f5c957f9c5c7a2dc73730b9db91600c1ce
Credentials for the admin devstack configuration are no
longer hardcoded. Thus, if infra changes the DSVM config,
we should pick up the changes.
Change-Id: I8924120aae8a8843d57327793bebce839dea0ebd
The request/response interception has not yet been used, and
introduced quite a bit of complexity, especially surrounding fetchMock.
Furthermore, they made our DSVM tests fail, as the browser's implementation
of Request requires that a request body be accessed using the regular
json(), text(), etc. promise generators. Since this would have
simply added more complexity to an already complex, unused feature,
we've simply removed the feature.
Change-Id: I4cdf7b7106c771f0562de47e8835076d48d03a31
This method permits the revocation of an auth token, whether by
the auth token itself, or by an admin token.
Change-Id: Ia80fd70986410b364351bffeaa5823a36d25d2cc
Fetch-mock doesn't sanely match against a Headers() instance, whose
implementation varies due to isomorphic-fetch. Here we deconstruct the instance
back into a map, so that the actual fetch() request is properly handled.
Change-Id: Ie99ca23a6cf75c48c8762e7de36aee71ef819b7f
This method handles sending an authorization request against the
keystone API, and returns the issued Authorization Token. At this
time it only supports the password authorization plugin. Additional
use cases should be provided by third-party developers.
It is the long term intent that this method will deprecate the
authorize() method, in order to provide a consistently idempotent
implementation.
Change-Id: If1368bcdae251606d2e03043345cd4fc6f0b8b80
Authenticate is now called against an endpoint whose version is
known, and thus can be more easily supported.
Change-Id: I6e5dd64ac7ccc91d0a35630335f301377d87079c
This resource will attempt to resolve a supported API version from
the versions available on the Keystone API.
Change-Id: Icca49d3c124fb9526aa4316290b475d95cfda2ce
This resource returns a (caching) promise, which will eventually
resolve to the list of versions published at the auth_url. It also
updates the unit tests to draw from a consolidated set of mock data.
Change-Id: I0d0de5b6ef6a1e3d1f5daa40a88ec3d799c43a64
This patch makes sure that successful HTTP requests, which result
in an error code, are passed to the catch() or reject handler, rather
than the success handler.
This results in two different cases in the claim() handler, that of
an internally thrown exception (like a TypeError), and that of a
Response() instance. In most cases, developers should not write
code that throws exceptions - and even in those, the ES6 Promise
API silently swallows most uncaught throws.
Change-Id: I736bcaccf6324a3d66191692e5f2ce922a727dea
This utility class provides an abstraction layer for HTTP calls via fetch(). Its purpose is
to provide common, SDK-wide behavior for all HTTP requests. Included are:
- Providing a common extension point for request and response manipulation.
- Access to default headers.
In the future, this class chould also be extended to provide:
- Some form of progress() support for large uploads and downloads (perhaps via introduction of Q)
- Convenience decoding of the response body, depending on Content-Type.
- Internal error handling (At this time, HTTP errors are passed to then() rather than catch()).
- Other features.
Change-Id: I8173554b1b7ef052e2a74504b98f4ec574ce6136