Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devenes/node-js-dummy-test
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.
https://github.com/devenes/node-js-dummy-test
body-parser container containerization docker docker-image ejs embedded-javascript embedded-javascript-templates express-js github-actions javascript js node node-ci node-js node-module nodejs npm npm-test pipeline
Last synced: about 2 months ago
JSON representation
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.
- Host: GitHub
- URL: https://github.com/devenes/node-js-dummy-test
- Owner: devenes
- License: apache-2.0
- Created: 2022-05-06T00:23:42.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-03-21T21:01:35.000Z (almost 2 years ago)
- Last Synced: 2024-05-02T02:31:47.577Z (8 months ago)
- Topics: body-parser, container, containerization, docker, docker-image, ejs, embedded-javascript, embedded-javascript-templates, express-js, github-actions, javascript, js, node, node-ci, node-js, node-module, nodejs, npm, npm-test, pipeline
- Language: JavaScript
- Homepage: https://devenes.github.io/node-js-dummy-test/
- Size: 1.11 MB
- Stars: 0
- Watchers: 2
- Forks: 9
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
To Do Web App served with Node.js and Express.js
About |
Features |
Technologies |
Requirements |
Starting |
License |
Author
## :dart: About ##
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.
## :sparkles: Features ##:heavy_check_mark: **Add tasks** \
:heavy_check_mark: **Store tasks** \
:heavy_check_mark: **Delete tasks**## :rocket: Technologies ##
The following tools were used in this project:
- [Node.js](https://nodejs.org/en/)
- [Javascript](https://www.javascript.com/)
- [Express.js](https://expressjs.com/)
- [Docker](https://www.docker.com/)
- [NPM](https://www.npmjs.com/)
- [Body-parser](https://www.npmjs.com/package/body-parser)
- [EJS](https://www.npmjs.com/package/ejs)
- [CSS](https://www.w3schools.com/css/default.asp)## 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
## :white_check_mark: Requirements ##
Before starting :checkered_flag:, you need to have [Git](https://git-scm.com) and [Node](https://nodejs.org/en/) installed.
## Output
![png](./readme/todo.jpg)
## :checkered_flag: Starting ##
```bash
# Clone this project
git clone https://github.com/devenes/node-js-dummy-test# Access
cd node-js-dummy-test# install all needed dependencies
npm install# Start the app in the browser
npm start# The server will initialize in the
```![start](./readme/start.jpg)
## Test App
Run
npm test
to run the tests![test](./readme/test.jpg)
## Build Docker Image with Dockerfile
Use the following commands in your `Dockerfile` to build a Docker image:
```dockerfile
FROM node:16-alpine
WORKDIR /app
COPY package*.json .
RUN npm install
COPY . .
EXPOSE 3000
CMD ["npm", "start"]
```## 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:```yml
name: Docker Deploymenton:
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:```yml
name: Node.js CI Teston:
push:
branches:
- "*"pull_request:
branches:
- "*"jobs:
build:
runs-on: ubuntu-lateststrategy:
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](https://docs.github.com/en/actions/monitoring-and-troubleshooting-workflows/using-workflow-run-logs)
- [Understanding GitHub Actions](https://docs.github.com/en/actions/learn-github-actions/understanding-github-actions)
- [Node.js](https://www.yusufsezer.com.tr/node-js-npm/)
- [Todo App with Node.js](https://medium.com/@atingenkay/creating-a-todo-app-with-node-js-express-8fa51f39b16f)
- [npm-run-script](https://docs.npmjs.com/cli/v8/commands/npm-run-script)
- [npm-test](https://docs.npmjs.com/cli/v8/commands/npm-test)
- [npm](https://www.npmjs.com/)
## :memo: License ##
This project is under license from Apache 2.0. For more details, see the [LICENSE](LICENSE) file.
Made with :heart: by devenes