This project demonstrates a simple ToDo list application built with a Vue.js frontend, a Node.js/Express backend, and a PostgreSQL database, all orchestrated using Docker Compose. It also includes pgAdmin for database management and setup for unit/integration/E2E testing.
todo-app/
├── frontend/                 # Vue.js Frontend Application
│   ├── public/
│   ├── src/
│   ├── tests/unit/
│   ├── .env.development      # Frontend development environment variables
│   ├── package.json
│   ├── vue.config.js
│   ├── nginx.conf            # Nginx configuration for serving Vue app and proxying API
│   └── Dockerfile            # Dockerfile for building frontend image
├── backend/                  # Node.js/Express Backend API
│   ├── src/
│   │   ├── routes/
│   │   ├── db.js
│   │   └── app.js
│   ├── tests/integration/    # Backend integration tests
│   ├── package.json
│   └── Dockerfile            # Dockerfile for building backend image
├── database/                 # PostgreSQL Database Initialization
│   └── init.sql              # SQL script for table creation and initial data
├── cypress/                  # End-to-End (E2E) tests with Cypress
│   ├── integration/
│   └── support/
├── .env                      # Environment variables for Docker Compose (e.g., database credentials)
├── docker-compose.yml        # Docker Compose configuration for all services
└── README.md                 # This file
- Docker Desktop (or Docker Engine and Docker Compose) installed on your machine.
- Node.js and npm (or yarn) installed for local development and running tests outside Docker.
- 
Clone the Repository (or create the files manually): If you're copying the files, ensure the directory structure matches the one above. 
- 
Create the .envfile: In the root directory of thetodo-appproject, create a file named.envand add the following content. You can change the values as needed.DB_USER=dockeruser DB_PASSWORD=dockerpassword DB_NAME=todo_db PGADMIN_EMAIL=admin@example.com PGADMIN_PASSWORD=adminpassword 
- 
Install Node.js Dependencies (Optional, but recommended for local testing/development): While Docker will install dependencies inside containers, it's good practice to have them locally for development tools and running tests directly. # In the root 'todo-app' directory cd frontend npm install cd ../backend npm install cd .. # For Cypress E2E tests (if you plan to run them locally) npm install cypress --prefix ./cypress # Install cypress into its own directory 
- 
Build and Run with Docker Compose: Navigate to the root todo-appdirectory in your terminal and run:docker-compose up --build -d - docker-compose up: Starts all services defined in- docker-compose.yml.
- --build: Forces Docker Compose to rebuild images if Dockerfiles or their contexts have changed.
- -d: Runs the containers in "detached" mode (in the background).
 
- 
Verify Services: - Frontend: Open your web browser and go to http://localhost:8080. You should see the ToDo list application.
- Backend API: You can test the backend directly by visiting http://localhost:3000/todosin your browser or using a tool like Postman/Insomnia. You should see the initial dummy data in JSON format.
- pgAdmin: Open http://localhost:5050in your browser.- Log in with the PGADMIN_DEFAULT_EMAILandPGADMIN_DEFAULT_PASSWORDfrom your.envfile.
- To connect to your database:
- Right-click on "Servers" in the left panel and select "Register" -> "Server...".
- General Tab:
- Name: ToDo Database(or any descriptive name)
 
- Name: 
- Connection Tab:
- Host name/address: database(This is the service name of the database container indocker-compose.yml)
- Port: 5432
- Maintenance database: todo_db(orpostgres)
- Username: dockeruser(from your.env)
- Password: dockerpassword(from your.env)
 
- Host name/address: 
- Click "Save". You should now be able to browse the todo_dbdatabase, its schemas, and thetodostable.
 
 
- Log in with the 
 
- Frontend: Open your web browser and go to 
To stop and remove the running containers, networks, and volumes (for persistent data):
docker-compose down -v- docker-compose down: Stops and removes containers and default network.
- -v: Also removes the volumes defined in- docker-compose.yml(- db_dataand- pgadmin_data). Use this if you want a clean slate for your database data. If you want to keep the data, omit- -v.
This project includes setups for unit, integration, and end-to-end (E2E) testing.
These tests focus on individual Vue components.
- Location: frontend/tests/unit/
- How to Run:
# Run inside the frontend container docker-compose run --rm frontend npm run test:unit
These tests verify the backend API endpoints and their interaction with mocked or real database calls.
- Location: backend/tests/integration/
- How to Run:
# Run inside the backend container docker-compose run --rm backend npm test 
These tests simulate user interactions in a real browser, interacting with the fully running application (frontend, backend, database).
- Location: cypress/integration/
- How to Run:
- Ensure all Docker containers are running:
docker-compose up -d 
- Open the Cypress test runner:
Cypress will open a UI where you can select and run your tests.# From the root 'todo-app' directory npx cypress open --project ./cypress
- Alternatively, run in headless mode (useful for CI/CD):
# From the root 'todo-app' directory npx cypress run --project ./cypress
 
- Ensure all Docker containers are running:
- Docker Logs:
- View logs for all services: docker-compose logs
- View logs for a specific service (e.g., backend): docker-compose logs backend
- Follow logs in real-time: docker-compose logs -f frontend
 
- View logs for all services: 
- Exec into containers:
- Get a shell inside a running container (e.g., backend): docker-compose exec backend sh(orbash)
- This allows you to inspect files, run commands, or debug directly within the container's environment.
 
- Get a shell inside a running container (e.g., backend): 
- pgAdmin: Use the web interface at http://localhost:5050to inspect database tables, run queries, and verify data persistence.
- Health Checks: The databaseservice indocker-compose.ymlincludes a health check. You can check the health status of services usingdocker-compose ps.