Nesse desafio trabalharemos no desenvolvimento de uma REST API para utilizar os dados do projeto Open Food Facts, que é um banco de dados aberto com informação nutricional de diversos produtos alimentícios.
O projeto tem como objetivo dar suporte a equipe de nutricionistas da empresa Fitness Foods LC para que eles possam revisar de maneira rápida a informação nutricional dos alimentos que os usuários publicam pela aplicação móvel.
- Prepare o projeto para ser disponibilizado no Github, copiando o conteúdo deste repositório para o seu (ou utilize o fork do projeto e aponte para o Github). Confirme que a visibilidade do projeto é pública (não esqueça de colocar no readme a referência a este challenge);
- O projeto deve utilizar a Linguagem específica na sua Vaga (caso esteja se candidatando). Por exempo: Python, R, Scala e entre outras;
- Considere como deadline 5 dias a partir do início do desafio. Caso tenha sido convidado a realizar o teste e não seja possível concluir dentro deste período, avise a pessoa que o convidou para receber instruções sobre o que fazer.
- Documentar todo o processo de investigação para o desenvolvimento da atividade (README.md no seu repositório); os resultados destas tarefas são tão importantes do que o seu processo de pensamento e decisões à medida que as completa, por isso tente documentar e apresentar os seus hipóteses e decisões na medida do possível.
- O projeto back-end deverá ser desenvolvido usando em NodeJS
- Documentação para configuração do projeto em ambientes de produção (como instalar, rodar e referências a libs usadas);
- Criar um banco de dados MongoDB usando Atlas: https://www.mongodb.com/cloud/atlas ou algum Banco de Dados SQL se não sentir confortável com NoSQL;
- Criar uma REST API usando NodeJS com as melhores práticas de desenvolvimento.
- Integrar a API com o banco de dados criado para persistir os dados
- Recomendável usar Drivers oficiais para integração com o DB
- Desenvolver Testes Unitários
Para a definição do modelo, consultar o arquivo products.json que foi exportado do Open Food Facts, um detalhe importante é que temos dois campos personalizados para poder fazer o controle interno do sistema e que deverão ser aplicados em todos os alimentos no momento da importação, os campos são:
imported_t
: campo do tipo Date com a dia e hora que foi importado;status
: campo do tipo Enum com os possíveis valores draft, trash e published;
Para prosseguir com o desafio, precisaremos criar na API um sistema de atualização que vai importar os dados para a Base de Dados com a versão mais recente do Open Food Facts uma vez ao día. Adicionar aos arquivos de configuração o melhor horário para executar a importação.
A lista de arquivos do Open Food, pode ser encontrada em:
- https://challenges.coode.sh/food/data/json/index.txt
- https://challenges.coode.sh/food/data/json/data-fields.txt
Onde cada linha representa um arquivo que está disponível em https://challenges.coode.sh/food/data/json/{filename}.
É recomendável utilizar uma Collection secundária para controlar os históricos das importações e facilitar a validação durante a execução.
Ter em conta que:
- Todos os produtos deverão ter os campos personalizados
imported_t
estatus
. - Limitar a importação a somente 100 produtos de cada arquivo.
Na REST API teremos um CRUD com os seguintes endpoints:
GET /
: Detalhes da API, se conexão leitura e escritura com a base de dados está OK, horário da última vez que o CRON foi executado, tempo online e uso de memória.PUT /products/:code
: Será responsável por receber atualizações do Projeto WebDELETE /products/:code
: Mudar o status do produto paratrash
GET /products/:code
: Obter a informação somente de um produto da base de dadosGET /products
: Listar todos os produtos da base de dados, adicionar sistema de paginação para não sobrecarregar oREQUEST
.
- Diferencial 1 Front End con ReactJs, configurar um projeto web para listar os produtos cadastrados na REST API.
- Diferencial 2 Configurar Docker no Projeto para facilitar o Deploy da equipe de DevOps;
- Diferencial 3 Configurar um sistema de alerta se tem algum falho durante o Sync dos produtos;
- Diferencial 4 Descrever a documentação da API utilizando o conceito de Open API 3.0;
- Diferencial 5 Escrever Unit Tests para os endpoints GET e PUT do CRUD;
- Deve conter o título de cada projeto
- Uma descrição de uma frase
- Como instalar e usar o projeto (instruções)
- Não esqueça o .gitignore
Avisar sobre a finalização e enviar para correção em: https://coodesh.com/review-challenge Após essa etapa será marcado a apresentação/correção do projeto.
- Será necessário compartilhar a tela durante a vídeo chamada;
- Deixe todos os projetos de solução previamente abertos em seu computador antes de iniciar a chamada;
- Deixe os ambientes configurados e prontos para rodar;
- Prepara-se pois você será questionado sobre cada etapa e decisão do Challenge;
- Prepare uma lista de perguntas, dúvidas, sugestões de melhorias e feedbacks (caso tenha).
Use a nossa comunidade para tirar dúvidas sobre o processo ou envie um e-mail para [email protected].