Por favor leiam este documento do começo ao fim, com muita atenção. O intuito deste teste é avaliar seus conhecimentos técnicos em programação. O teste consiste em parsear este arquivo de texto(CNAB) e salvar suas informações (transações financeiras) em uma base de dados a critério do candidato. Este desafio deve ser feito por você em sua casa. O tempo limite para esse teste é de uma semana a partir da data do envio do teste.
- Primeiro, faça um fork deste projeto para sua conta no Github (crie uma se você não possuir).
- Em seguida, implemente o projeto tal qual descrito abaixo, em seu clone local.
- Por fim, envie via email o projeto ou o fork/link do projeto para seu contato [email protected].
Você recebeu um arquivo CNAB com os dados das movimentações finanaceira de várias lojas. Precisamos criar uma maneira para que estes dados sejam importados para um banco de dados.
Sua tarefa é criar uma interface web que aceite upload do arquivo CNAB, normalize os dados e armazene-os em um banco de dados e exiba essas informações em tela.
Sua aplicação web DEVE:
- Ter uma tela (via um formulário) para fazer o upload do arquivo.
- Interpretar ("parsear") o arquivo recebido, normalizar os dados, e salvar corretamente a informação em um banco de dados de sua preferência, se atente as documentações que estão logo abaixo.
- Exibir uma lista das operações importadas por lojas, e nesta lista deve conter um totalizador do saldo em conta.
- Ser escrita na sua linguagem de programação de preferência.
- Ser simples de configurar e rodar, funcionando em ambiente compatível com Unix (Linux ou Mac OS X). Ela deve utilizar apenas linguagens e bibliotecas livres ou gratuitas.
- Git com commits atomicos e bem descritos.
- PostgreSQL, MySQL ou MongoDB.
- Testes automatizados (pontos extreas se utilizar).
- Docker compose (Pontos extras se utilizar).
- Readme file descrevendo bem o projeto e seu setup.
Sua aplicação web não precisa:
- Lidar com autenticação ou autorização
- Ser escrita usando algum framework específico (mas não há nada errado em usá-los também, use o que achar melhor).
- Documentação da API - Swagger (Será um diferencial e pontos extras se fizer)
Descrição do campo | Inicio | Fim | Tamanho | Comentário |
---|---|---|---|---|
Tipo | 1 | 1 | 1 | Tipo da transação |
Data | 2 | 9 | 8 | Data da ocorrência |
Valor | 10 | 19 | 10 | Valor da movimentação. Obs. O valor encontrado no arquivo precisa ser divido por cem(valor / 100.00) para normalizá-lo. |
CPF | 20 | 30 | 11 | CPF do beneficiário |
Cartão | 31 | 42 | 12 | Cartão utilizado na transação |
Hora | 43 | 48 | 6 | Hora da ocorrência atendendo ao fuso de UTC-3 |
Dono da loja | 49 | 62 | 14 | Nome do representante da loja |
Nome loja | 63 | 81 | 19 | Nome da loja |
Tipo | Descrição | Natureza | Sinal |
---|---|---|---|
1 | Débito | Entrada | + |
2 | Boleto | Saída | - |
3 | Financiamento | Saída | - |
4 | Crédito | Entrada | + |
5 | Recebimento Empréstimo | Entrada | + |
6 | Vendas | Entrada | + |
7 | Recebimento TED | Entrada | + |
8 | Recebimento DOC | Entrada | + |
9 | Aluguel | Saída | - |