Aplicações testáveis com Node.js
Essa aplicação é utilizada como base para demonstrar como podemos utilizar de patterns conhecidos na programação para facilitar a escrita de testes automatizados: https://www.youtube.com/watch?v=XmcZyCRtHqw
Esse repositório contém uma aplicação Node.js de base que possui apenas uma funcionalidade de criação de pedidos (src/create-order.js
).
Essa funcionalidade salva as informações do pedido no banco de dados e determina a prioridade do pedido com base no seu valor: Se o valor for maior que 5000 então é um pedido prioritário;
Ainda na aplicação, possuímos um arquivo de testes para a funcionalidade (src/create-order.test.js
) que basicamente testa:
- Se é possível criar um pedido;
- Se os pedidos estão sendo priorizados corretamente;
- Se o e-mail de "novo pedido" está sendo enviado;
Dependências
Essa aplicação precisa da v19 do Node.js para funcionar por estar usando o Test Runner nativo da plataforma disponível somente nessa versão e nas futuras.
Executando
Para o projeto funcionar é necessário que você esteja com o PostgreSQL executando em sua máquina. Rcomendo utilizar o Docker para subir o banco de dados:
docker run --name pg -e POSTGRESQL_USERNAME=docker -e POSTGRESQL_PASSWORD=docker -e POSTGRESQL_DATABASE=app -p 5432:5432 bitnami/postgresql
Além disso, é necessário criar um arquivo .env
na raiz do projeto com as variáveis ambiente para conexão com o banco de dados:
PGUSER=docker
PGHOST=localhost
PGPASSWORD=docker
PGDATABASE=app
PGPORT=5432
Branches
main
: Código finalizado!base
: Código base sem utilização de nenhum pattern para melhorar a experiência de testes;mocking
: Código que utiliza o pattern de repository para operações no banco com mocking;in-memory
: Código que utiliza o pattern de in-memory databases para suprir o uso de mocking;