Welcome to use atest
to improve your code quality.
You can use atest
as a CLI or as:
- Web UI
- VS Code Extension
See also the screenshots below:
There are various ways of installing atest
:
- CLI via
hd i atest
- Web server
- Kubernetes
- Argo CD
- Helm
If you're developing APIs locally, the best way is to install it as a container service. Then you can access it via your browser.
Currently, it supports the following kinds of services:
- Operate System services
- Linux and Darwin
- Podman and Docker
sudo atest service install -m podman --version master
docker run -v /var/www/sample:/var/www/sample \
--network host \
linuxsuren/api-testing:master
The default web server port is 8080
. So you can visit it via: http://localhost:8080
sudo k3s server --write-kubeconfig-mode 666
k3s kubectl apply -k sample/kubernetes/default
kustomize build sample/kubernetes/docker.io/ | k3s kubectl apply -f -
The test suite file could be local, or in the HTTP server. Have a look at some examples:
atest run -p your-local-file.yaml
atest run -p https://gitee.com/linuxsuren/api-testing/raw/master/sample/testsuite-gitee.yaml
atest run -p http://localhost:8080/server.Runner/ConvertTestSuite?suite=sample
The last example pertains to the API Testing server.
There are two kinds of functions for two situations: template rendering and test results verification.
- Template rendering functions are based on the Go template
- The verification functions are based on expr library
You can query the supported functions on the UI page or by using the command:
atest func
In some cases you may want to run the test cases after an HTTP server is ready. Then you can use the hooks feature as follows:
name: Gitlab
api: https://gitlab.com/api/v4
param:
user: linuxsuren
items:
- name: projects
request:
api: /projects
before:
items:
- "sleep(1)"
after:
items:
- "sleep(1)"
You can use all the functions that are available in the expr library.
JMeter is a load test tool. You can run the following commands from the root directory of this repository:
atest convert --converter jmeter -p sample/testsuite-gitee.yaml --target bin/gitee.jmx
jmeter -n -t bin/gitee.jmx
Please feel free to bring more test tool converters.
You can run the API testings in Jenkins, as demonstrated in the example below:
pipeline {
agent any
stages() {
stage('test') {
steps {
sh '''
curl http://localhost:9090/get -o atest
chmod u+x atest
./atest run -p http://localhost:9090/server.Runner/ConvertTestSuite?suite=api-testing
'''
}
}
}
}
You can see the test results in Grafana.
It can monitor the server and browser via the Apache SkyWalking. Please add the following flag if you want to get the browser tracing data:
# 12800 is the HTTP port of Apache SkyWalking
# 11800 is the gRPC port of Apache SkyWalking
export SW_AGENT_REPORTER_GRPC_BACKEND_SERVICE=localhost:11800
export SW_AGENT_REPORTER_DISCARD=false
atest server --skywalking http://localhost:12800
There are multiple storage backends supported. See the status from the list:
Name | Status |
---|---|
Local Storage | Ready |
S3 | Ready |
ORM DataBase | Ready |
Git Repository | Ready |
Etcd | Ready |
MongoDB | Devloping |
Local storage is the built-in solution. You can run it with the following command:
podman run --pull always -p 8080:8080 ghcr.io/linuxsuren/api-testing:master
# The default local storage directory is: /var/www/sample
# You can find the test case YAML files in it.
# Visit it from http://localhost:8080 once it's ready.
Or, you can run the CLI in the terminal like this:
atest server --local-storage 'sample/*.yaml' --console-path console/atest-ui/dist
Use the host network mode if you want to connect to your local environment:
podman run --pull always --network host ghcr.io/linuxsuren/api-testing:master
Start a database with the following command if you don't have a database already. You can install tiup via hd i tiup
.
tiup playground --db.host 0.0.0.0
# create a config file
mkdir bin
echo "- name: db
kind:
name: atest-store-orm
url: localhost:7071
url: localhost:4000
username: root
properties:
database: test" > bin/stores.yaml
# start the server with gRPC storage
podman run -p 8080:8080 -v bin:var/data/atest \
--network host \
ghcr.io/linuxsuren/api-testing:master \
atest server --console-path=/var/www/html \
--config-dir=/var/data/atest
# start the gRPC storage which ready to connect to an ORM database
podman run -p 7071:7071 \
--network host \
ghcr.io/linuxsuren/api-testing:master atest-store-orm
You can use a S3 compatible storage as the storage backend.
# The default port is 7072
podman run --network host \
ghcr.io/linuxsuren/api-testing:master atest-store-s3
Have a look at the expected configuration below:
- name: s3
url: http://172.11.0.13:30999 # address of the s3 server
kind:
name: atest-store-s3
url: localhost:7072 # address of the s3 storage extension
properties:
accessKeyID: 6e03rIMChrsZ6YZl
secretAccessKey: F0xH6o2qRYTyAUyRuXO81B4gj7zUrSaj
sessiontoken: ""
region: cn
disableSSL: true
forcepathstyle: true
bucket: vm1
You can use a git repository as the storage backend.
# The default port is 7074
podman run --network host \
ghcr.io/linuxsuren/api-testing:master atest-store-git
Have a look at the expected configuration below:
- name: git
url: http://172.11.0.13:30999 # address of the git repository
username: linuxsuren
password: linuxsuren
kind:
name: atest-store-git # the extension binary file name
url: localhost:7074 # address of the git storage extension
properties: # optional properties for specific features
targetPath: . # target path to find YAML files
name: linuxsuren # the name for git commit
email: linuxsuren@github.com # the email address for git commit
insecure: false # whether to use insecure
You can use a MongoDB as the storage backend.
Have a look at the expected configuration below:
- name: mongodb
url: 172.11.0.13:27017 # address of the mongodb
username: linuxsuren
password: linuxsuren
kind:
name: atest-store-mongodb # the extension binary file name
properties: # optional properties for specific features
database: testing # the database name
collection: atest # the collection name
You can put sensitive information into a secret server. For example, Vault.
Connect to a vault extension via flag: --secret-server
. Such as:
atest server --secret-server localhost:7073
You can get the resource usage in the report through Docker:
atest run -p sample/testsuite-gitlab.yaml --monitor-docker test --report md
Item | Description |
---|---|
expect.bodyFieldsExpect |
See also the syntax from https://github.com/tidwall/gjson |
It support GitHub, Dex as OAuth provider. See also the following usage:
atest server --auth oauth --client-id your-id --client-secret your-secret
Developers can have storage, secret extensions. Implementing a gRPC server according to loader.proto is required.
You can find the official images from both Docker Hub and others. See the image path:
ghcr.io/linuxsuren/api-testing:master
docker.io/linuxsuren/api-testing:master
registry.aliyuncs.com/linuxsuren/api-testing:master
ccr.ccs.tencentyun.com/linuxsuren/api-testing:master
docker.m.daocloud.io/linuxsuren/api-testing:master
(mirror)
The tag latest
represents the latest release version. The tag master
represents the image of the latest master branch. We highly recommend you to use a fixed version instead of those in a production environment.