Giter Club home page Giter Club logo

desafio-ruby-on-rails's Introduction

Desafio programação - para vaga desenvolvedor Ruby on Rails

Por favor leiam este documento do começo ao fim, com muita atenção. O intuito deste teste é avaliar seus conhecimentos técnicos, para ser mais específico em Ruby on Rails. O teste consiste em parsear este arquivo de texto(FINANCEIRO) 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. Gaste o tempo que você quiser, porém normalmente você não deve precisar de mais do que algumas horas.

Instruções de entrega do desafio

  1. Primeiro, faça um fork deste projeto para sua conta no Github (crie uma se você não possuir).
  2. Em seguida, implemente o projeto tal qual descrito abaixo, em seu clone local.
  3. Por fim, envie via email o projeto ou o fork/link do projeto para [email protected]

Descrição do projeto

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 FINANCEIRO, normalize os dados e armazene-os em um banco de dados relacional e exiba essas informações em tela.

Sua aplicação web DEVE:

  1. Ter uma tela (via um formulário) para fazer o upload do arquivo(pontos extras se não usar um popular CSS Framework )
  2. Interpretar ("parsear") o arquivo recebido, normalizar os dados, e salvar corretamente a informação em um banco de dados relacional, se atente as documentações que estão logo abaixo.
  3. Exibir uma lista das operações importadas por lojas, e nesta lista deve conter um totalizador do saldo em conta
  4. Ser escrita obrigatoriamente em Ruby 2.0+ e Rails 5+
  5. 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.
  6. Git com commits bem descritos
  7. PostgreSQL
  8. Simplecov para disponibilizar o code coverage
  9. Docker compose (Pontos extras se utilizar)
  10. Readme file descrevendo bem o projeto e seu setup
  11. Incluir informação descrevendo como consumir o endpoint da API

Sua aplicação web não precisa:

  1. Lidar com autenticação ou autorização (pontos extras se ela fizer, mais pontos extras se a autenticação for feita via OAuth).
  2. Ser escrita usando framework Ruby on Rails (mas não há nada errado em usá-los também, use o que achar melhor).
  3. Documentação da api.(Será um diferencial e pontos extras se fizer)

Documentação do FINANCEIRO

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

Documentação sobre os tipos das transações

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 -

Avaliação

Seu projeto será avaliado de acordo com os seguintes critérios.

  1. Sua aplicação preenche os requerimentos básicos?
  2. Você documentou a maneira de configurar o ambiente e rodar sua aplicação?
  3. Você seguiu as instruções de envio do desafio?
  4. Qualidade e cobertura dos testes unitários.

Adicionalmente, tentaremos verificar a sua familiarização com as bibliotecas padrões (standard libs), bem como sua experiência com programação orientada a objetos a partir da estrutura de seu projeto.

Sucesso!

Solução

Ambiente de desenvolvimento

  1. Clone o repositório do Github e vá para o diretório contendo a solução:
  • git clone [email protected]:DiegoVilela/desafio-ruby-on-rails.git
  • cd desafio-ruby-on-rails
  1. Inicialize os containers:
  • docker-compose up -d --build
  1. Para executar os testes unitários e ver a porcentagem de cobertura:
  • docker-compose exec web coverage run --source='.' manage.py test
  • docker-compose exec web coverage report
  1. Acesse o sistema:
  1. (Opcional) Para verificar os logs execute:
  • docker-compose logs -f
  1. Para testar a funcionalidade de upload, pode ser utilizado o arquivo FINANCEIRO.txt disponível em /desafio-ruby-on-rails/code/FINANCEIRO.txt.

Ambiente de produção

  1. Antes de subir o ambiente de produção, encerre o ambiente de desenvolvimento:
  • docker-compose down -v
  1. Crie os arquivos de configuração no diretório desafio-ruby-on-rails:
  • .env.prod:
DEBUG=0
SECRET_KEY=change_me
DJANGO_ALLOWED_HOSTS=localhost 127.0.0.1 [::1]
SQL_ENGINE=django.db.backends.postgresql
SQL_DATABASE=finance_prod
SQL_USER=finance_user
SQL_PASSWORD=finance
SQL_HOST=db
SQL_PORT=5432
DATABASE=postgres
  • .env.prod.db:
POSTGRES_USER=finance_user
POSTGRES_PASSWORD=finance
POSTGRES_DB=finance_prod
  1. Inicie o ambiente de produção:
  • docker-compose -f docker-compose.prod.yml up -d --build
  1. (Opcional) Verifica se os três containers (nginx, web e db) estão rodando:
  • docker ps
  1. Execute as migrações do banco de dados:
  • docker-compose -f docker-compose.prod.yml exec web python manage.py migrate --noinput
  1. Colete os arquivos estáticos:
  • docker-compose -f docker-compose.prod.yml exec web python manage.py collectstatic --no-input --clear
  1. Execute os testes unitários:
  • docker-compose -f docker-compose.prod.yml exec web coverage run --source='.' manage.py test
  1. Acesse o sistema:

Observações

O ambiente de produção seria apenas para realização testes antes do deploy, onde seria provavelmente utilizado um serviço de banco de dados gerenciado como o RDS da AWS.

Foi utilizado usuário root nos containers db e nginx, o que não é recomendado em produção.

desafio-ruby-on-rails's People

Contributors

dgvilela avatar magnomatos822 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.