Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ealenn/echo-server
REST Server Tests (Echo-Server) API / Docker / Kubernetes / Helm
https://github.com/ealenn/echo-server
dev-tools devops-tools docker echo echo-server helm helm-charts kubernetes nodejs rest-api server testing
Last synced: about 21 hours ago
JSON representation
REST Server Tests (Echo-Server) API / Docker / Kubernetes / Helm
- Host: GitHub
- URL: https://github.com/ealenn/echo-server
- Owner: Ealenn
- License: gpl-3.0
- Created: 2019-11-20T13:18:59.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-12-17T23:49:09.000Z (22 days ago)
- Last Synced: 2025-01-01T01:04:23.077Z (8 days ago)
- Topics: dev-tools, devops-tools, docker, echo, echo-server, helm, helm-charts, kubernetes, nodejs, rest-api, server, testing
- Language: JavaScript
- Homepage: https://ealenn.github.io/Echo-Server
- Size: 926 KB
- Stars: 272
- Watchers: 4
- Forks: 54
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Echo-Server / Docker / Kubernetes / Helm
[![Codecov](https://img.shields.io/codecov/c/github/ealenn/echo-server?style=for-the-badge&logo=codecov)](https://codecov.io/gh/Ealenn/Echo-Server)
[![CodeFactor Grade](https://img.shields.io/codefactor/grade/github/ealenn/echo-server?style=for-the-badge)](https://www.codefactor.io/repository/github/ealenn/echo-server)
[![GitHub stars](https://img.shields.io/github/stars/Ealenn/Echo-Server?style=for-the-badge&logo=github)](https://github.com/Ealenn/Echo-Server/stargazers)
[![GitHub issues](https://img.shields.io/github/issues/Ealenn/Echo-Server?style=for-the-badge&logo=github)](https://github.com/Ealenn/Echo-Server/issues)
[![DockerHub](https://img.shields.io/docker/pulls/ealen/echo-server.svg?style=for-the-badge&logo=docker)](https://hub.docker.com/repository/docker/ealen/echo-server)
[![DockerHub](https://img.shields.io/badge/SIZE-%3C%2030%20MB-1488C6?style=for-the-badge&logo=docker)](https://hub.docker.com/repository/docker/ealen/echo-server)> Read the docs : [https://ealenn.github.io/Echo-Server](https://ealenn.github.io/Echo-Server)
An echo server is a server that replicates the request sent by the client and sends it back.
Available:
![](https://img.shields.io/badge/linux-amd64-blue?style=flat-square&logo=docker)
![](https://img.shields.io/badge/linux-arm/v6-blue?style=flat-square&logo=docker)
![](https://img.shields.io/badge/linux-arm/v7-blue?style=flat-square&logo=docker)
![](https://img.shields.io/badge/linux-arm64/v8-blue?style=flat-square&logo=docker)
![](https://img.shields.io/badge/linux-ppc64le-blue?style=flat-square&logo=docker)
![](https://img.shields.io/badge/linux-s390x-blue?style=flat-square&logo=docker)- GET / POST / PUT / PATCH / DELETE
- Request (Query, Body, IPs, Host, Urls...)
- Request Headers / Response Headers
- Environment variables
- Control via Headers/Query
- Folders and Files
- Monitoring![docker](https://ealenn.github.io/Echo-Server/assets/images/docker.png)
- [Echo-Server / Docker / Kubernetes / Helm](#echo-server--docker--kubernetes--helm)
- [Table of contents](#table-of-contents)
- [Configuration](#configuration)
- [Use Echo-Server](#use-echo-server)
- [Custom responses](#custom-responses)
- [Custom HTTP Status Code](#custom-http-status-code)
- [Custom Body](#custom-body)
- [Custom Body with Environment variable value](#custom-body-with-environment-variable-value)
- [Custom Headers](#custom-headers)
- [Custom response latency](#custom-response-latency)
- [File/Folder explorer](#filefolder-explorer)
- [Combine custom actions](#combine-custom-actions)
- [Change default Queries/Request commands](#change-default-queriesrequest-commands)
- [Loggers](#loggers)
- [Format](#format)
- [Seq](#seq)
- [ELK](#elk)
- [Setting up](#setting-up)
- [Docker](#docker)
- [Docker-Compose](#docker-compose)
- [Kubernetes](#kubernetes)
- [Kubernetes with Helm](#kubernetes-with-helm)
- [NodeJS](#nodejs)
- [Contributing](#contributing)
- [Versioning](#versioning)
- [License](#license)
- [Development](#development)
- [Documentation](#documentation)
- [Tests](#tests)
- [Release notes](#release-notes)
- [Update Helm Chart](#update-helm-chart)| Environment | Helm | CLI | Default |
|---------------------|--------------------------------|----------------------|---------------|
| PORT | service.port | --port | `80` |
| LOGS__IGNORE__PING | application.logs.ignore.ping | --logs:ignore:ping | `false` |
| ENABLE__HOST | application.enable.host | --enable:host | `true` |
| ENABLE__HTTP | application.enable.http | --enable:http | `true` |
| ENABLE__REQUEST | application.enable.request | --enable:request | `true` |
| ENABLE__COOKIES | application.enable.cookies | --enable:cookies | `true` |
| ENABLE__HEADER | application.enable.header | --enable:header | `true` |
| ENABLE__ENVIRONMENT | application.enable.environment | --enable:environment | `true` |
| ENABLE__FILE | application.enable.file | --enable:file | `true` |![curl](https://ealenn.github.io/Echo-Server/assets/images/curl.png)
I use [jq](https://stedolan.github.io/jq) for nice `curl` results ;)
| Query | Header | Content | Conditions |
|---------------------|-----------------------|----------------------------------| ------------------------- |
| ?echo_code= | X-ECHO-CODE | HTTP code `200`, `404` | 200 <= `CODE` <= 599 |
| | | `404-401` or `200-500-301` | |
| ?echo_body= | X-ECHO-BODY | Body message | |
| ?echo_env_body= | X-ECHO-ENV-BODY | The key of environment variable | Enable environment `true` |
| ?echo_header= | X-ECHO-HEADER | Response Header `Lang: en-US` | Enable header `true` |
| ?echo_time= | X-ECHO-TIME | Wait time in `ms` | 0 <= `TIME` <= 30.000 |
| ?echo_file= | X-ECHO-FILE | Path of Directory or File | Enable file `true` |```bash
➜ curl -I --header 'X-ECHO-CODE: 404' localhost:8080
➜ curl -I localhost:8080/?echo_code=404HTTP/1.1 404 Not Found
``````bash
➜ curl -I --header 'X-ECHO-CODE: 404-300' localhost:8080
➜ curl -I localhost:8080/?echo_code=404-300HTTP/1.1 404 Not Found
HTTP/1.1 300 Multiple Choices
``````bash
➜ for i in {1..10}
➜ do
➜ curl -I localhost:8080/?echo_code=200-400-500
➜ doneHTTP/1.1 500 Internal Server Error
HTTP/1.1 400 Bad Request
HTTP/1.1 200 OK
HTTP/1.1 500 Internal Server Error
HTTP/1.1 200 OK
HTTP/1.1 500 Internal Server Error
``````bash
➜ curl --header 'X-ECHO-BODY: amazing' localhost:8080
➜ curl localhost:8080/?echo_body=amazing"amazing"
```#### Custom Body with Environment variable value
```bash
➜ curl --header 'X-ECHO-ENV-BODY: HOSTNAME' localhost:8080
➜ curl localhost:8080/?echo_env_body=HOSTNAME"c53a9ed79fa2"
``````bash
➜ for i in {1..10}
➜ do
➜ curl localhost:8080/?echo_env_body=HOSTNAME
➜ done"c53a9ed79fa2"
"f10c3af61e40"
"c53a9ed79fa2"
"f10c3af61e40"
"c53a9ed79fa2"
``````bash
➜ curl --header 'X-ECHO-HEADER: One:1' localhost:8080
➜ curl localhost:8080/?echo_header=One:1HTTP/1.1 200 OK
One: 1
``````bash
➜ curl --header 'X-ECHO-HEADER: One:1, Two:2' localhost:8080
➜ curl "localhost:8080/?echo_header=One:1,%20Two:2"HTTP/1.1 200 OK
One: 1
Two: 2
``````bash
➜ curl --header 'X-ECHO-TIME: 5000' localhost:8080
➜ curl "localhost:8080/?echo_time=5000"⏳... 5000 ms
```You can change default validations with
| ENVIRONMENT | CLI | Default |
|----------------------------|---------------------------| ---------|
| CONTROLS__TIMES__MIN | --controls:times:min | `0` |
| CONTROLS__TIMES__MAX | --controls:times:max | `60000` |*(Latency is defined in milliseconds)*
```bash
➜ curl --header 'X-ECHO-FILE: /' localhost:8080
➜ curl "localhost:8080/?echo_file=/"["app", "bin", "etc", "usr", "var"]
``````bash
➜ curl --header 'X-ECHO-CODE: 401' --header 'X-ECHO-BODY: Oups' localhost:8080
➜ curl "localhost:8080/?echo_body=Oups&echo_code=401"HTTP/1.1 401 Unauthorized
"Oups"
```## Change default Queries/Request commands
[Read the docs](https://ealenn.github.io/Echo-Server/pages/configuration/commands.html)
| Environment | CLI | Default |
|------------------------------------|------------------------------------|--------------------|
| COMMANDS__HTTPBODY__QUERY | --commands:httpBody:query | `echo_body` |
| COMMANDS__HTTPBODY__HEADER | --commands:httpBody:header | `x-echo-body` |
| COMMANDS__HTTPENVBODY__QUERY | --commands:httpEnvBody:query | `echo_env_body` |
| COMMANDS__HTTPENVBODY__HEADER | --commands:httpEnvBody:header | `x-echo-env-body` |
| COMMANDS__HTTPCODE__QUERY | --commands:httpCode:query | `echo_code` |
| COMMANDS__HTTPCODE__HEADER | --commands:httpCode:header | `x-echo-code` |
| COMMANDS__HTTPHEADERS__QUERY | --commands:httpHeaders:query | `echo_header` |
| COMMANDS__HTTPHEADERS__HEADER | --commands:httpHeaders:header | `x-echo-header` |
| COMMANDS__TIME__QUERY | --commands:time:query | `echo_time` |
| COMMANDS__TIME__HEADER | --commands:time:header | `x-echo-time` |
| COMMANDS__FILE__QUERY | --commands:file:query | `echo_file` |
| COMMANDS__FILE__HEADER | --commands:file:header | `x-echo-file` |[Read the docs](https://ealenn.github.io/Echo-Server/pages/configuration/loggers.html)
| Environment | CLI | Default |
|------------------------------------|------------------------------------|--------------------|
| LOGS__APP | --logs:app | `echo-server` |
| LOGS__LEVEL | --logs:level | `debug` |
| LOGS__FORMAT | --logs:format | `default` || LOG FORMAT | DESCRIPTION |
|-------------------|-----------------------------------------------------------------------------|
| default | Combine `line` & `object` |
| line | Simple `Fri, 22 Jan 2021 10:45:20 GMT | [GET] - http://localhost:8080/path` |
| object | JSON `{ "host": {}, http: {}, request: {}}` |[Full example](https://github.com/Ealenn/Echo-Server/tree/master/docker-compose) - [Documentation](https://ealenn.github.io/Echo-Server/pages/quick-start/docker-compose.html)
| Environment | CLI | Default |
|------------------------------------|------------------------------------|--------------------|
| LOGS__SEQ__ENABLED | --logs:seq:enabled | `false` |
| LOGS__SEQ__SERVER | --logs:seq:server | ` ` |
| LOGS__SEQ__KEY | --logs:seq:key | ` ` |
| LOGS__SEQ__LEVEL | --logs:seq:level | `info` |[Full example](https://github.com/Ealenn/Echo-Server/tree/master/docker-compose) - [Documentation](https://ealenn.github.io/Echo-Server/pages/quick-start/docker-compose.html)
[Read the docs](https://ealenn.github.io/Echo-Server/pages/quick-start/docker.html)
```bash
docker run -p 8080:80 ealen/echo-server
```[Read the docs](https://ealenn.github.io/Echo-Server/pages/quick-start/docker-compose.html)
**Sample**
```yaml
version: "3"
services:
echo-server:
image: ealen/echo-server
ports:
- 8080:80
```**With Seq**
```yaml
version: "3"
services:
echo:
image: ealen/echo-server
environment:
PORT: 80
LOGS__SEQ__ENABLED: "true"
LOGS__SEQ__SERVER: "http://seq:5341"
ports:
- 8080:80seq:
image: datalust/seq
environment:
ACCEPT_EULA: "Y"
ports:
- 3010:80
```[Read the docs](https://ealenn.github.io/Echo-Server/pages/quick-start/kubernetes.html)
```bash
curl -sL https://raw.githubusercontent.com/Ealenn/Echo-Server/master/docs/examples/echo.kube.yaml | kubectl apply -f -
```[Read the docs](https://ealenn.github.io/Echo-Server/pages/quick-start/helm.html) - [Artifact Hub](https://artifacthub.io/packages/helm/ealenn/echo-server)
```bash
helm repo add ealenn https://ealenn.github.io/charts
helm repo update
helm install --set ingress.enable=true --name echoserver ealenn/echo-server
```[Read the docs](https://ealenn.github.io/Echo-Server/pages/quick-start/nodejs)
```bash
# Dependencies
npm ci
# Run with node
node ./src/webserver --port 8080
# Run with npm script
PORT=8080 npm run start
```---
Please read [CONTRIBUTING.md](CONTRIBUTING.md) for details on our code of conduct, and the process for submitting pull requests to us.
We use [SemVer](http://semver.org/) for versioning.
For the versions available, see the [tags on this repository](https://github.com/Ealenn/Echo-Server/releases).This project is licensed under the GNU Lesser General Public License - see the [LICENSE.txt](https://github.com/Ealenn/Echo-Server/blob/master/LICENSE.txt) file for details.
---
Docker-Compose is available on `./docs` folder.
```bash
docker compose up -d
```The documentation is here [localhost:4000](http://localhost:4000)
```bash
npm ci
# Without code coverage
npm run test
# With code coverage
npm run test-with-coverage
``````bash
git log --pretty=oneline
```=> [https://github.com/Ealenn/charts/tree/master/charts/echo-server](https://github.com/Ealenn/charts/tree/master/charts/echo-server)