Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/0xvbetsun/todo-app

Simple todo-app with documentation and e2e testing via Postman
https://github.com/0xvbetsun/todo-app

go golang newman openapi postman todo-app

Last synced: 6 days ago
JSON representation

Simple todo-app with documentation and e2e testing via Postman

Awesome Lists containing this project

README

        

# Todo App

The project represents the configuration and setup basic server for TODO application with auto-testing and OpenAPI specification from postman's collection

![CI](https://github.com/vbetsun/todo-app/workflows/CI/badge.svg)
[![GoReport](https://goreportcard.com/badge/github.com/vbetsun/todo-app)](https://goreportcard.com/report/github.com/vbetsun/todo-app)
![license](https://img.shields.io/github/license/vbetsun/todo-app)
[![GitHub go.mod Go version of a Go module](https://img.shields.io/github/go-mod/go-version/vbetsun/todo-app.svg)](https://github.com/vbetsun/todo-app)
[![GoDoc](https://pkg.go.dev/badge/github.com/vbetsun/todo-app)](https://pkg.go.dev/github.com/vbetsun/todo-app)

## Prerequisites

- Git
- Docker
- Docker Compose

## How to Install

Clone from github and navigate to the project's folder
```sh
# HTTPS
git clone https://github.com/vbetsun/todo-app.git

# SSH
git clone [email protected]:vbetsun/todo-app.git

cd todo-app
```

## How to Deploy

```sh
cp ./deployments/.env.example ./deployments/.env
```

change env variables for your needs

```dotenv
PORT=8000 # port for serving API
DOCS_PORT=8080 # port for serving OpenAPI documentation
POSTGRES_HOST=localhost # host of postgre db
POSTGRES_PASSWORD=someStr0ngPass # password to psql
```

and start the application via `docker compose`. It should start the API server, PostgreSQL database, pgAdmin and OpenAPI documentation, which you can see on http://localhost:${DOCS_PORT}

```sh
docker compose -f ./deployments/docker-compose.yml up -d
```

after that you have to run migrations

```sh
make migrate-up
```

## Database structure

![ERD](./docs/ERD.png)

## How to Test

for testing our API we're going to use POstman collection via Newman

```sh
make test-e2e
```