4 KiB
4 KiB
GoHorseJobs - Plano de QA Massivo (30 Atividades)
Este documento descreve os fluxos críticos de teste para garantir a estabilidade e segurança da plataforma.
🔐 Grupo 1: Segurança e Autenticação (HttpOnly & RBAC)
- Login Seguro: Validar que após o login, o cookie
jwtNÃO é acessível viadocument.cookieno console. - Expiração de Sessão: Alterar o JWT para expirar em 10 segundos e verificar se o frontend redireciona para
/loginautomaticamente. - Cross-Subdomain Auth: Logar em
ghj.rede5.com.bre verificar se a API emapi-ghj.rede5.com.braceita o cookie. - RBAC Candidato: Tentar acessar
/api/v1/userscom token de candidato e validar o erro403 Forbidden. - RBAC Admin: Validar que apenas administradores conseguem acessar o dashboard de auditoria.
- Logout Total: Clicar em Logout e tentar dar um "Back" no navegador para ver se a sessão foi realmente invalidada.
🐎 Grupo 2: Fluxo de Recrutamento (Empresas & Vagas)
- Criação de Vaga: Criar vaga com todos os campos e validar se aparece instantaneamente na Home.
- Upload de Logo: Subir um logo de 5MB para a empresa e validar se o redimensionamento automático (Civo Storage) funciona.
- Edição de Vaga: Alterar o status de uma vaga de
openparaclosede verificar se ela some das buscas públicas. - Busca por Localização: Testar o Autocomplete de Kyoto, Japão e validar se a vaga criada no QA anterior é encontrada.
- Filtro de Salário: Filtrar vagas com salário > 15.000 e validar os resultados.
- Destaque de Vaga (Stripe): Simular o checkout de uma vaga "Featured" e validar se ela ganha o badge de destaque após o webhook do Stripe.
👥 Grupo 3: Experiência do Candidato
- Perfil Completo: Preencher 10 habilidades e validar se o gráfico de radar (se houver) renderiza corretamente.
- Candidatura com Perguntas: Responder a um formulário de 5 perguntas customizadas e validar se o recrutador recebe as respostas.
- Upload de CV: Subir um PDF corrompido e validar se o sistema rejeita com mensagem amigável.
- Favoritos: Adicionar 5 vagas aos favoritos e validar se a lista persiste após o refresh.
- Alertas de Vaga: Criar um alerta para "Go Developer" e simular a criação de uma vaga para disparar o e-mail (LavinMQ).
💬 Grupo 4: Comunicação Real-time (Appwrite & FCM)
- Chat Instantâneo: Abrir duas abas (Empresa e Candidato) e validar se as mensagens aparecem sem refresh.
- Notificação Push (FCM): Bloquear a tela do celular e validar se o Push chega quando uma nova mensagem é recebida.
- Status de Leitura: Marcar mensagem como lida no Appwrite e validar o visual no frontend.
- Histórico de Chat: Validar se mensagens antigas (mais de 50) carregam via infinite scroll.
⚡ Grupo 5: Performance e Infraestrutura (LavinMQ & Redis)
- Carga na Fila: Disparar 100 candidaturas em 1 segundo e validar se o Worker do LavinMQ processa todas sem travar o sistema.
- Cache de Home: Validar se a Home carrega em menos de 200ms após a primeira visita (Redis).
- Resiliência DB: Derrubar o container do Postgres e validar se o Backend exibe erro de "Serviço Temporariamente Indisponível" em vez de crashar.
- Auto-reconnect AMQP: Desligar o LavinMQ por 5 segundos e validar se o Backend reconecta automaticamente quando ele volta.
🛠️ Grupo 6: Ferramentas Administrativas
- Seeder Reset: Rodar o seeder de reset e validar se o banco volta ao estado inicial perfeito.
- Purge Cache Cloudflare: Clicar no botão de Purge no Dashboard e validar via header
CF-Cache-Status: MISS. - Teste de SMTP: Usar a nova ferramenta de "Testar Envio" para validar as credenciais do Gmail/Sendgrid.
- Logs de Auditoria: Verificar se a tentativa de login falha de um IP desconhecido gera um alerta no sistema.
- Configurações de Tema: Alterar a cor primária para Verde e validar se toda a UI (botões, badges) muda instantaneamente.