Skip to content

todo application built with Node.js and Express.js that lets you add tasks on a single page, store new and finished tasks in different arrays. Containerized with Docker and tested with NPM through GitHub Actions pipeline.

License

Notifications You must be signed in to change notification settings

infraform/docker-compose-todo

Repository files navigation

Node.js CI Test Docker Deployment Node.js Scan SARIF Node.js Coverage Node.js Coverage

To Do Web App served with Node.js and Express.js

Description

Simple To Do application built with Node.js and Express.js that lets you add tasks on a single page, store new and finished tasks in different arrays. Containerized with Docker and tested with NPM through GitHub Actions pipeline.

Embedded Javascript

EJS simply stands for Embedded Javascript. It is a simple templating language/engine that lets its user generate HTML with plain javascript. EJS is mostly useful whenever you have to output HTML with a lot of javascript. EJS is a simple templating language that lets you generate HTML markup with plain JavaScript. No religiousness about how to organize things. No reinvention of iteration and control-flow.

Body-Parser

Body-Parser is the Node. js body parsing middleware. It is responsible for parsing the incoming request bodies in a middleware before you handle it. This extracts the entire body portion of an incoming request stream and exposes it on req.body

Output

png

Terraform Output

png

Run App locally

  • Run npm install to install all needed dependencies
  • Then start the server using npm start
  • Navigate to your browser http://localhost:3000/ to view the app
  • start

    Test App

    Run npm test to run the tests

    test

    Build Docker Image with Dockerfile

    Use the following commands in your Dockerfile to build a Docker image:

    FROM node:16-alpine
    WORKDIR /app
    COPY package*.json ./
    RUN npm install
    COPY . .
    EXPOSE 3000
    CMD ["npm", "start"]
    • Note: Set your copy directory with ./ in Dockerfile. Not just with .

    • This is because the Docker Compose sometimes give you a warning about the . directory

    Containerization with Docker using GitHub Actions

    Create your own GitHub Actions workflow to build your Docker image and push it to DockerHub. Name your workflow file as dockerx.yml and add the following steps:

    name: Docker Deployment
    
    on:
      push:
        branches:
          - "release"
    
      pull_request:
        branches:
          - "release"
    
    jobs:
      dockerx:
        runs-on: ubuntu-latest
        steps:
          - name: Set up QEMU
            uses: docker/setup-qemu-action@v1
    
          - name: Set up Docker Buildx
            uses: docker/setup-buildx-action@v1
    
          - name: Login to DockerHub
            uses: docker/login-action@v1
            with:
              username: ${{ secrets.DOCKERHUB_USERNAME }}
              password: ${{ secrets.DOCKERHUB_PASSWORD }}
    
          - name: Build and push
            uses: docker/build-push-action@v2
            with:
              push: true
              tags: ${{ secrets.DOCKERHUB_USERNAME }}/todo-nodejs-vx:${{github.run_number}}

    Test Your Code with GitHub Actions

    Create your own GitHub Actions workflow to test your code. Name your workflow file as node.js.yml and add the following steps:

    name: Node.js CI Test
    
    on:
      push:
        branches:
          - "*"
    
      pull_request:
        branches:
          - "*"
    
    jobs:
      build:
        runs-on: ubuntu-latest
    
        strategy:
          matrix:
            node-version: [12.x, 14.x, 16.x]
    
        steps:
          - uses: actions/checkout@v3
    
          - name: Use Node.js ${{ matrix.node-version }}
            uses: actions/setup-node@v3
            with:
              node-version: ${{ matrix.node-version }}
              cache: "npm"
    
          - run: npm ci
    
          - run: npm run build --if-present
    
          - run: npm test

    Resources

    Using workflow run logs

    Understanding GitHub Actions

    Node.js

    Todo App with Node.js

    npm-run-script

    npm-test

    npm

    About

    todo application built with Node.js and Express.js that lets you add tasks on a single page, store new and finished tasks in different arrays. Containerized with Docker and tested with NPM through GitHub Actions pipeline.

    Topics

    Resources

    License

    Stars

    Watchers

    Forks

    Releases

    No releases published

    Packages

    No packages published