Link do deploy: https://djalmahenry.github.io/k6-performance-tests/
Este projeto utiliza as seguintes tecnologias:
- K6 🐊
- JavaScript 🟨
- Grafana Cloud ☁
Cada uma dessas tecnologias desempenha um papel importante nos testes de desempenho realizados por este repositório:
K6: É a ferramenta principal usada para criar e executar os testes de desempenho. Ele permite a criação de scripts de teste em JavaScript para simular o tráfego para a API e coletar métricas de desempenho.
JavaScript: É a linguagem de programação usada para escrever os scripts de teste. O K6 suporta JavaScript, o que permite a criação de testes complexos e personalizados.
Grafana Cloud: É a plataforma utilizada para visualizar os resultados dos testes. Os resultados dos testes realizados localmente e na nuvem podem ser enviados para o Grafana Cloud para análise e visualização.
Para começar, é necessário instalar o K6 em seu ambiente.
Aqui estão as instruções para instalação no Linux, MacOS, Windows e Docker:
sudo gpg --no-default-keyring --keyring /usr/share/keyrings/k6-archive-keyring.gpg --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys C5AD17C747E3415A3642D57D77C6C491D6AC1D69
echo "deb [signed-by=/usr/share/keyrings/k6-archive-keyring.gpg] https://dl.k6.io/deb stable main" | sudo tee /etc/apt/sources.list.d/k6.list
sudo apt-get update
sudo apt-get install k6
sudo dnf install https://dl.k6.io/rpm/repo.rpm
sudo dnf install k6
brew install k6
Com Chocolatey:
choco install k6
Com Windows Package Manager:
winget install k6
docker pull grafana/k6
Após a instalação, clone o repositório:
git clone https://github.com/DjalmaHenry/K5-Performance-Tests.git
Para executar um teste local, você pode usar um dos scripts de exemplo para executar, use o comando:
k6 run loginUsers.js
Primeiro, é necessário fazer login no Grafana Cloud usando o comando:
k6 login cloud --token YourToken
obs.: Esse token será gerado para você quando criar um novo projeto no Grafana Cloud com K6.
Em seguida, você pode executar os testes no Grafana Cloud usando o comando:
k6 cloud loginUsers.js