Ao iniciar este projeto, você concorda com as diretrizes do Código de Ética e Conduta e do Manual da Pessoa Estudante da Trybe.
Você já usa o GitHub diariamente para desenvolver os exercícios, certo? Agora, para desenvolver os projetos, você deverá seguir as instruções a seguir. Tenha atenção a cada passo, e se tiver qualquer dúvida nos envie por Slack! #vqv 🚀
Aqui você vai encontrar os detalhes de como estruturar o desenvolvimento do seu projeto a partir desse repositório, utilizando uma branch específica e um Pull Request para colocar seus códigos.
- Boas vindas ao repositório do projeto App de Delivery!
- Sumário
- Contexto
- Habilidades
- Entregáveis
- Instruções para entregar seu projeto:
- Requisitos do projeto
Fluxo Comum
01login.test
- 1 - Crie uma tela de login que deve ser acessível pelos endpoints / e /login no navegador
- 2 - Crie os elementos da tela de login com os data-testids disponíveis no protótipo
- 3 - Desenvolva a tela de login de maneira que ela impossibilite o login com dados mal-formatados
- 4 - Desenvolva a tela de login de maneira que ela impossibilite o login com dados válidos, porém inexistentes no banco de dados
- 5 - Desenvolva a tela de login de maneira que ela possibilite fazer o login com dados válidos e existentes no banco de dados
02register.test
- 6 - Crie uma tela de registro que deve ser acessível via endpoint /register no navegador e pelo botão de registro na tela de login
- 7 - Crie os elementos da tela de registro com os data-testids disponíveis no protótipo
- 8 - Desenvolva a tela de registro de maneira que ela impossibilite o cadastro com dados mal-formatados
- 9 - Desenvolva a tela de registro de maneira que ela possibilite cadastrar com dados válidos
- 10 - Desenvolva a tela de registro de maneira que ela impossibilite o cadastro de um usuário já existente
Fluxo do Cliente
03customer_products.test
- 11 - Crie uma tela de produtos do cliente contendo uma barra de navegação - navbar - que servirá também para demais telas das pessoas usuárias
- 12 - Desenvolva a tela de produtos do cliente criando os demais elementos com os data-testids disponíveis no protótipo
- 13 - Desenvolva a tela de produtos do cliente de forma que ela pressuponha dados válidos da pessoa usuária armazenados no localStorage
- 14 - Desenvolva a tela de produtos do cliente de forma que os cards de todos os produtos pré-cadastrados contenham os valores corretos
- 15 - Desenvolva a tela de produtos do cliente de forma que o preço total esteja correto após a adição de itens aleatórios
- 16 - Desenvolva a tela de produtos do cliente de forma que haja um botão de carrinho que redirecionará para a tela de checkout caso itens sejam adicionados
04customer_checkout.test
- 17 - Crie uma tela de checkout do cliente com elementos com os data-testids disponíveis no protótipo
- 18 - Desenvolva a tela de checkout do cliente de forma a possuir os dados corretos do carrinho e preço total
- 19 - Desenvolva a tela de checkout do cliente de forma que seja possível remover itens do carrinho
- 20 - Desenvolva a tela de checkout do cliente de forma a nos redirecionar para a tela de detalhes do pedido feito após a finalização do mesmo
- 21 - Desenvolva a tela de checkout do cliente de forma a gerar uma nova venda na tabela sales, assim como relações em salesProducts ao finalizar o pedido
05customer_orders.test
- 22 - Crie uma tela de pedidos do cliente com elementos a partir dos data-testids disponíveis no protótipo
- 23 - Desenvolva a tela de pedidos do cliente de forma a conter a lista de pedidos do mesmo com os dados corretos
- 24 - Desenvolva a tela de pedidos do cliente de forma a dar acesso à tela de detalhes de um pedido ao clicar no card do mesmo
06customer_order_details.test
Fluxo da Pessoa Vendedora
07seller_orders.test
- 27 - Crie uma tela de pedidos da pessoa vendedora com elementos a partir dos data-testids disponíveis no protótipo
- 28 - Desenvolva a tela de pedidos da pessoa vendedora de forma a conter a lista de pedidos do mesmo com os dados corretos
- 29 - Desenvolva a tela de pedidos da pessoa vendedora de forma a dar acesso à tela de detalhes de um pedido ao clicar no card do mesmo
08seller_order_details.test
Validação do Status do Pedido
- 32 - Desenvolva a tela de detalhes do pedido da pessoa vendedora de forma a ser capaz de alterar o status do pedido
09customer_seller_status_sync.test
- 33 - Garanta que o status do pedido atualizado na tela de detalhes do pedido da pessoa vendedora seja refletido na tela de detalhes do pedido do cliente após atualização das páginas
- 34 - Garanta que o status do pedido atualizado na tela de detalhes do pedido da pessoa vendedora seja refletido na tela de lista de pedidos do cliente após atualização das páginas
- 35 - Garanta que o status do pedido atualizado na tela de detalhes do pedido do cliente seja refletido na tela de lista de pedidos da pessoa vendedora após atualização das páginas
10customer_seller_socket_status_sync.test
- 36 - Desenvolva a tela de detalhes do pedido da pessoa vendedora de forma a interagir em tempo real com a tela de detalhes do pedido do cliente
- 37 - Desenvolva a tela de detalhes do pedido da pessoa vendedora de forma a interagir em tempo real com a tela de lista de pedidos do cliente
- 38 - Desenvolva a tela de detalhes do pedido do cliente de forma a interagir em tempo real com a tela de lista de pedidos da pessoa vendedora
Fluxo da Pessoa Administradora
11admin_manage_users.test
- 39 - Crie uma tela de pessoa administradora com elementos a partir dos data-testids disponíveis no protótipo
- 40 - Desenvolva a tela da pessoa administradora de forma a validar o formulário de cadastro
- 41 - Desenvolva a tela da pessoa administradora de forma que seja possível cadastrar pessoas usuárias válidas
- 42 - Desenvolva a tela da pessoa administradora de forma que ela impossibilite o cadastro de pessoas usuárias já existentes
- 43 - (
Bônus
) Desenvolva a tela da pessoa administradora de forma que haja uma tabela de pessoas usuárias cadastradas - 44 - (
Bônus
) Desenvolva a tela da pessoa administradora de forma que seja possível deletar pessoas usuárias na tabela
Cobertura de Testes
12coverage_tests.test
- 45 - Crie testes que cubram no mínimo 30 por cento dos arquivos do front-end e back-end em src com um mínimo de 75 linhas cobertas em cada
- 46 - (
Bônus
) Crie testes que cubram no mínimo 60 por cento dos arquivos do front-end e back-end em src com um mínimo de 150 linhas cobertas em cada - 47 - (
Bônus
) Crie testes que cubram no mínimo 90 por cento dos arquivos do front-end e back-end em src com um mínimo de 225 linhas cobertas em cada
Extra não avaliativo
- Depois de terminar o desenvolvimento
- Revisando um pull request
- Avisos finais
A distribuidora de cervejas da dona Tereza está se informatizando! 🚀 Seu negócio, antes focado em um local específico da cidade, passou a receber uma quantidade massiva de encomendas de outros pontos, expandindo sua atuação, sobretudo via delivery. Isso tudo graças ao excelente preço das bebidas e atendimento da equipe de vendas.
Agora a distribuidora possui alguns pontos de venda na cidade para agilizar no atendimento dessas áreas. Cada ponto de venda, por sua vez, possui uma pessoa vendedora responsável.
Como seu antigo sistema, que era um conjunto de planilhas, já não atende a necessidade do negócio, pois gera muita manutenção, dona Tereza procurou a sua equipe de pessoas desenvolvedoras com uma ideia de aplicativo que pudesse agilizar a vida de sua equipe e das pessoas que compram seus produtos. O aplicativo precisa:
- Ter acesso via login: tanto clientes como pessoas vendedoras, assim como a própria dona Tereza, que administra o sistema, devem ter acesso ao aplicativo via login, porém para funções diferentes: (1) A pessoa cliente, que compra da lista de produtos; (2) A pessoa vendedora, que aprova, prepara e entrega; (3) A pessoa administradora, que gerencia quem usa o aplicativo;
- Fazer a comunicação entre clientes e pessoas vendedoras: a pessoa cliente faz o pedido via "carrinho de compras" e a pessoa vendedora aprova, prepara e envia esse pedido. Quando o produto é recebido por quem comprou, essa pessoa marca o pedido como "recebido". Ambos devem possuir detalhes sobre seus pedidos;
- Funcionar em tempo real: as telas de pedidos/detalhes do pedido devem ser atualizadas em tempo real, à medida que essas interações acontecem. Se a pessoa cliente faz o pedido, o mesmo deve aparecer para a pessoa vendedora em seu dash de pedidos sem que ela precise atualizar a página. A pessoa cliente, por sua vez, deve ter as informações sobre seu pedido também atualizadas em tempo real, ou seja, ter informações se o pedido está sendo preparado ou se já saiu pra entrega;
Sua equipe, que já possui uma boa experiência com desenvolvimento, em pouco tempo apresentou um protótipo e um Diagrama de ER conforme imagem:
A ideia da sua equipe já pressupõe alguma escalabilidade, dado que foram estabelecidas algumas entidades genéricas no banco de dados e componentização no front-end, para que, caso o sistema cresça, não seja muito difícil mudar e ampliar essa estrutura.
A proposta encantou, mas dona Tereza quer ver o negócio em ação! Ela está disposta a pagar por um MVP do projeto e vocês fecharam o negócio com um prazo de 10 dias para entrega.
Agora é mãos à obra! Vamos começar?
Nesse projeto, você deverá ser capaz de:
- Manter aderência do código à especificação. Seu programa deve se comportar como especificado no repositório, no protótipo e no Diagrama de ER;
- Manter a organização do seu código e a arquitetura geral da aplicação (tanto da API quando do front-end);
- Manter aderência ao padrão REST na API;
- Respeitar a estrutura do banco de dados. Sua implementação não deve adicionar ou remover tabelas, campos ou relacionamentos e sua API deve estar preparada para aproveitar essa estrutura por completo;
- Manter uma cobertura de testes. Seu código deve ser testável e possuir uma suíte de testes unitários e/ou de integração robusta e com alta cobertura.
- Implementar a funcionalidade de comunicação em tempo real, utilizando o socket.io.
- Manter aderência aos princípios SOLID;
-
Cada grupo terá uma branch específica no formato
main-group-X
. Ex:main-group-1
;main-group-2
; etc; -
Para entregar o seu projeto você deverá criar um
Pull Request
base neste repositório no formato[MAIN GROUP X] [BASE]
, que deve apontar a branchmain-group-X
para branchmain
, ela será sua PR principal e deve agregar ao final todo o trabalho do seu grupo para avaliação; -
Cada feature/fix/etc deve ser desenvolvida em uma nova branch, cujo formato preferencialmente deve ser
main-group-X-<alteração>-<especificação>
. Ex:main-group-1-feat-login-form
. Isso ajudará tanto o seu time quanto a equipe de instrução a localizar seus trabalhos no projeto; -
Cada feature/fix/etc deve, ao término, ser mergeada (preferencialmente via PR, com code review e aprovação de todo o grupo) com a branch principal do grupo, onde ocorrerá a avaliação. Ex:
main-group-1-feat-login-form
deve ser mergeado commain-group-1
; -
Cada PR deve, preferencialmente ter o título no formato
[MAIN GROUP X] [CONTEXTO] [ALTERAÇÃO] [DESCRIÇÃO]
. Ex:[MAIN GROUP 1] [API] [FEAT] [LOGIN]
;[MAIN GROUP 1] [FRONT] [FEAT] [LOGIN-FORM]
; etc. Isso ajudará tanto o seu time quanto a equipe de instrução a localizar seus trabalhos no projeto.
Lembre-se que você pode consultar nosso conteúdo sobre Git & GitHub sempre que precisar!
Esse será o projeto mais desafiador até agora! Nessa aplicação, vocês serão responsáveis por criar e integrar tanto o back-end quanto o front-end!
O projeto em si é super divertido! Como dado no contexto, você vai criar uma plataforma de delivery de cerveja. 🍻
Para facilitar o entendimento, podemos dividir a aplicação em ** 4 fluxos principais**, uma validação de status entre cliente e pessoa vendedora e cobertura de testes (front-end
e back-end
):
-
Fluxo Comum que compreende:
- (1) Tela de Login (
01login.test
); - (2) Tela de Registro (
02register.test
).
- (1) Tela de Login (
-
Fluxo do Cliente que compreende: :
- (3) Tela de Produtos (
03customer_products.test
); - (4) Tela de Checkout (
04customer_checkout.test
); - (5) Tela de Pedidos (
05customer_orders.test
); - (6) Tela de Detalhes do Pedido (
06customer_order_details.test
).
- (3) Tela de Produtos (
-
Fluxo da Pessoa Vendedora que compreende:
- (7) Tela de Pedidos (
07seller_orders.test
); - (8) Tela de Detalhes/Controle do Pedido (
08seller_order_details.test
).
- (7) Tela de Pedidos (
-
Validação do Status do Pedido que compreende:
- (9) Teste de status sem atualização em tempo real (
09customer_seller_status_sync.test
); - (10) Teste de status com atualização em tempo real (
10customer_seller_socket_status_sync.test
).
- (9) Teste de status sem atualização em tempo real (
-
Fluxo da Pessoa Administradora que compreende:
- (11) Tela de gerenciamento de usuários (
11admin_manage_users.test
).
- (11) Tela de gerenciamento de usuários (
-
Testes da aplicação que compreende:
- (12) Testes de cobertura (
12coverage_tests.test
).
- (12) Testes de cobertura (
-
⚠️ IMPORTANTE⚠️ : A tela de login deve ser capaz de direcionar para a tela principal de cada pessoa usuária, sendo as páginas:- Do cliente:
/customer/products
, - Da pessoa vendedora:
/seller/orders
, - Da pessoa administradora:
/admin/manage
- Do cliente:
-
Para o banco de dados, utilizaremos a biblioteca ORM
Sequelize
, que fará interface com oMySQL
!- Utilize para referência de criação de
migrations
eseeders
o arquivo./db.example.sql
; - O Diagrama de ER também pode ajudar a "visualizar" banco;
- Utilize para referência de criação de
-
Utilize o o protótipo para se guiar na construção do front-end, ele é comentado com os nomes de cada elemento (é necessário ter feito login no
figma
para visualizar); -
Para servir arquivos estáticos como imagens no back-end, utilize o seguinte path:
./back-end/public
;- Nosso banco de imagens pode ser baixado aqui;
data-testid
, pois eles serão usados na correção do projeto.
Você pode ler mais sobre os atributos data-*
neste link.
- Projeto em grupo.
- Serão 10 dias de projeto.
- Data de entrega para avaliação final do projeto: `dd/mm/yyyy - 14:00h`.
- Clone o repositório
git clone git@github.com:tryber/sd-011-project-delivery-app.git
.- Entre na pasta do repositório que você acabou de clonar:
cd sd-011-project-delivery-app
- Vá para a branch do seu grupo, com
git checkout main-group-XX && git pull
, ondeXX
é o número do seu grupo. Exemplos:main-group-1
,main-group-22
.
- Instale as dependências
- Instale as dependências:
npm install
- Faça alterações separadas por novas branchs criadas a partir da branch
main-group-XX
, criando uma nova branch para cada demanda
- Verifique que você está na branch
main-group-XX
- Exemplo:
git branch
- Exemplo:
- Se não estiver, mude para a branch
main-group-XX
- Exemplo:
git checkout main-group-XX && git pull
- Exemplo:
- Agora, crie uma branch para a demanda que você vai desenvolver do seu projeto
- Você deve criar uma branch com uma breve descrição da demanda a ser desenvolvida
- Exemplo:
git checkout -b main-group-XX-cria-campo-de-input
- Adicione as mudanças ao stage do Git e faça um
commit
- Verifique que as mudanças ainda não estão no stage
- Exemplo:
git status
(devem aparecer listadas as novas alterações em vermelho)
- Exemplo:
- Adicione o novo arquivo ao stage do Git
- Exemplo:
git add .
(adicionando todas as mudanças - que estavam em vermelho - ao stage do Git)git status
(deve aparecer listado o arquivo joaozinho/README.md em verde)
- Exemplo:
- Faça o
commit
inicial- Exemplo:
git commit -m 'iniciando o projeto x'
(fazendo o primeiro commit)git status
(deve aparecer uma mensagem tipo nothing to commit )
- Exemplo:
- Adicione a sua branch com o novo
commit
ao repositório remoto
- Usando o exemplo anterior:
git push -u origin main-group-XX-cria-campo-de-input
- Crie um novo
Pull Request
(PR)
- Vá até a página de Pull Requests do repositório no GitHub
- Clique no botão verde "New pull request"
- Clique na caixa de seleção "Compare" e escolha a branch do grupo,
main-group-XX
, e a sua branch com atenção - Coloque um título para a sua Pull Request
- Exemplo: "[GRUPO XX] Cria tela de busca"
- Clique no botão verde "Create pull request"
- Adicione uma descrição para o Pull Request e clique no botão verde "Create pull request"
- Não se preocupe em preencher mais nada por enquanto!
- Volte até a página de Pull Requests do repositório e confira que o seu Pull Request está criado
- Assim que aprovado por pelo menos duas pessoas do seu grupo e o Linter estiver adereçado, acesse SEU Pull Request e clique no botão "Merge pull request"
-
Faça
commits
das alterações que você fizer no código regularmente -
Lembre-se de sempre após um (ou alguns)
commits
atualizar o repositório remoto -
Os comandos que você utilizará com mais frequência são:
git status
(para verificar o que está em vermelho - fora do stage - e o que está em verde - no stage)git add
(para adicionar arquivos ao stage do Git)git commit
(para criar um commit com os arquivos que estão no stage do Git)git push -u origin nome-da-branch
(para enviar o commit para o repositório remoto na primeira vez que fizer opush
de uma nova branch)git push
(para enviar o commit para o repositório remoto após o passo anterior)
São os scripts da raiz do projeto (./package.json
) (e não das aplicações individuais ./front-end/package.json
e ./back-end/package.json
):
-
start
: Limpa as portas3000
e3001
e simula a inicialização no avaliador. Prepara o campo rodando oSequelize
para restaurar o banco de dados de testes (final-test
) e sobe a aplicação compm2
em modofork
(Uma instância pra cada aplicação). Nesse modo as alterações não são assistidas;- uso (na raiz do projeto):
npm start
- uso (na raiz do projeto):
-
stop
: Para e deleta as aplicações rodando nopm2
;- uso (na raiz do projeto):
npm stop
- uso (na raiz do projeto):
-
dev
: Limpa as portas3000
e3001
e sobe a aplicação compm2
em modofork
(Uma instância pra cada aplicação), nesse modo, as atualizações são assistidas (modowatch
);- uso (na raiz do projeto):
npm run dev
- uso (na raiz do projeto):
-
dev:prestart
: A partir da raiz, esse comando faz o processo de instalação de dependências (npm i
) nos dois projetos (./front-end
e./back-end
) e roda oSequelize
no./back-end
(lembrar de configurar o.env
no mesmo);- uso (na raiz do projeto):
npm run dev:prestart
- uso (na raiz do projeto):
-
db:reset
: Rodas os scripts doSequelize
restaurando o banco de dados de desenvolvimento (final-dev
), utilize caso ocorra algum problema no seu banco local;- uso (na raiz do projeto):
npm run db:reset
- uso (na raiz do projeto):
-
db:reset:debug
: Rodas os scripts doSequelize
restaurando o banco de dados de desenvolvimento (final-dev
), utilize caso ocorra algum problema no seu banco local; Esse comando também é capaz de retornar informações detalhadas de erros (quando ocorrerem no processo);- uso (na raiz do projeto):
npm run db:reset:debug
- uso (na raiz do projeto):
-
test <nomes-dos-arquivos>
: Roda todos os testes (ou uma parte deles caso<nomes-dos-arquivos>
seja definido) utilizando o banco de dados de testes (final-test
);- uso (na raiz do projeto):
npm test
,npm test 01login 02register
ou aindanpm run test 01 02
- uso (na raiz do projeto):
-
test:dev <nomes-dos-arquivos>
: Roda todos os testes (ou uma parte deles caso<nomes-dos-arquivos>
seja definido) utilizando o banco de dados de desenvolvimento (final-dev
);- uso (na raiz do projeto):
npm run test:dev
,npm run test:dev 01login 02register
ou aindanpm test:dev 01 02
;
- uso (na raiz do projeto):
-
test:dev:open <nomes-dos-arquivos>
: Roda todos os testes (ou uma parte deles caso<nomes-dos-arquivos>
seja definido) utilizando o banco de dados de desenvolvimento (final-dev
), exemplonpm test:dev:open 01login 02register
ou aindanpm test:dev:open 01 02
; Esse teste deve mostrar abrir uma janela mostrando o comportamento das páginas;- uso (na raiz do projeto):
npm run test:dev:open
,npm run test:dev:open 01login 02register
ou aindanpm test:dev:open 01 02
;
- uso (na raiz do projeto):
-
test:dev:report "<nomes-dos-arquivos>"
: Roda todos os testes (ou uma parte deles caso"<nomes-dos-arquivos>"
seja definido) utilizando o banco de dados de desenvolvimento (final-dev
); Esse teste devolve um output em texto com o resultado de todos os testes; Oslogs
são gerados em./__tests__/reports
.- uso (na raiz do projeto):
npm run test:dev:report
,npm run test:dev:report "01login 02register"
ou aindanpm run test:dev:report "01 02"
;
- uso (na raiz do projeto):
⚠️ IMPORTANTE⚠️ : O processo de avaliação completo é bem demorado (em torno de 20 minutos), por isso, é importante que os testes sejam feitos por partes, localmente, antes de serem enviados para o avaliador! Para isso, utilize os comandos de teste local (npm run test:dev*
) apresentados em "Scripts relevantes dopackage.json
principal"!- Exemplo: Após terminar os requisitos do primeiro arquivo (
01login.test.js
), vc pode utilizar o comandonpm run test:dev 01
ounpm run test:dev:open 01
(caso queira visualizar) para testar aquela parte do projeto. - Aqui, vocês também tem liberdade para utilizar os comandos
.only
ou.skip
para validar testes específicos no avaliador local (pasta./__tests__/end-to-end
), exemplo:
- Exemplo: Após terminar os requisitos do primeiro arquivo (
/*
⚠️ **IMPORTANTE** ⚠️: Esse artifício **não deve ser "commitado" com o projeto, sob risco de desqualificação na avaliação**, porém pode ser utilizado para ganhar tempo no teste local.
*/
describe(requirement(1), () => {
test.only("O avaliador navegará para o endereço do host utilizando o endpoint '/'", async () => { // O `test.only` deve rodar o teste específico do requisito 1 e pular os demais
// ...
});
});
-
⚠️ IMPORTANTE⚠️ : Para testes locais, é fundamental configurar o arquivo de variáveis de ambiente.env
(deenvironment
) dentro da pasta./back-end
(ele é o único.env
no projeto), conforme exemplo em.env.example
, na mesma pasta. Esse arquivo servirá de referência para o avaliador e caso não exista, o avaliador vai utilizar valoresdefault
pro processo (O que pode estourar erro no teste local, caso suas configurações não sejam as mesmas). -
Excepcionalmente nesse projeto, também existe a necessidade de manter e subir no repositório o arquivo
jwt.evaluation.key
, que também deve estar em./back-end
. Esse arquivo deve conter única e exclusivamente a chave utilizada para criptografia com JWT, que também vai ser testado pelo avaliador. Nesse sentido, esse arquivo pode ser lido por sua aplicação na hora de trabalhar comtokens
. -
⚠️ IMPORTANTE⚠️ : Inicie o projeto pela raiz, utilizando o comandonpm i
;- Após isso, é possível fazer a instalação de ambos os aplicativos (back e front) através da raiz do projeto, utilizando o comando
npm run dev:start
(esse comando também restaurará o banco de dados, caso o.env
esteja configurado corretamente).
- Após isso, é possível fazer a instalação de ambos os aplicativos (back e front) através da raiz do projeto, utilizando o comando
Usaremos o ESLint para fazer a análise estática do seu código.
Este projeto já vem com as dependências relacionadas ao linter configuradas nos arquivos package.json
nos seguintes caminhos:
sd-011-project-delivery-app/back-end/package.json
sd-011-project-delivery-app/front-end/package.json
Para poder rodar os ESLint
em um projeto basta executar o comando npm install
dentro do projeto de forma individual, ou seja, precisa-se executar esse comando dentro da pasta back-end
e também na pasta front-end
e depois npm run lint
dentro de cada uma dessas pastas, assim você verifica as particularidades individualmente. Se a análise do ESLint
encontrar problemas no seu código, tais problemas serão mostrados no seu terminal. Se não houver problema no seu código, nada será impresso no seu terminal.
Devido ao fato de as configurações das regras do ESLint
dos projetos de front e back serem diferentes, é preciso executar o ESLint
em cada projeto.
Você pode também instalar o plugin do ESLint
no VSCode
, bastar ir em extensions e baixar o plugin ESLint
.
- Dica: Abra separadamente cada pasta do projeto (
back-end
efront-end
emVSCode
s separados, para tirar proveito doESLint
individual de cada projeto).
Usaremos também o StyleLint para fazer a análise estática do seu código.
O Stylelint é aplicável APENAS no frontend
Para poder rodar o StyleLint
em um projeto basta executar o comando npm install
dentro do projeto de front-end e depois npm run lint:styles
. Se a análise do StyleLint
encontrar problemas no seu código, tais problemas serão mostrados no seu terminal. Se não houver problema no seu código, nada será impresso no seu terminal.
Caso ainda fique alguma dúvida, você pode consultar nosso conteúdo sobre ESLint
⚠ PULL REQUESTS COM ISSUES DE LINTER NÃO SERÃO AVALIADAS. ATENTE-SE PARA RESOLVÊ-LAS ANTES DE FINALIZAR O DESENVOLVIMENTO! ⚠
./back-end
(pela raiz do projeto, o comando npm run db:reset
será de grande ajuda, pois serve para restaurar o banco de dados -dev
). O avaliador irá executar funções do sequelize para garantir a estrutura do banco de dados.
O projeto já provê uma estrutura inicializada do ORM (em ./back-end/src/database
); Aqui, é necessário que você desenvolva as migrations e seeders corretamente, seguindo o modelo em ./db.example.sql
(esse arquivo serve como referência, e não tem qualquer influência sobre a aplicação ou avaliação).
default
no arquivo ./back-end/src/database/config/config.js
que já vem no projeto caso nada seja definido. Por tanto, tome cuidado na hora de fazer qualquer alteração nesse arquivo, pois é através dele que o avaliador utilizará as referências do banco de dados correto para cada situação (desenvolvimento e testes).
Esse projeto fornece por padrão o arquivo .sequelizerc
em .back-end
para configurações do padrão de pastas no Sequelize.
Opcionalmente no desenvolvimento local, você pode alterar o valor EVAL_ALWAYS_RESTORE_DEV_DB
do arquivo .env
em ./back-end
para false
, o que persistirá os dados dos testes locais durante os mesmos.
Essa opção pode gerar implicações para a performance e confiabilidade do teste local, já que o avaliador pode se comportar mal caso haja uma quantidade grande de registros para avaliar. Caso ocorra algum problema, utilize o comando npm run db:reset
ou npm run db:reset:debug
(para encontrar erros) pela raiz do projeto para restaurar o banco, ou altere de volta a opção EVAL_ALWAYS_RESTORE_DEV_DB
para true
.
O nosso protótipo possui um conjunto de componentes base. Isso é proposital e sugere que é fundamental que vocês componentizem o front-end de maneira que seja possível fazer o maior reaproveitamento possível de cada estrutura.
É bom lembrar que um front-end em React com pouca componentização gera muita manutenção no tempo e atrasa a entrega. Aqui, é aconselhável pensar utilizando um modelo atômico de desenvolvimento.
O data-testid de cada elemento que será usado na avaliação do projeto está no arquivo data-testids.md na raiz do projeto. Cada um desse elementos tem no protótipo do figma um número, e nesse arquivo, o data-testid
que deve ser atribuido ao valor de tal.
O Fluxo comum deve garantir que seja possível fazer login e registrar no sistema.
Todos os testes desse arquivo:
- Verificarão se o banco de dados contém as pessoas usuárias padrão (conforme referência em
db.example.sql
); - Farão a navegação para a página principal em
localhost:3000/login
.
Observações técnicas
- Aqui deve-se garantir que a aplicação possui acesso a uma rota
/login
; - A rota padrão (
/
) deve fazer redirecionamento para rota/login
.
O que será avaliado
- O avaliador navegará para o endereço do host utilizando o endpoint
/
;- O avaliador verificará o redirecionamento para página
/login
;
- O avaliador verificará o redirecionamento para página
- O avaliador navegará para o endereço do host utilizando o endpoint
/login
.
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
Comum / Login
;
O que será avaliado
O avaliador buscará pelos elementos fundamentais aos demais testes.
Observações técnicas
- A senha recebe qualquer tipo de caractere;
- Aqui, os critérios para considerar dados de login mal-formatados são:
- Email incompleto, fora de um padrão comum como:
<email>@<domínioPrincipal>.<domínioGenérico>
; - Senha com número de caracteres menor que
6
.
- Email incompleto, fora de um padrão comum como:
O que será avaliado
- O avaliador testará 3 situações aleatórias diferentes (uma para cada validação) de maneira isolada, sendo uma delas válida;
- O avaliador testará seu formulário com as 3 situações de maneira sequencial;
- O avaliador não vai executar o login pelo botão de login: ele validará se o botão ficará habilitado ou não, a depender dos critérios durante o input dos dados;
- É esperado que haja a validação dos dados durante a escrita dos mesmos.
4 - Desenvolva a tela de login de maneira que ela impossibilite o login com dados válidos, porém inexistentes no banco de dados
Observações técnicas
- Sua página deve ser capaz de alertar a pessoa usuária de que aquele login é inválido após sua tentativa. Já que apesar de formatado corretamente, os dados não existam no banco de dados.
O que será avaliado
- O avaliador tentará fazer login através do botão de login, com dados aleatórios válidos;
- O avaliador espera que haja uma requisição
POST
para API, que retorne o status404 - Not found
; - O avaliador deve identificar que o endereço da página não foi alterado;
- O avaliador espera que apareça na tela um elemento, antes oculto, com uma mensagem de erro qualquer.
- Elemento:
common_login__element-invalid-email
- Elemento:
5 - Desenvolva a tela de login de maneira que ela possibilite fazer o login com dados válidos e existentes no banco de dados
Observações técnicas
Sua página deve ser capaz de utilizar os dados do cliente previstos em db.example.sql
:
- Note que, a senha armazenada no banco é uma (
hash md5
)[https://pt.wikipedia.org/wiki/MD5], cuja tradução também está comentada no arquivo; - Sua API deve ser capaz de traduzir uma senha comum para uma
hash md5
, comparando-a e validando-a com a do banco de dados; - É possível utilizar bibliotecas de terceiros como a (
md5
)[https://www.npmjs.com/package/md5], ou a nativacrypto
para conversão de valores paramd5
.
O que será avaliado
- O avaliador tentará fazer a ação de login com dados válidos, esse teste pressupõe a validade de anteriores;
- O avaliador utilizará o e-mail
zebirita@email.com
e senha$#zebirita#$
para fazer o login;
- O avaliador utilizará o e-mail
Todos os testes desse arquivo:
- Farão a navegação para a página principal em
localhost:3000/login
; - Farão a navegação para a página de registro através do
Botão de registro
;
6 - Crie uma tela de registro que deve ser acessível via endpoint /register no navegador e pelo botão de registro na tela de login
Observações técnicas
- Aqui deve-se garantir que a aplicação possui acesso a uma rota
/register
; - Também deve ser possível acessar a tela de registro clicando no botão de cadastro via tela de login`.
O que será avaliado
- O avaliador navegará para o endereço do host utilizando o endpoint
/register
; - O avaliador tentará, pela tela de login, acessar a página de registro clicando no
Botão de cadastro
.
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
Comum / Cadastro
;
O que será avaliado
O avaliador buscará pelos elementos fundamentais aos demais testes.
8 - Desenvolva a tela de registro de maneira que ela impossibilite o cadastro com dados mal-formatados
Observações técnicas
- A senha recebe qualquer tipo de caractere;
- Aqui, os critérios para considerar dados de registro mal-formatados são:
- Nome completo com número de caracteres menor que
12
. - Email incompleto, fora de um padrão comum:
<email>@<domínioPrincipal>.<domínioGenérico>
; - Senha com número de caracteres menor que
6
.
- Nome completo com número de caracteres menor que
O que será avaliado
- O avaliador testará 4 situações aleatórias diferentes (uma para cada validação) de maneira isolada, sendo uma delas válida;
- O avaliador testará seu formulário com as 4 situações de maneira sequencial;
- O avaliador não vai executar o registro pelo botão de registro; Ele validará se o botão ficará habilitado ou não, a depender dos critérios durante o input dos dados;
- É esperado que haja a validação dos dados durante a escrita dos mesmos.
Observações técnicas
Sua página deve ser capaz de cadastrar pessoas usuárias com dados válidos:
- Note que, a senha deve ser armazenada no banco como uma (
hash md5
)[https://pt.wikipedia.org/wiki/MD5], a tradução deve ocorrer na API; - É possível utilizar bibliotecas de terceiros como a (
md5
)[https://www.npmjs.com/package/md5], ou a nativacrypto
para conversão de valores paramd5
.
O que será avaliado
- O avaliador tentará fazer a ação de cadastro com dados aleatórios válidos, validando-os posteriormente no banco de dados;
- O avaliador espera que haja uma requisição
POST
para API ao clicar noBotão de registro
, que retorne o status201 - Created
; - O avaliador espera acessar uma página
localhost:3000/customer/products
como padrão para o usuário do tipo cliente; - Não é necessário ter a página pronta, mas a rota no front deve estar acessível para que o avaliador a identifique.
10 - Desenvolva a tela de registro de maneira que ela impossibilite o cadastro de um usuário já existente
Observações técnicas
Sua página deve impedir o cadastro de pessoas com o mesmo Nome ou E-mail.
O que será avaliado
- O avaliador tentará realizar o fluxo de cadastro anterior duas vezes, com um dado gerado aleatóriamente.
- Na primeira vez o avaliador espera que haja uma requisição
POST
para API ao clicar noBotão de registro
, que retorne o status201 - Created
; - Na segunda vez o avaliador espera que haja uma requisição
POST
para API ao clicar noBotão de registro
, que retorne o status409 - Conflict
; - O avaliador espera que apareça na tela um elemento, antes oculto, com uma mensagem de erro qualquer.
- Elemento:
common_register__element-invalid_register
;
- Elemento:
O fluxo do cliente deve garantir que seja possível navegar e escolher produtos, adicionar produtos ao carrinho, fazer checkout (gerar uma nova venda), consultar pedidos e acessar detalhes do mesmo.
Todos os testes desse arquivo:
- Farão o fluxo de login com o cliente "Zé Birita" (o login é sempre validado nos testes);
- Esse fluxo deve dar acesso a uma página padrão de produtos em
localhost:3000/customer/products
; - Verificarão no banco de dados, se consta a lista de produtos padrão, conforme a tabela
products
do modelo emdb.example.sql
.
11 - Crie uma tela de produtos do cliente contendo uma barra de navegação - navbar - que servirá também para demais telas das pessoas usuárias
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
Comum / Produtos
;
O que será avaliado
O avaliador buscará pelos elementos fundamentais aos demais testes:
- Elemento genérico que seja um item de menu para página de produtos;
- Elemento genérico que seja um item de menu para página de pedidos;
- Elemento genérico para o nome da pessoa usuária;
- Elemento genérico que seja um item de menu para o logout.
12 - Desenvolva a tela de produtos do cliente criando os demais elementos com os data-testids disponíveis no protótipo
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
Comum / Produtos
; - Deve-se construir um total de
11
cards, cada um correspondente a um item da tabela produtos, conforme a tabelaproducts
do modelo emdb.example.sql
. - Os
data-testid
desses itens devem terminar com o id de cada produto, exemplo:customer_products__element-card-price-1
;customer_products__element-card-price-2
; ...;customer_products__element-card-price-11
.
O que será avaliado
O avaliador buscará pelos elementos relacionados a todos os cards de produtos:
- Elemento genérico do nome/título do produto;
- Elemento genérico do preço do produto;
- Imagem do produto;
- Botão para adicionar quantidade de itens;
- Botão para remover quantidade de itens;
- Input de quantidade de itens.
13 - Desenvolva a tela de produtos do cliente de forma que ela pressuponha dados válidos da pessoa usuária armazenados no localStorage
Observações técnicas
- Após o login (e durante a navegação), deve-se manter os dados da pessoa usuária no
localStorage
, conforme o modelo:
{
name: "Nome Da Pessoa Usuária",
email: "email@dominio.com",
role: "customer",
token: "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJuYW1lIjoiTm9tZSBEYSBQZXNzb2EgVXN1w6FyaWEiLCJlbWFpbCI6ImVtYWlsQGRvbWluaW8uY29tIiwicm9sZSI6ImN1c3RvbWVyIn0.s5cmiyY16yViCXkHuzWekxkMeYBi75eT8uJnSbfadNE"
}
- Sua página também deve ser capaz de deslogar a pessoa usuária que não possuir um
token
válido nolocalStorage
;- Note que aqui, é necessário que sua API seja capaz de gerar um
token
JWT
, com base na chave em./back-end/jwt.evaluation.key
após um login válido.
- Note que aqui, é necessário que sua API seja capaz de gerar um
- Aqui, também será validado se esses dados são descartados ao logout.
O que será avaliado
- O avaliador testará se o
local storage
contém os dados da pessoa usuária após o login; - O avaliador testará se o nome da pessoa, contido no
local storage
, também está na navbar; - O avaliador testará se o
local storage
contém umtoken
válido; - O avaliador testará se o logout descarta os dados do
local storage
da pessoa usuária.
14 - Desenvolva a tela de produtos do cliente de forma que os cards de todos os produtos pré-cadastrados contenham os valores corretos
Observações técnicas
- Há um total de
11
cards, cada um correspondente a um item da tabela produtos, conforme a tabelaproducts
do modelo emdb.example.sql
; - Os dados desses produtos devem condizer com os dados do banco de dados;
- Nesse requisito, deve-se garantir que as imagens dos produtos estejam disponíveis para acesso direto via rota estática na sua API.
O que será avaliado
- O avaliador testará se os dados de cada card condizem com os dados do banco de dados.
- O avaliador testará se é possível fazer uma requisição para os endereços das imagens de cada produto.
15 - Desenvolva a tela de produtos do cliente de forma que o preço total esteja correto após a adição de itens aleatórios
Observações técnicas
- Cada card deve possibilitar a adição, remoção ou definição manual da quantidade de itens de cada produto;
- Esses itens devem compor um "carrinho de compras", que deve ser persistente no fluxo do cliente até o momento do checkout (quando o carrinho se torna uma venda concretizada);
- Dica: Considere utilizar o
localStorage
como forma de armazenar uma entidadecarrinho
; - Dica: Considere a utilização de um contexto específico para acessar e manipular esses dados (tirando essa competência dos componentes filho);
- Esse contexto não deve ser geral, ou seja, não deve ser acessado por outras páginas fora do escopo do cliente.
- Dica: Para facilitar o processo, considere o carrinho como um 'modelo' de uma entidade banco de dados, mas programado no front-end (por ser temporário);
- Esses dados não devem persistir ao logout.
- Dica: Considere utilizar o
- O valor total do pedido é a soma dos resultados das quantidades de cada item, multiplicada pelo preço unitário dos mesmos;
O que será avaliado
- O avaliador deve utilizar um recorte aleatório de produtos para fazer o pedido (esses dados são imprimidos durante o teste);
- Para cada item da lista gerada:
- O avaliador testará se a adição do item (
Botão de adição
), adiciona aoinput
da quantidade; - O avaliador testará se após a adição do item, a ação de remoção (
Botão de remoção
) do dobro da quantidade manterá oinput
da quantidade no0
(não gerando valores negativos); - O avaliador testará se é possível fazer a alteração manual
input
da quantidade; - O avaliador testará o fluxo completo de adição de itens, validando o valor total de produtos.
- O avaliador testará se a adição do item (
16 - Desenvolva a tela de produtos do cliente de forma que haja um botão de carrinho que redirecionará para a tela de checkout caso itens sejam adicionados
Observações técnicas
- Sua página deve garantir que alterações no carrinho também mudem o valor total da venda:
- Dica: Tire proveito do contexto específico mencionado anteriormente para realizar a lógica e fornecer o resultado do cálculo.
O que será avaliado
- O avaliador testará a existência de um botão de carrinho com um valor total válido e que seja capaz de nos direcionar à tela de checkout.
- O avaliador espera acessar uma página
localhost:3000/customer/checkout
após o clique no botão do carrinho; - Não é necessário ter a página pronta, mas a rota no front deve estar acessível para que o avaliador a identifique.
- O avaliador espera acessar uma página
Todos os testes desse arquivo:
- Vão utilizar uma amostragem de produtos do banco de dados (impresso na tela durante o teste);
- Vão gerar um novo pedido com o preço total presumido e dados aleatórios para utilização nos testes (impresso na tela durante o teste);
- Vão fazer login com o cliente "Zé Birita";
- Vão validar o valor total dos produtos adicionados na tela de produtos;
- Vão navegar para a tela de checkout através do botão do carrinho de compras;
- O endereço da página deve ser
localhost:3000/customer/checkout
.
17 - Crie uma tela de checkout do cliente com elementos com os data-testids disponíveis no protótipo
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
Comum / Checkout
; - A quantidade de itens no checkout deve corresponder à quantidade de itens no recorte aleatório de produtos utilizados no teste;
- Aqui, a referência de identificação do campos das linhas da tabela deve ser o índice (
index
) da matriz (array
) dos produtos no carrinho de compras, exemplo:element-order-table-name-0
;element-order-table-name-1
; ...;element-order-table-name-x
.
O que será avaliado
- O avaliador testará os data-testids referentes aos itens do carrinho e demais elementos.
18 - Desenvolva a tela de checkout do cliente de forma a possuir os dados corretos do carrinho e preço total
Observações técnicas
- Os dados propostos no recorte aleatório de produtos (itens e preço total) no teste devem condizer com os dados contidos no carrinho durante o checkout.
O que será avaliado
- O avaliador testará se os itens contidos na venda correspondem aos itens do checkout
Observações técnicas
- O cliente deve ser capaz de remover itens do carrinho pela tela de checkout, alterando o valor total da venda.
O que será avaliado
- O avaliador tentará realizar a remoção de itens validando-os na tabela.
- O avaliador vai deletar uma quantidade aleatória de itens do carrinho (esses dados são impressos no teste).
20 - Desenvolva a tela de checkout do cliente de forma a nos redirecionar para a tela de detalhes do pedido feito após a finalização do mesmo
Observações técnicas
- Não se preocupe aqui em ter a tela de detalhes do pedido pronta;
- O que deve estar garantido, é que é possível ter acesso a uma rota
localhost:3000/customer/orders/<id>
no front, onde oid
é retornado da requisição da venda;
- O que deve estar garantido, é que é possível ter acesso a uma rota
- Ao final do pedido (ao clicar no 'Botão de finalização do pedido'), a tela de checkout deve disparar uma requisição pra API, inserindo a venda e retornando o
id
da mesma, para utilização no redirecionamento.
O que será avaliado
- O avaliador verificará se ao final do checkout é disparado uma request
POST
com uma autorização (token
) válida que retorne status201 - Created
; - O avaliador verificará se após isso o endereço da url contém o
id
do pedido criado, exemplo, se oid
gerado for3
, então:localhost:3000/customer/orders/3
.
21 - Desenvolva a tela de checkout do cliente de forma a gerar uma nova venda na tabela sales, assim como relações em salesProducts ao finalizar o pedido
Observações técnicas
- O "status" padrão de cada pedido deve ser
Pendente
;- Para ficar no radar: Os status de um pedido podem ser:
Pendente
;Preparando
;Em Trânsito
;Entregue
.
- Para ficar no radar: Os status de um pedido podem ser:
- Deve-se garantir que a requisição para API se encarregue de criar uma venda, e na mesma requisição, relacionar essa venda com os produtos do carrinho:
- Aqui possuímos uma relação de
N:N
(Muitos para muitos) onde se relacionam as tabelas:sales
< 1:N >salesProducts
< N:1 >products
.
- Aqui possuímos uma relação de
- Os testes farão a inserção da venda via checkout e após isso farão a validação desses dados no banco de dados.
- Atente que, no protótipo, a tela
Cliente / Detalhes do Pedido
possui a data do pedido:- A data deve ser inserida automaticamente durante o processo de inserção da venda após o checkout;
- O banco de dados está configurado para o
fuso horário Zulu (Z)
(timezone: 'Z'
em./back-end/database/config/config.js
) que é alinhado com oUTC+0
;- Saiba mais sobre o
UTC
(Tempo universal coordenado); - Isso é necessário para evitar conflitos de horário na hora da leitura e escrita da informação no banco de dados.
- Saiba mais sobre o
- É possível utilizar bibliotecas externas para manipulação de datas como o
Moment.js
, ou mesmo utilizar o objetoDate
para normatizar horários na hora da leitura ou escrita no formatoUTC
.
- Dica: É possível utilizar o Sequelize para definir um valor padrão para um campo durante a criação do seu modelo, valores padrão podem incluir a data atual.
O que será avaliado
- O avaliador testará se, após realizado o checkout, as alterações constarão no banco de dados.
Todos os testes desse arquivo:
- Vão utilizar uma amostragem de produtos do banco de dados (impresso na tela durante o teste);
- Vão fazer login com o cliente "Zé Birita";
- Vão gerar um novo pedido com o preço total presumido e dados aleatórios para utilização nos testes (impresso na tela durante o teste);
- Vão fazer o checkout desse novo pedido;
- Vão acessar a
HomePage
do usuário, navegando para a tela de login (que deve fazer o redirecionamento);- Lembrando que, acessar a tela de login com um usuário já logado, deve fazer o direcionamento para página padrão do mesmo.
- Vão navegar para a tela de produtos através do menu de navegação (saindo da tela de detalhes do pedido);
- Vão navegar para a tela de pedidos do cliente através do menu de navegação;
- Vão coletar os dados de vendas da tabela
sales
referentes ao usuário (id3
) - O endereço da página deve ser
localhost:3000/customer/orders
.
22 - Crie uma tela de pedidos do cliente com elementos a partir dos data-testids disponíveis no protótipo
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
Comum / Meus Pedidos
; - Os
data-testid
desses itens devem terminar com oid
de cada venda no banco, exemplo:customer_products__element-order-date-1
;customer_products__element-order-date-2
; ...;customer_products__element-order-date-x
.
O que será avaliado
- O avaliador ira testar se existem
data-testids
para até os dez primeiros itens contidos na tabela 'sales';- O avaliador oficial irá testar somente uma venda, mas caso você opte por usar o parâmetro de ambiente
EVAL_ALWAYS_RESTORE_DEV_DB=false
no back-end, localmente o teste fará avaliação de até dez vendas.
- O avaliador oficial irá testar somente uma venda, mas caso você opte por usar o parâmetro de ambiente
23 - Desenvolva a tela de pedidos do cliente de forma a conter a lista de pedidos do mesmo com os dados corretos
Observações técnicas
- Garanta que os dados dos itens de cada card condizem com as vendas registradas na tabela
sales
(vendas);
O que será avaliado
- O avaliador irá testar se os dados associados aos
data-testids
dos dez primeiros itens coincidem com os do banco de dados.- O avaliador oficial irá testar somente uma venda, mas caso você opte por usar o parâmetro de ambiente
EVAL_ALWAYS_RESTORE_DEV_DB=false
no back-end, localmente o teste fará avaliação de até dez vendas.
- O avaliador oficial irá testar somente uma venda, mas caso você opte por usar o parâmetro de ambiente
24 - Desenvolva a tela de pedidos do cliente de forma a dar acesso à tela de detalhes de um pedido ao clicar no card do mesmo
Observações técnicas
- Não se preocupe aqui em ter a tela de detalhes do pedido pronta;
- O que deve estar garantido, é que é possível ter acesso a uma rota
localhost:3000/customer/orders/<id>
no front;
- O que deve estar garantido, é que é possível ter acesso a uma rota
- Aqui, o acesso a cada item deve ser possível pelos cards na tela de pedidos;
O que será avaliado
- O avaliador acessará a tela de detalhes do último pedido pela tela de pedidos, após o checkout do mesmo, exemplo:
- Se o pedido gerado for o de
id
5
, o avaliador espera acessar via aquele card, o endereçolocalhost:3000/customer/orders/5
.
- Se o pedido gerado for o de
Todos os testes desse arquivo:
- Vão utilizar uma amostragem de produtos do banco de dados (impresso na tela durante o teste);
- Vão fazer login com o cliente "Zé Birita";
- Vão gerar um novo pedido com o preço total presumido e dados aleatórios para utilização nos testes (impresso na tela durante o teste);
- Vão fazer o checkout desse novo pedido, o que deve redirecionar para tela de detalhes daquele pedido;
- O endereço da página deve ser
localhost:3000/customer/orders/<idVenda>
.
25 - Crie uma tela de detalhes do pedido do cliente com elementos a partir dos data-testids disponíveis no protótipo
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
Comum / Detalhes do Pedido
;
O que será avaliado
- O avaliador testará os
data-testids
referentes aos itens da venda e demais elementos.
26 - Desenvolva a tela de detalhes do pedido do cliente de forma a possuir os dados corretos da venda
Observações técnicas
- Sua aplicação deve garantir que os dados do pedido do cliente estejam atualizados ao acessar o detalhe de algum deles.
O que será avaliado
- O avaliador testará se os dados contidos nos campos das linhas (produtos relacionados à venda), tal como demais valores (id do pedido, nome da pessoa vendedora, data de pedido, status da venda, preço total) conferem com os dados da venda feita anteriormente.
O fluxo da pessoa vendedora deve garantir que é possível listar pedidos relacionados com aquela pessoa vendedora e manipular o status desse pedido.
Todos os testes desse arquivo:
- Vão utilizar uma amostragem de produtos do banco de dados (impresso na tela durante o teste);
- Vão fazer login com o cliente "Zé Birita";
- Vão gerar um novo pedido com o preço total presumido e dados aleatórios para utilização nos testes (impresso na tela durante o teste);
- Vão fazer o checkout desse novo pedido, por tanto a venda estará registrada no banco de dados;
- Vão fazer o logout do sistema;
- Vão fazer o login com a vendedora "Fulana Pereira" utilizando o e-mail
fulana@deliveryapp.com
e senhafulana@123
; - Vão coletar os dados de vendas da tabela
sales
referentes ao usuário (id2
); - A página padrão esperada para pessoa vendedora é
localhost:3000/seller/orders
.
27 - Crie uma tela de pedidos da pessoa vendedora com elementos a partir dos data-testids disponíveis no protótipo
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
P. Vend / Pedidos
; - Os
data-testid
desses itens devem terminar com oid
de cada venda no banco, exemplo:seller_orders__element-order-date-1
;seller_orders__element-order-date-2
; ...;seller_orders__element-order-date-x
.
O que será avaliado
- O avaliador irá testar se existem
data-testids
para até os dez primeiros itens contidos na tabela 'sales';- O avaliador oficial irá testar somente uma venda, mas caso você opte por usar o parâmetro de ambiente
EVAL_ALWAYS_RESTORE_DEV_DB=false
no back-end, localmente o teste fará avaliação de até dez vendas.
- O avaliador oficial irá testar somente uma venda, mas caso você opte por usar o parâmetro de ambiente
28 - Desenvolva a tela de pedidos da pessoa vendedora de forma a conter a lista de pedidos do mesmo com os dados corretos
Observações técnicas
- Garanta que os dados dos itens de cada card condizem com as vendas registradas na tabela
sales
(vendas);
O que será avaliado
- O avaliador irá testar se os dados associados aos
data-testids
dos dez primeiros itens batem com os do banco de dados.- O avaliador oficial irá testar somente uma venda, mas caso você opte por usar o parâmetro de ambiente
EVAL_ALWAYS_RESTORE_DEV_DB=false
no back-end, localmente o teste fará avaliação de até dez vendas.
- O avaliador oficial irá testar somente uma venda, mas caso você opte por usar o parâmetro de ambiente
29 - Desenvolva a tela de pedidos da pessoa vendedora de forma a dar acesso à tela de detalhes de um pedido ao clicar no card do mesmo
Observações técnicas
- Não se preocupe aqui em ter a tela de detalhes do pedido pronta;
- O que deve estar garantido, é que é possível ter acesso a uma rota
localhost:3000/seller/orders/<id>
no front;
- O que deve estar garantido, é que é possível ter acesso a uma rota
- Aqui, o acesso a cada item deve ser possível pelos cards na tela de pedidos;
O que será avaliado
- O avaliador acessará a tela de detalhes do último pedido pela tela de pedidos, após o checkout do mesmo, exemplo:
- Se o pedido gerado for o de
id
5
, o avaliador espera acessar via aquele card, o endereçolocalhost:3000/seller/orders/5
.
- Se o pedido gerado for o de
Todos os testes desse arquivo:
- Vão utilizar uma amostragem de produtos do banco de dados (impresso na tela durante o teste);
- Vão fazer login com o cliente "Zé Birita";
- Vão gerar um novo pedido com o preço total presumido e dados aleatórios para utilização nos testes (impresso na tela durante o teste);
- Vão fazer o checkout desse novo pedido, por tanto a venda estará registrada no banco de dados;
- Vão fazer o logout do sistema;
- Vão fazer o login com a vendedora "Fulana Pereira" utilizando o e-mail
fulana@deliveryapp.com
e senhafulana@123
; - Vão clicar no card referente à venda realizada para ter acesso a tela de detalhes do mesmo.
30 - Crie uma tela de detalhes do pedido da pessoa vendedora com elementos a partir dos data-testids disponíveis no protótipo
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
P. Vend / Detalhes do Pedido
;
O que será avaliado
- O avaliador testará os
data-testids
referentes aos itens da venda e demais elementos.
31 - Desenvolva a tela de detalhes do pedido da pessoa vendedora de forma a possuir os dados corretos da venda
Observações técnicas
- Sua aplicação deve garantir que os dados do pedido do cliente estejam atualizados ao acessar o detalhe de algum deles.
O que será avaliado
- O avaliador testará se os dados contidos nos campos das linhas (produtos relacionados à venda), tal como demais valores (id do pedido, nome da pessoa vendedora, data de pedido, status da venda, preço total) conferem com os dados da venda feita anteriormente.
A validação de status consiste em uma série de testes que devem assegurar que os status do pedido sejam alterados e refletidos para clientes e pessoas vendedoras
32 - Desenvolva a tela de detalhes do pedido da pessoa vendedora de forma a ser capaz de alterar o status do pedido
Observações técnicas
- Os status de um pedido podem ser:
Pendente
- Valor padrão na criação do pedido;Preparando
- Status que pode ser alterado pela pessoa vendedora;Em Trânsito
- Status que pode ser alterado pela pessoa vendedora;Entregue
- Status que pode ser alterado pelo cliente.
- Esse requisito irá avaliar se as alterações do status do pedido na tela da pessoa vendedora são persistentes ao clicar em:
Botão de marcar para 'preparo'
,Botão de marcar para 'saiu para entrega'
:- O
Botão de marcar para 'preparo'
deve estar habilitado caso o status do pedido esteja comoPendente
, esse botão deve alterar o status do pedido paraPreparando
; - O
Botão de marcar para 'preparo'
deve estar desabilitado caso o status do pedido esteja comoPreparando
,Em Trânsito
ouEntregue
; - O
Botão de marcar para 'saiu para entrega'
deve estar habilitado caso o status do pedido esteja comoPreparando
, esse botão deve alterar o status do pedido paraEm Trânsito
; - O
Botão de marcar para 'saiu para entrega'
deve estar desabilitado caso o status do pedido esteja comoPendente
,Em Trânsito
ouEntregue
;
- O
O que será avaliado
- O avaliador testará se alteração do pedido é persistente após atualizar a página fazendo o processo de logout/login.
Todos os testes desse arquivo:
- Vão utilizar uma amostragem de produtos do banco de dados (impresso na tela durante o teste);
- Vão fazer login com o cliente "Zé Birita";
- Vão gerar um novo pedido com o preço total presumido e dados aleatórios para utilização nos testes (impresso na tela durante o teste);
- Vão fazer o checkout desse novo pedido, por tanto a venda estará registrada no banco de dados;
- Vão gerar outro contexto de navegação (anônimo) para utilizar no fluxo da pessoa vendedora;
- Vão fazer o login (no novo contexto) com a vendedora "Fulana Pereira";
- Vão clicar no card referente a venda realizada para ter acesso a tela de detalhes do mesmo.
33 - Garanta que o status do pedido atualizado na tela de detalhes do pedido da pessoa vendedora seja refletido na tela de detalhes do pedido do cliente após atualização das páginas
Observações técnicas
- Sua aplicação deve garantir que:
- Dado o fluxo de criação de um pedido pelo cliente, que leva a tela de detalhes daquele pedido;
- Dado o acesso dos detalhes desse pedido pela pessoa vendedora em paralelo (não há logout no processo);
- Seja possível fazer a alteração no status do pedido pela pessoa vendedora, e ao atualizar as páginas, esse status esteja refletido na tela de detalhes do pedido do cliente.
O que será avaliado
- O avaliador verificará se, ao alterar o status do pedido na tela da pessoa vendedora, o mesmo também é alterado na tela de detalhes do pedido do cliente após atualização das páginas fazendo o processo de logout/login nas mesmas.
34 - Garanta que o status do pedido atualizado na tela de detalhes do pedido da pessoa vendedora seja refletido na tela de lista de pedidos do cliente após atualização das páginas
Observações técnicas
- Sua aplicação deve garantir que:
- Dado o fluxo de criação de um pedido pelo cliente, acessando após isso, a tela de lista de pedidos do mesmo;
- Dado o acesso dos detalhes desse pedido pela pessoa vendedora em paralelo (não há logout no processo);
- Seja possível fazer a alteração no status do pedido pela pessoa vendedora, e ao atualizar as páginas, esse status esteja refletido no mesmo item listado na tela de pedido do cliente.
O que será avaliado
- O avaliador verificará se, ao alterar o status do pedido na tela da pessoa vendedora, o mesmo também é alterado na tela de pedidos do cliente após atualização das páginas fazendo o processo de logout/login nas mesmas.
35 - Garanta que o status do pedido atualizado na tela de detalhes do pedido do cliente seja refletido na tela de lista de pedidos da pessoa vendedora após atualização das páginas
Observações técnicas
- Sua aplicação deve garantir que:
- Dado o fluxo de criação de um pedido pelo cliente, que leva a tela de detalhes daquele pedido;
- Dado o acesso dos detalhes desse pedido pela pessoa vendedora em paralelo (não há logout no processo);
- Dada a alteração de status do pedido da pessoa vendedora (colocando o pedido "Em trânsito");
- Dado o acesso da lista de pedidos pela pessoa vendedora em paralelo (não há logout no processo);
- Seja possível fazer a alteração no status do pedido pelo cliente, e ao atualizar as páginas, esse status esteja refletido no mesmo item listado na tela de pedido da pessoa vendedora.
- Esse requisito também validará a interação com:
Botão de marcar como 'entregue'
:- O
Botão de marcar como 'entregue'
deve estar habilitado caso o status do pedido esteja comoEm Trânsito
, esse botão deve alterar o status do pedido paraEntregue
; - O
Botão de marcar como 'entregue'
deve estar desabilitado caso o status do pedido esteja comoPendente
,Preparando
ouEntregue
;
- O
O que será avaliado
- O avaliador verificará se, ao alterar o status do pedido na tela do cliente, o mesmo também é alterado na tela de detalhes do pedido da pessoa vendedora após atualização das páginas fazendo o processo de logout/login nas mesmas.
Esse teste é similar ao anterior, porém assumindo a implementação do socket.io
no escopo das páginas:
- Pedidos do cliente;
- Detalhes do pedido do cliente;
- Pedidos da pessoa vendedora;
- Detalhes do pedido da pessoa vendedora;
⚠️ IMPORTANTE⚠️ : Esse escopo deve ser respeitado para que isso não quebre demais testes ou interfira em páginas que não utilizam esse recurso.- Dica: Utilize um contexto específico para inicialização do socket, cujo provedor contemple somente esse conjunto de páginas;
- Esse contexto pode ter funções específicas para inicialização de
listeners
, emissão e recepção de eventos, e pode ser utilizado sob demanda por suas páginas.
Todos os testes desse arquivo:
- Vão utilizar uma amostragem de produtos do banco de dados (impresso na tela durante o teste);
- Vão fazer login com o cliente "Zé Birita";
- Vão gerar um novo pedido com o preço total presumido e dados aleatórios para utilização nos testes (impresso na tela durante o teste);
- Vão fazer o checkout desse novo pedido, por tanto a venda estará registrada no banco de dados;
- Vão gerar outro contexto de navegação (anônimo) para utilizar no fluxo da pessoa vendedora;
- Vão fazer o login (no novo contexto) com a vendedora "Fulana Pereira";
- Vão clicar no card referente a venda realizada para ter acesso a tela de detalhes do mesmo.
36 - Desenvolva a tela de detalhes do pedido da pessoa vendedora de forma a interagir em tempo real com a tela de detalhes do pedido do cliente
Observações técnicas
- Sua aplicação deve garantir que:
- Dado o fluxo de criação de um pedido pelo cliente, que leva a tela de detalhes daquele pedido;
- Dado o acesso dos detalhes desse pedido pela pessoa vendedora em paralelo (não há logout no processo);
- Seja possível fazer a alteração no status do pedido pela pessoa vendedora, e sem atualizar as páginas, esse status esteja refletido na tela de detalhes do pedido do cliente.
O que será avaliado
- O avaliador verificará se, ao alterar o status do pedido na tela da pessoa vendedora, o mesmo também é alterado na tela de detalhes do pedido do cliente após atualização das páginas.
37 - Desenvolva a tela de detalhes do pedido da pessoa vendedora de forma a interagir em tempo real com a tela de lista de pedidos do cliente
Observações técnicas
- Sua aplicação deve garantir que:
- Dado o fluxo de criação de um pedido pelo cliente, acessando após isso, a tela de lista de pedidos do mesmo;
- Dado o acesso dos detalhes desse pedido pela pessoa vendedora em paralelo (não há logout no processo);
- Seja possível fazer a alteração no status do pedido pela pessoa vendedora, e sem atualizar as páginas, esse status esteja refletido no mesmo item listado na tela de pedido do cliente.
O que será avaliado
- O avaliador verificará se, ao alterar o status do pedido na tela da pessoa vendedora, o mesmo também é alterado na tela de pedidos do cliente após atualização das páginas.
38 - Desenvolva a tela de detalhes do pedido do cliente de forma a interagir em tempo real com a tela de lista de pedidos da pessoa vendedora
Observações técnicas
- Sua aplicação deve garantir que:
- Dado o fluxo de criação de um pedido pelo cliente, que leva a tela de detalhes daquele pedido;
- Dado o acesso dos detalhes desse pedido pela pessoa vendedora em paralelo (não há logout no processo);
- Dada a alteração de status do pedido da pessoa vendedora (colocando o pedido "Em trânsito");
- Dado o acesso da lista de pedidos pela pessoa vendedora em paralelo (não há logout no processo);
- Seja possível fazer a alteração no status do pedido pelo cliente, e sem atualizar as páginas, esse status esteja refletido no mesmo item listado na tela de pedido da pessoa vendedora.
- Esse requisito também validará a interação com:
Botão de marcar como 'entregue'
:- O
Botão de marcar como 'entregue'
deve estar habilitado caso o status do pedido esteja comoEm Trânsito
, esse botão deve alterar o status do pedido paraEntregue
; - O
Botão de marcar como 'entregue'
deve estar desabilitado caso o status do pedido esteja comoPendente
,Preparando
ouEntregue
;
- O
O que será avaliado
- O avaliador verificará se, ao alterar o status do pedido na tela do cliente, o mesmo também é alterado na tela de detalhes do pedido da pessoa vendedora após atualização das páginas.
O fluxo da pessoa administradora deve possibilitar o cadastro de clientes e pessoas vendedoras tal como a remoção dos mesmos.
Todos os testes desse arquivo devem:
- Fazer login utilizando dados da pessoa administradora;
- email
adm@deliveryapp.com
e senha--adm2@21!!--
.
- email
- Ter a seguinte página esperada pelo avaliador:
localhost:3000/admin/manage
.
39 - Crie uma tela de pessoa administradora com elementos a partir dos data-testids disponíveis no protótipo
Observações técnicas
- Se oriente pela seguinte tela do protótipo:
P. Adm. / Gerenciamento
;- Num primeiro momento, não serão considerados os itens da tabela de usuários, foque aqui em consolidar o formulário de cadastro.
O que será avaliado
- O avaliador testará os
data-testids
referentes aos elementos do formulário de cadastro.
Observações técnicas
- Assim como no formulário de registro aqui também serão validados os campos para registro;
- Aqui, os critérios para considerar dados de registro mal-formatados são:
- Nome completo com número de caracteres menor que
12
. - Email incompleto, fora de um padrão comum:
<email>@<domínioPrincipal>.<domínioGenérico>
; - Senha com número de caracteres menor que
6
; - Não definir o cargo (
role
):- Dica: O
select
do cargo (role
), pode ter um valor default.
- Dica: O
- Nome completo com número de caracteres menor que
O que será avaliado
- O avaliador testará 4 situações aleatórias diferentes (uma para cada validação) de maneira isolada, sendo uma delas válida;
- O avaliador testará seu formulário com as 4 situações de maneira sequencial;
- O avaliador não vai executar o registro pelo botão de registro: ele validará se o botão ficará habilitado ou não, a depender dos critérios durante o input dos dados;
- É esperado que haja a validação dos dados durante a escrita dos mesmos.
41 - Desenvolva a tela da pessoa administradora de forma que seja possível cadastrar pessoas usuárias válidas
Observações técnicas
Sua página deve ser capaz de cadastrar pessoas usuárias com dados válidos:
- Note que, a senha deve ser armazenada no banco como uma (
hash md5
)[https://pt.wikipedia.org/wiki/MD5], a tradução deve ocorrer na API; - É possível utilizar bibliotecas de terceiros como a (
md5
)[https://www.npmjs.com/package/md5], ou a nativacrypto
para conversão de valores paramd5
;
Aqui a rota de cadastro deve ser diferente da rota de cadastro comum, pois também é possível definir a categoria de usuário aqui (role
);
- Essa é uma rota específica para pessoa administradora, portanto a mesma rota na api deve considerar um token válido e referênte ao usuário de categoria
administrator
;
O que será avaliado
- O avaliador tentará fazer a ação de cadastro com uma lista de pessoas (impressa durante o teste) com dados aleatórios válidos, validando-os posteriormente no banco de dados;
- Para cada pessoa, o avaliador espera que haja uma requisição
POST
para API ao clicar noBotão de registro
, que retorne o status201 - Created
; - Os dados dessa pessoa serão validados na tabela
user
do banco de dados.
42 - Desenvolva a tela da pessoa administradora de forma que ela impossibilite o cadastro de pessoas usuárias já existentes
Observações técnicas
Sua página deve impedir o cadastro de pessoas com o mesmo Nome ou E-mail.
O que será avaliado
- O avaliador tentará realizar o fluxo de cadastro anterior duas vezes, mas com apenas uma pessoa usuária gerada aleatóriamente.
- Na primeira vez o avaliador espera que haja uma requisição
POST
para API ao clicar noBotão de registro
, que retorne o status201 - Created
; - Na segunda vez o avaliador espera que haja uma requisição
POST
para API ao clicar noBotão de registro
, que retorne o status409 - Conflict
; - O avaliador espera que apareça na tela um elemento, antes oculto, com uma mensagem de erro qualquer.
- Elemento:
admin_manage__element-invalid-register
.
- Elemento:
43 - (Bônus
) Desenvolva a tela da pessoa administradora de forma que haja uma tabela de pessoas usuárias cadastradas
Observações técnicas
- Aqui, é necessário que a página também retorne os dados atualizados das pessoas usuárias cadastradas (não incluindo pessoas administradoras):
- Não é necessário interação em tempo real nesta página, utilizar o socket nesse contexto pode interferir na avaliação;
- Dica: É possível utilizar um contexto específico que contemple o formulário e a tabela de usuários;
O que será avaliado
- O avaliador testará os data-testids referentes aos elementos da tabela de pessoas usuárias;
- O avaliador tentará realizar o fluxo de cadastro com uma quantidade aleatória de pessoas usuárias válidas e verificará se as mesmas aparecem na tabela.
44 - (Bônus
) Desenvolva a tela da pessoa administradora de forma que seja possível deletar pessoas usuárias na tabela
Observações técnicas
- A pessoa administradora deve ser capaz de remover pessoas usuárias através da tabela.
- Na api, essa é uma rota protegida e exclusiva da pessoa administradora, portanto deve considerar um token válido e referente ao usuário de categoria
administrator
;
- Na api, essa é uma rota protegida e exclusiva da pessoa administradora, portanto deve considerar um token válido e referente ao usuário de categoria
O que será avaliado
- O avaliador tentará realizar a remoção de itens validando-os na tabela.
- O avaliador vai deletar uma quantidade aleatória de itens do carrinho (esses dados são impressos no teste).
A cobertura de testes deve garantir que, tanto no front-end
quanto no back-end
, os sistemas foram testados e possuem componentes e/ou funções estáveis e à prova de erros.
Antes de todos os testes, esse arquivo deve rodar, em ambas aplicações, o comando test:coverage:json
.
- Tanto no
front-end
quanto noback-end
, esse comando deve gerar um arquivo de cobertura (coverage
) específico para cada; - Serão coletados dos arquivos, os dados:
pct
- porcentagem total da cobertura;skipped
- se algum teste foi pulado com.only
ou.skip
;covered
- quantas linhas foram cobertas no teste.
.only
e .skip
(principalmente para ganhar tempo), essas alterações dos testes não devem subir com sua aplicação para o repositório, correndo o risco de desaprovação no projeto.
UnhandledPromiseRejectionWarning
), por isso, busquem sempre fazer o tratamento correto de funções assíncronas durante o projeto, tal como nos testes.
45 - Crie testes que cubram no mínimo 30 por cento dos arquivos do front-end e back-end em src com um mínimo de 75 linhas cobertas em cada
Observações técnicas
Garanta que tanto o seu front-end
quanto back-end
possuem testes que cubram ao menos 30%
da aplicação com 75
linhas cobertas:
- É possível testar a cobertura de duas formas:
- A partir da raiz de cada projeto, utilizando
npm run test:coverage
(o que deve trazer uma tabela de cobertura, sem o número absoluto de linhas cobertas); - A partir da raiz de cada projeto, utilizando
npm run test:coverage:json
(o que deve trazer um arquivo./coverage/coverage.json
, com um detalhamento da cobertura);
- A partir da raiz de cada projeto, utilizando
O que será avaliado
- Serão validados os dados de cobertura no
front-end
e noback-end
;
46 - (Bônus
) Crie testes que cubram no mínimo 60 por cento dos arquivos do front-end e back-end em src com um mínimo de 150 linhas cobertas em cada
Observações técnicas
Garanta que tanto o seu front-end
quanto back-end
possuem testes que cubram ao menos 60%
da aplicação com 150
linhas cobertas:
- É possível testar a cobertura de duas formas:
- A partir da raiz de cada projeto, utilizando
npm run test:coverage
(o que deve trazer uma tabela de cobertura, sem o número absoluto de linhas cobertas); - A partir da raiz de cada projeto, utilizando
npm run test:coverage:json
(o que deve trazer um arquivo./coverage/coverage.json
, com um detalhamento da cobertura);
- A partir da raiz de cada projeto, utilizando
O que será avaliado
- Serão validados os dados de cobertura no
front-end
e noback-end
;
47 - (Bônus
) Crie testes que cubram no mínimo 90 por cento dos arquivos do front-end e back-end em src com um mínimo de 225 linhas cobertas em cada
Observações técnicas
Garanta que tanto o seu front-end
quanto back-end
possuem testes que cubram ao menos 90%
da aplicação com 225
linhas cobertas:
- É possível testar a cobertura de duas formas:
- A partir da raiz de cada projeto, utilizando
npm run test:coverage
(o que deve trazer uma tabela de cobertura, sem o número absoluto de linhas cobertas); - A partir da raiz de cada projeto, utilizando
npm run test:coverage:json
(o que deve trazer um arquivo./coverage/coverage.json
, com um detalhamento da cobertura);
- A partir da raiz de cada projeto, utilizando
O que será avaliado
- Serão validados os dados de cobertura no
front-end
e noback-end
;
Terminei meu projeto, e agora? Uma prática legal, caso queira apresentar ou publicar seu projeto, é dar deploy
na sua aplicação.
Um bom exercício aqui é utilizar seu aprendizado de Heroku
para subir as duas aplicações, garantindo a comunicação de uma com a outra.
Um ponto importante aqui, é que também é necessário subir um banco de dados no Heroku para levar seus dados para a nuvem. O Heroku conta com o ClearDB
(Artigo em inglês), para te ajudar nessa tarefa!
Se seu projeto estiver concluído, considere a expansão que ele pode passar ao longo do tempo. Esse projeto consegue expandir suas entidades? Consegue ter outros módulos (um web-chat, uma área de gerentes de vendedores, instâncias para lojas)?
É super importante que tenhamos seguido todos os princípios e boas práticas de programação (como SOLID
, por exemplo), tal como uma boa modelagem do banco de dados que torne possível gerar escala.
Evidentemente, nada fica ideal num primeiro momento, mas quanto mais conseguirmos trabalhar no nosso projeto pensando a manutenção dele no longo prazo, mais fácil fica de programarmos coisas novas partindo do nosso código legado, por isso é importante sempre revisar nosso trabalho!
Para sinalizar que o seu projeto está pronto para "Code Review", faça o seguinte:
-
Vá até a página DO SEU Pull Request, adicione a label de "code-review" e marque seus colegas:
-
No menu à direita, clique no link "Labels" e escolha a label code-review;
-
No menu à direita, clique no link "Assignees" e escolha o seu usuário;
-
No menu à direita, clique no link "Reviewers" e digite
students
, selecione o timetryber/students-sd-011
.
-
Caso tenha alguma dúvida, aqui tem um video explicativo.
Use o conteúdo sobre Code Review para te ajudar a revisar os Pull Requests.
#VQV
Ao finalizar e submeter o projeto, não se esqueça de avaliar sua experiência preenchendo o formulário. Leva menos de 3 minutos!
Link: FORMULÁRIO DE AVALIAÇÃO DE PROJETO
#VQV
Você sabia que o LinkedIn é a principal rede social profissional e compartilhar o seu aprendizado lá é muito importante para quem deseja construir uma carreira de sucesso? Compartilhe esse projeto no seu LinkedIn, marque o perfil da Trybe (@trybe) e mostre para a sua rede toda a sua evolução.