Automated testing framework for api services, http, gRPC
- No program development is required, only configuration files need to be written
- You can specify dependencies between testcases
- Testcases without dependencies can be executed concurrently and execute faster
- Use XPath to extract variables for easy writing
- supports importing variables from files and extracting variables from response
Obtain the bin file corresponding to the operating system and CPU architecture from the link above
make build
or
go install github.com/vearne/autotest@latest
autotest test --config-file=${CONFIG_FILE}
autotest run --config-file=${CONFIG_FILE} --env-file=${ENV_FILE}
autotest extract --xpath=${XPATH} --json=${JSON}
cd ./docker-compose
docker compose up -d
curl -X POST 'http://localhost:8080/api/books' \
--header 'Content-Type: application/json' \
--data '{"title": "book3_title", "author": "book3_author"}'
curl -X DELETE 'http://localhost:8080/api/books/1'
curl -X PUT 'localhost:8080/api/books/3' \
--header 'Content-Type: application/json' \
--data '{"title": "book3_title", "author": "book3_author-2"}'
curl 'http://localhost:8080/api/books'
autotest run -c=./config_files/autotest.yml -e=./config_files/.env.dev
get the title of each book in the book list
autotest extract -x "//title" -j '[
{
"id": 2,
"title": "Effective Go",
"author": "The Go Authors"
},
{
"id": 3,
"title": "book3_title",
"author": "book3_author-2"
}
]'
- 1) support utilizing the script language Lua to ascertain the conformity of HTTP responses with expectations.
- 2) output report to file
- 3) support automating tests for gRPC protocol-based API services.