Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Trendyol/gaos
HTTP mocking to test API services for chaos scenarios
https://github.com/Trendyol/gaos
api chaos go mocking
Last synced: 3 months ago
JSON representation
HTTP mocking to test API services for chaos scenarios
- Host: GitHub
- URL: https://github.com/Trendyol/gaos
- Owner: Trendyol
- License: apache-2.0
- Created: 2020-07-08T06:12:34.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-05-11T20:39:10.000Z (over 1 year ago)
- Last Synced: 2024-08-02T15:48:18.829Z (6 months ago)
- Topics: api, chaos, go, mocking
- Language: Go
- Homepage:
- Size: 162 KB
- Stars: 214
- Watchers: 24
- Forks: 7
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: CODEOWNERS
Awesome Lists containing this project
README
GAOS
HTTP mocking to test API services for chaos scenarios
*Gaos*, can create and provide custom mock restful services via using your fully-customizable scenarios and runs them on Docker & Kubernetes & localhost flawlessly.
**Warning:** Currently in Beta.
[![asciicast](https://asciinema.org/a/348527.svg)](https://asciinema.org/a/348527)
## Features
> * API response mocking
> * Custom behaviour scenarios
> * Create custom actions for each scenario
> * Robust routing
> * Serve static & dynamic responses
> * Duration, Latency, Error scenarios
> * Deploy your services on Docker & K8S
> * ... and much more, explore the Gaos!## Installation
* Via HomeBrew
```bash
$ brew tap trendyol/trendyol-tap
$ brew install gaos
```* Via Go
```bash
$ go get -u github.com/Trendyol/gaos
```* Build on Docker
```bash
$ make build
```## Scenarios
| Scenario | Explanation |
| ---------------------- |:----------------------------------------------:|
| `latency` | Adds extra latency for request |
| `duration` | Adds duration limit for request |
| `span` | Executes `accept` if in the specified time range, `ignore` otherwise. |
| `rate` | Executes `ignore` if reaches the value or on multiples of, `accept` otherwise. |## Actions
| Action | Explanation |
| ---------------------- |:----------------------------------------------:|
| `accept` | Execute if span and rate conditions doesn't match in the specified scenario |
| `ignore` | Execute if span and rate conditions does match in the specified scenario |
| `direct` | Specifies which scenario should be handled by next request |
| `result` | Specifies *Result Type* that will be return eventually |
| `status` | Specifies *Status Code* for given *Result Type* |## Results
| Result | Explanation |
| ---------------------- |:----------------------------------------------:|
| `type` | *Result Type* of the content |
| `content` | Definitions the relevant result's content, according to *Result Type* |### Result Type
| Result Type | Explanation |
| ---------------------- |:----------------------------------------------:|
| `static` | Returns `json` content |
| `file` | Returns `content.type` after reading the file in `content.path` |
| `redirect` | Sends request to remote `content.host` and awaits response _(reverse proxy)_ |## Usage
```bash
Usage:
gaos [command]Available Commands:
help Help about any command
run Run Gaos server on localhost
start Start Gaos server on given engine (Docker, K8S)Flags:
-h, --help help for gaos
```### Run Command
```bash
Run Gaos server on your localhostUsage:
gaos run [flags]Flags:
-x, --execute string execute scenario services
-s, --scenario string scenario file input (default "./scenario.json")
```Example:
```bash
$ gaos run -s ./examples/example.json
```After Gaos server started:
```bash
$ go run ./examples/example.go
```### Start Command
```bash
Start Gaos server on given engine (Docker, K8S)Usage:
gaos start [flags]Flags:
-c, --config string choose k8s config (default "minikube")
--cpu string cpu limit (default "500m")
-e, --environment string gaos running environment {docker, k8s} (default "local")
--memory string memory limit (default "500mi")
-n, --namespace string choose namespace (default "default")
-p, --password string image registry password
-r, --registry string image registry
--replica string replica count (default "1")
-s, --scenario string scenario file input (default "./scenario.json")
--secret string secret key name
-t, --timeout string client timeout (default "5m")
-u, --username string image registry username
```* Example: Docker
```bash
$ gaos start -e docker -s './examples/example.json'
```* Example: Kubernetes
```bash
$ gaos start -e k8s -s './examples/example.json'
```## Running Tests
*Requirements:*
* [bats](https://github.com/bats-core/bats-core)
* [docker](https://www.docker.com/)
* [kind](https://github.com/kubernetes-sigs/kind) (with `kind-kind` context, `localhost:5000` [local registry](https://kind.sigs.k8s.io/docs/user/local-registry/))```bash
$ bats e2e.bats
```## Known Issues
* Lack of some unit tests
* E2E tests are not running on pipeline yet. (Manually: `bats e2e.bats`)
* Not tested in Windows yet## TO-DO
* [ ] Add `./docs` folder for better documentation
* [ ] Scenario linter - to check rules, keys and paths
* [ ] Remote server config reader
* [ ] API client
* [ ] [Envoy](https://www.envoyproxy.io/) support - sidecar feature
* [ ] [Consul](https://www.consul.io/) support - service mesh feature## License
The base project code is licensed under Apache License unless otherwise specified. Please see the **[LICENSE](https://github.com/Trendyol/gaos/blob/master/LICENSE)** file for more information.
GAOS