- Instalar as dependências:
npm install
- Rodar a aplicação localmente:
npm run dev
- rodar a aplicação no container Docker
docker-compose up
- MongoDB URL
Uma boa opção aqui é criar uma conta em:
e no próprio passo a passo do sistema é possível criar um banco e pegar uma URL utilizando a interface do Mongo Atlas
- Testes
Para executa-los: npm run test
coverage: npm run test:coverage
- Documentação dos Endpoints
https://studio.apollographql.com/public/Voltbras-Challenge/variant/current
- Vídeo
https://www.youtube.com/watch?v=aEBv-Uu5AtQ&ab_channel=SamuelAlves
[✅] Crie o schema GraphQL com uma query suitablePlanets: que retorna os dados dos planetas com gravidade alta.
[✅] Crie uma mutation installStation: que dado um planeta, instala uma estação de carregamento no planeta.
[✅] Crie uma query stations: que irá listar todas as estações instaladas nos planetas.
[✅] Crie uma mutation recharge: que dado uma estação e um datetime de quanto a recarga irá finalizar, realiza uma recarga, começando a partir do momento em que a mutation foi chamada e finalizando com a datetime passada.
[✅] Documentação do projeto: explicação de como rodá-lo.
[✅] Repositório privado no GitHub ou GitLab.
[✅] Vídeo curto demonstrando o funcionamento básico do sistema. Requisitos Extras
[✅] Adicione testes usando Jest ou qualquer outro framework para testes.
[✅] Usar Typescript.
[✅] Docker-compose para simplificar a execução do servidor e do DB.
[✅] ORM (Foi usada Mongoose): Usamos prisma mas sinta-se livre para usar qualquer ORM.
[✅] Adicione autenticação: apenas um usuário autenticado poderá fazer uma recarga ou uma reserva.
[✅] Crie uma mutation reservation: que dado uma estação, um usuário e um intervalo de tempo, cria uma reserva da estação para o usuário naquele determinado intervalo de tempo.
[✅] Crie uma query stationHistory: onde será possível visualizar o histórico de recargas de uma estação (mostrar o horário, o tempo de duração da recarga e o usuário que realizou-a).
-
Todos os campos exceto login e createUser estão com autenticação
-
Há um serviço dentro do módulo de recharges (Agenda) configurado para a cada 15 segundos (para fins de demonstração) que verifica o status das recharges e atualiza no banco
-
Há também alguns endpoints extras e testados, principalmente no módulo de users e de stations
-
TriggerReservationé o nome do endpoint que aciona uma reserva pelo ID, e caso seja possível ativa uma recarga com o endDate alinhado com o da reserva -
O Token gerado no Login deve ser adicionado como Authorization no Apollo Studio Bearer "valorDoTokenSemAspas"
-
Infelizmente não tive tempo pra fazer mais testes de integração, mas tem um exemplo com o módulo de Stations usando recursos nativos do Apollo
-
Os arquivos de abstração "interfaces" e os contratos foram feitos com Classe Abstrata no caso da inversão de controle principalmente. O motivo é que interfaces não transpilam para JS (fazem apenas type check estático) e Classes Abstratas, além do typecheck da class, transpilam(pois existe class em JS). Permitindo que o contrato seja validado em run-time. fonte: https://betterprogramming.pub/how-to-follow-the-dependency-inversion-principle-in-nestjs-and-angular-8d344303dc3b
-
Coisas que eu queria ter feito eu não deu tempo: Logging mais robusto, Error Handler customizado, padronização de alguns nomes, um serviço de trigger de recharge por reservas, paginação, caching (no caso dos planetas) etc.