Bem vindo(a)! Esse é o Delivery Much Tech Challenge.
Aqui você terá todas as informações para realizar o seu desafio.
O tempo sugerido para conclusão do desafio é de cinco dias, mas não é uma regra. Estamos mais interessados em observar a qualidade da solução do que o tempo.
Quando sua solução estiver pronta, envie um e-mail para tech.challenge@deliverymuch.com.br
com o link do seu repositório no Github. Seu código será analisado pelo nosso time de engenheiros. Após a análise, enviaremos o feedback e as instruções dos próximos passos!
Bom desafio!
Você deve construir uma API que recebe ingredientes como parâmetro de entrada em uma chamada GET e retorna uma lista de receitas. Utilize as APIs públicas da RecipePuppy (http://www.recipepuppy.com/about/api/) e da Giphy (https://developers.giphy.com/docs/) para obter os dados necessários.
A API deve receber como parâmetro um conjunto de ingredientes (máximo 3) e deve retornar os itens utilizados para realizar a busca; e uma lista de receitas.
Cada item lista de receitas deve possuir 4 atributos:
- Título da receitam;
- Lista de ingredientes;
- Link para acessar a receita;
- Link de um gif para a receita.
A API possui apenas um endpoint, que deve respeitar a seguinte chamada:
http://{HOST}/recipes/?i={ingredient_1},{ingredient_2}
Exemplo:
http://127.0.0.1/recipes/?i=onion,tomato
A resposta dessa requisição deve seguir a seguinte estrutura:
{
"keywords": ["onion", "tomato"],
"recipes": [{
"title": "Greek Omelet with Feta",
"ingredients": ["eggs", "feta cheese", "garlic", "red onions", "spinach", "tomato", "water"],
"link": "http://www.kraftfoods.com/kf/recipes/greek-omelet-feta-104508.aspx",
"gif": "https://media.giphy.com/media/xBRhcST67lI2c/giphy.gif"
},{
"title": "Guacamole Dip Recipe",
"ingredients": ["avocado", "onions", "tomato"],
"link":"http://cookeatshare.com/recipes/guacamole-dip-2783",
"gif":"https://media.giphy.com/media/I3eVhMpz8hns4/giphy.gif"
}
]
}
- Utilizar NodeJS para criar a aplicação;
- Toda configuração e chaves de acesso (se necessário) devem ser acessadas em um arquivo de ambiente. Sua configuração deve estar documentada no README;
- Para obter o gif no Giphy, utilize o título da receita recebido pelo RecipePuppy;
- Os ingredientes recebidos pelo RecipePuppy são recebidos em String. Organize os ingredientes em um array e ordene esse array por ordem alfabética;
- Se algum dos serviços externos estiver indisponível o projeto deverá informar o usuário dessa indisponibilidade;
- Utilizar Docker para executar o projeto;
- O projeto está completo para ser executado?
- O projeto atende ao que se propõe fazer?
- Todos requisitos foram atendidos?
- O código está de acordo com o guia de estilo do NodeJS?
- O código está bem estruturado?
- O código está fluente na linguagem?
- O código faz o uso correto de Design Patterns?
- O código foi entregue com um arquivo de README claro de como se guiar?
- A documentação foi suficiente para executar o projeto?
- Os commits são pequenos e consistentes?
- As mensagens de commit são claras?
- O código possibilita expansão para novas funcionalidades?
- O código é Don't Repeat Yourself?
- O código é fácil de compreender?
- O código possui configuração de lint?
- O código possui testes unitários?