Skip to content
This repository has been archived by the owner on Feb 9, 2023. It is now read-only.
/ aspecto-cli Public archive

CLI and build-time tool to keep your APIs resilient

Notifications You must be signed in to change notification settings

aspecto-io/aspecto-cli

Repository files navigation

Don't break your APIs

PRs Welcome Aspecto@npm



What is Aspecto?

Aspecto is the CLI test runner of Aspecto.
You can integrate it in your CI, git hooks or just run it manually.
The CLI will generate a test suite from Aspecto server, based on real data that was collected and prepared beforehand.
The generated suite will be run against a url you will provide, could be localhost, staging, production or anything else.

Installation

In your project, run:

yarn add @aspecto/cli --dev

You can now run aspecto-cli from your package.json scrips, like this:

...
scripts: {
    "aspecto:test": "aspecto test <url> [options]"
}
...

Alternatively, you can install @aspecto/cli globally and use it from the terminal from wherever you'd like.

Usage

aspecto test <URL> [options]

URL

The url you'd like Aspecto CLI to run the generated tests against.
Usually, you'd point this on your localhost when testing locally or to your staging url when running on your CI.

CLI Options

--package <packageName>

Alias -p. This will tell our servers to generate the tests based on which data that was collected beforehand.
It will usually be the name in your service package.json.
If you don't provide this option, we will try to get the name from the package.json ourselves.

--token <token>

Alias -t. Your authentication token, provided at https://app.aspecto.io/app/integration.
If non provided, we'll try to get it ourselves from the ASPECTO_TOKEN env param (process.env.ASPECTO_TOKEN).

--env <envs>

Alias -e. A csv of envs.
This will tell our servers to generate the tests based on data collected in the provided environments.
By default, we will create tests based on data from all environments.

Example: --env production,staging

--allow-methods <methods>

Alias -m. A csv of http methods. This will tell our servers to generate the tests based on data collected from routes meeting the allowed methods.
By default, we will create tests based on all http methods.

Example: --allow-methods POST,PUT

--allow-codes <codes>

Alias -c. A csv of http status codes. This will tell our servers to generate the tests based on data collected from responses with status code meeting the allowed codes.
By default, we will create tests based on all status codes.

Example: --allow-codes 200,204

--allow-fail

Alias -a. Use this flag to make the process quit with 1 when failing.
By default, the process will quit with 0.

--fail-strategy <soft|strict>

Alias -f. Relevant only when using --allow-fail.
Soft will fail the process only on a failed test.
Strict will fail the process on any kind of failure (i.e. bad usage, failure to fetch tests).

--timeout <timeout>

Alias -o. How long to wait (in milliseconds) before timing out an API call as part of the test suites. Default is 5000ms.

--test-param <param>

Alias -r. Supply parameters to populate data in tests which were configured accordingly in Aspecto tests section.
This enables you to alter certain parts of the request to match your specific testing setup.

You can define the parameter and it's value:

--test-param KEY1=value1 --test-param KEY2=value2

If not provided, we will try to pick it from your environment.

--verbose

Alias -v. Use this flag to print debug logs.

Examples

  $ aspecto test http://localhost:3322 --package my-service --token **** --allow-fail --env development -c 200,404 -m GET
  $ aspecto test https://staging.aspecto.com --env staging -a --verbose
  $ aspecto test https://prod.aspecto.com --allow-codes 200,204,500

About

CLI and build-time tool to keep your APIs resilient

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •