This project is a simple RESTful API for managing a Todo List built using Golang, Gin, and a global in-memory store (which can be later replaced with Postgres or Redis).
If you are new to the project, follow these steps to set up the environment and install the necessary dependencies.
- Go 1.16 or higher is required. You can install Go from the official website.
-
Clone the repository Clone the project from GitHub:
git clone git@github.com:nicehorse06/todo-list-api.git cd todo-list-api
-
Initialize the Go module Ensure the project is using Go modules. Run the following command to initialize Go modules if it hasn't been done yet:
go mod init github.com/nicehorse06/todo-list-api
-
Install dependencies Use
go get
to install all required dependencies for this project, including the Gin framework and testing libraries:go get -u github.com/gin-gonic/gin go get -u github.com/stretchr/testify/assert
Alternatively, if the
go.mod
file is present, run the following to install dependencies:go mod tidy
-
Run the application After installing dependencies, you can run the project with the following command:
go run main.go
-
Run the tests To run the test cases and ensure everything is working properly, execute:
go test -v
Here are some useful Go CLI commands to work with the project.
Use the following command to start the API server:
go run main.go
This will start the server at localhost:8080
, and you can access the endpoints such as http://localhost:8080/tasks
.
Use the following command to run all the test cases:
go test -v
The -v
flag provides verbose output, showing detailed information for each test case.
The following endpoints are available:
-
Create a Task
- POST
/tasks
- Body parameters:
title
,description
,due_date
- Response: Returns the created task details
- POST
-
Get All Tasks
- GET
/tasks
- Response: Returns a list of all tasks
- GET
-
Get a Single Task
- GET
/tasks/:id
- Parameters:
id
(the task ID) - Response: Returns the task details by its ID
- GET
-
Update a Task
- PUT
/tasks/:id
- Parameters:
id
(the task ID) - Body parameters:
title
,description
,status
- Response: Returns the updated task details
- PUT
-
Delete a Task
- DELETE
/tasks/:id
- Parameters:
id
(the task ID) - Response: Deletes the task and returns a success message
- DELETE
-
Mark Task as Complete
- PATCH
/tasks/:id/complete
- Parameters:
id
(the task ID) - Response: Marks the task as complete and returns the updated task details
- PATCH