Step CI is an open-source tool, which makes testing and monitoring APIs simple
Quick overview:
- Language-agnostic. Flexible, declarative configuration language
- REST, GraphQL, XML
- Integrated. Works seamlessly with Node, Docker and GitHub Actions
Install the CLI
npm install -g stepci
Create example workflow (tests/workflow.yml
)
version: "1.0"
name: Status Check
env:
host: example.com
tests:
example:
steps:
- name: GET request
url: https://{{env.host}}
method: GET
check:
status: /^20/
Run the workflow
stepci run tests/workflow.yml
Create example workflow (tests/workflow.yml
)
version: "1.0"
name: Status Check
env:
host: example.com
tests:
example:
steps:
- name: GET request
url: https://{{env.host}}
method: GET
check:
status: /^20/
Run the Docker image
docker run -v "$(pwd)"/tests:/tests ghcr.io/stepci/stepci tests/workflow.yml
Create example workflow (tests/workflow.yml
)
version: "1.0"
name: Status Check
env:
host: example.com
tests:
example:
steps:
- name: GET request
url: https://{{env.host}}
method: GET
check:
status: /^20/
Add Step CI GitHub Action (./github/workflows/stepci.yml
)
on: [push]
jobs:
api_test:
runs-on: ubuntu-latest
name: API Tests
steps:
- uses: actions/checkout@v3
- name: Step CI Action
uses: stepci/stepci@main
with:
workflow: "tests/workflow.yml"
Documentation is accessible under docs/
You can find a collection of Step CI example tests under examples/
- Status Check
- Validating XML
- Validating JSON
- JSON Schema
- Validating HTML
- Validating Bytes
- Performance
- SSL Certificates
- Captures
- Graph QL
- Soap API
- Form Submission
- File Uploads
- Basic Auth
- Cookies
- Conditions
- Using Matchers
version: "1.0"
name: Status Check
env:
host: example.com
tests:
example:
steps:
- name: GET request
url: https://{{env.host}}
method: GET
check:
status: /^20/
version: "1.0"
name: Validating XML
tests:
example:
steps:
- name: GET request
url: https://api-campaign-us-1.goacoustic.com/XMLAPI
method: GET
check:
xpath:
//SUCCESS: "false"
version: "1.0"
name: Validating JSON
tests:
example:
steps:
- name: GET request
url: https://jsonplaceholder.typicode.com/posts/1
method: GET
check:
jsonpath:
$.id: 1
version: "1.0"
name: JSON Schema
tests:
example:
steps:
- name: GET request
url: https://jsonplaceholder.typicode.com/posts/1
method: GET
check:
jsonschema:
type: object
properties:
userId:
type: integer
required: true
id:
type: integer
required: true
title:
type: string
required: true
body:
type: string
required: true
version: "1.0"
name: Validating HTML
tests:
example:
steps:
- name: GET request
url: https://example.com
method: GET
check:
selector:
title: Example Domain
version: "1.0"
name: Validating Bytes
tests:
example:
steps:
- name: Image
url: https://httpbin.org/image
headers:
accept: image/webp
method: GET
check:
sha256: 567cfaf94ebaf279cea4eb0bc05c4655021fb4ee004aca52c096709d3ba87a63
version: "1.0"
name: Performance
tests:
example:
steps:
- name: GET Request
url: https://example.com
method: GET
check:
performance:
firstByte:
- lte: 200
total:
- lte: 500
version: "1.0"
name: SSL Certificates
tests:
example:
steps:
- name: GET Request
method: GET
url: https://example.com
check:
ssl:
valid: true
signed: true
daysUntilExpiration:
- gte: 60
version: "1.0"
name: Captures
env:
host: jsonplaceholder.typicode.com
resource: posts
tests:
example:
steps:
- name: Post the post
url: https://{{env.host}}/{{env.resource}}
method: POST
headers:
Content-Type: application/json
json:
title: Hello Step CI!
body: This is the body
userId: 1
captures:
id:
jsonpath: $.id
check:
status: 201
captures:
id: 101
- name: Get post by id
url: https://{{env.host}}/{{env.resource}}/{{captures.id}}
method: GET
headers:
Content-Type: application/json
check:
status: 404
headers:
Content-Type: application/json; charset=utf-8
body: "{}"
version: "1.0"
name: GraphQL
tests:
example:
steps:
- name: Request
url: https://echo.hoppscotch.io/graphql
method: POST
headers:
Content-Type: application/json
graphql:
query: |
query Request {
method
url
headers {
key
value
}
}
variables:
id: 1
check:
status: 200
jsonpath:
$.data.method: POST
version: "1.0"
name: SOAP API
tests:
example:
steps:
- name: POST request
url: https://www.dataaccess.com/webservicesserver/NumberConversion.wso
method: POST
headers:
Content-Type: text/xml
SOAPAction: "#POST"
body: >
<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<NumberToWords xmlns="http://www.dataaccess.com/webservicesserver/">
<ubiNum>500</ubiNum>
</NumberToWords>
</soap:Body>
</soap:Envelope>
check:
status: 200
selector:
m\:numbertowordsresult: "five hundred "
version: "1.0"
name: Form Submission
tests:
example:
steps:
- name: Submit a form
url: https://httpbin.org/post
method: POST
formData:
email: hello@stepci.com
logo:
file: README.md
check:
status: 200
version: "1.0"
name: File Uploads
tests:
example:
steps:
- name: Upload
url: https://httpbin.org/post
method: POST
body:
file: README.md
check:
status: 200
version: "1.0"
name: Basic Auth
tests:
example:
steps:
- name: Basic Auth
url: https://httpbin.org/basic-auth/hello/world
method: GET
auth:
basic:
username: hello
password: world
check:
status: 200
version: "1.0"
name: Cookies
tests:
example:
steps:
- name: Cookies
url: https://httpbin.org/cookies
method: GET
cookies:
wows: world
check:
status: 200
cookies:
wows: world
version: "1.0"
name: Conditions
tests:
example:
steps:
- name: GET request
url: https://example.com
method: GET
check:
status: 200
captures:
title:
selector: title
- if: captures.title != "Example Domain"
name: GET request
url: https://example.com
method: GET
check:
status: 200
version: "1.0"
name: Using Matchers
tests:
example:
steps:
- name: GET request
url: https://jsonplaceholder.typicode.com/posts/1
method: GET
check:
jsonpath:
$.id:
- eq: 1
- isNumber: true
Step CI is distributed under Mozilla Public License terms