Skip to content

Back-end do sistema para cadastro dos estudantes da cidade de Grossos/RN que utilizam dos ônibus fornecidos pela prefeitura para se deslocarem até as instituições de ensino da cidade vizinha, Mossoró/RN.

Notifications You must be signed in to change notification settings

ClaudionorOjr/studentbus-server

Repository files navigation

Student Bus

⚙️ Dependências

bcryptjs
$ npm i bcryptjs

# Instalação das tipagens
$ npm i @types/bcryptjs -D

Commitizen
$ npm i commitizen -D

# Configuração do Commitizen
$ npx commitizen init cz-conventional-changelog --save-dev --save-exact

Atualizar .git/hooks/prepare-commit-msg com o código:

#!/bin/bash
exec < /dev/tty && node_modules/.bin/cz --hook || true

Dotenv
$ npm i dotenv

ESLint
$ npm i eslint -D

# Instalando o plugin ESLint da Rocketseat para formatação do código
$ npm i @rocketseat/eslint-config

# Configuração do ESlint (opcional)
$ npx eslint --init

Adicionar ao .eslintrc.json:

{
  "extends": "@rocketseat/eslint-config/node",
  "rules": {
    "camelcase": "off",
    "no-useless-constructor": "off"
  }
}

Alterar o arquivo node.js nas dependências do plugin em node_modules para aceitar ponto e vírgula ao final das linhas.


Faker-js
# Lib para gerar dados fictícios
$ npm i @faker-js/faker -D

Fastify
$ npm i fastify

# Lib integrada ao fastify para a criação de Json Web Tokens
$ npm i @fastify/jwt

Semantic-release
$ npm i semantic-release -D

# Plugins adicionais
$ npm i @semantic-release/git @semantic-release/changelog -D

Arquivo de configuração do semantic-release, ``.releaserc.json`:

{
  "branches": ["main", { "name": "alpha", "prerelease": true }],
  "plugins": [
    "@semantic-release/commit-analyzer",
    "@semantic-release/release-notes-generator",
    "@semantic-release/github",
    "@semantic-release/changelog",
    [
      "@semantic-release/git",
      {
        "assets": ["package.json", "package-lock.json", "CHANGELOG.md"],
        "message": "chore(release): ${nextRelease.version} [skip ci]\n\n${nextRelease.notes}"
      }
    ]
  ]
}

TypeScript
# Instalação do TypeScript e das tipagens para node
$ npm i typescript @types/node -D

# Inicializando o TypeScript
$ npx tsc --init

# Permite que o node execute código TypeScript
$ npm i tsx -D

# Realiza a conversão do código de TypeScrip para JavaScript (build)
$ npm i tsup -D

Vitest
$ npm i vitest -D

# Plugin para que o vitest consiga entender os paths configurados no tsconfig
$ npm i vite-tsconfig-paths -D

# Interface para visualizar e executar os testes
$ npm i @vitest/ui -D

Criar arquivo de configuração do Vitest (vite.config.ts):

Adicionando o plugin nas configurações do Vitest

import { defineConfig } from 'vitest/config';
import tsconfigPaths from 'vite-tsconfig-paths';

export default defineConfig({
  plugins: [tsconfigPaths()],
});

Adicionar os scripts de testes ao package.json:

"scripts": {
  ...
  "test": "vitest run",
  "test:watch": "vitest",
  "test:coverage": "vitest run --coverage",
  "test:ui": "vitest --ui"
},

About

Back-end do sistema para cadastro dos estudantes da cidade de Grossos/RN que utilizam dos ônibus fornecidos pela prefeitura para se deslocarem até as instituições de ensino da cidade vizinha, Mossoró/RN.

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published