Como usar o Bencher no GitLab CI/CD


Conforme o seu caso de uso, você pode configurar o Benchmarking Contínuo no GitLab CI/CD para o seu:

🐰 Certifique-se de ter criado um token de API e definido como uma variável mascarada chamada BENCHER_API_TOKEN antes de continuar! Navegue até Seu Repositório -> Configurações -> CI/CD -> Variáveis -> Expandir -> Adicionar variável. A chave da variável deve ser BENCHER_API_TOKEN e o valor da variável deve ser o seu token de API. Marque as caixas Proteger variável e Mascarar variável.

Ramificação Alvo

Uma pedra angular do Benchmarking Contínuo Estatístico é ter uma base histórica para a sua ramificação alvo. Esta base histórica pode então ser usada para detectar regressões de desempenho em Solicitações de Merge.

benchmark_target_branch:
rules:
- if: $CI_COMMIT_BRANCH == "main" && $CI_PIPELINE_SOURCE == "push"
when: always
image: debian:bullseye
before_script:
- curl --proto '=https' --tlsv1.2 -sSfL https://bencher.dev/download/install-cli.sh | sh
script:
- |
bencher run \
--project save-walter-white-1234abcd \
--token "$BENCHER_API_TOKEN" \
--branch main \
--testbed debian:bullseye \
--adapter json \
--err \
bencher mock
  1. Crie um arquivo GitLab CI/CD. (ex.: .gitlab-ci.yml)
  2. Crie um trabalho GitLab CI/CD. (ex.: benchmark_target_branch)
  3. Execute if o pipeline foi acionado por um push para a ramificação main. Consulte a documentação de regras do GitLab CI/CD e a documentação de variáveis predefinidas do GitLab CI/CD para uma visão geral completa. (ex.: rules: - if: ...)
  4. Defina a imagem na qual o trabalho será executado. Consulte a documentação de imagem do GitLab CI/CD para uma visão geral completa. (ex.: image: debian:bullseye)
  5. Instale o CLI do Bencher usando o script de conveniência. (ex.: before_script: ...)
  6. Use o subcomando CLI bencher run para rodar os benchmarks da sua ramificação main. Consulte o subcomando CLI bencher run para uma visão geral completa. (ex.: bencher run)
  7. Defina a opção --project para o slug do Projeto. Consulte os docs da opção --project para mais detalhes. (ex.: --project save-walter-white-1234abcd)
  8. Defina a opção --token para a variável de ambiente BENCHER_API_TOKEN mascarada. Consulte os docs da opção --token para mais detalhes. (ex.: --token "$BENCHER_API_TOKEN")
  9. Defina a opção --branch para o nome da Ramificação. Veja seleção de ramificação para uma visão geral completa. (ex.: --branch main)
  10. Defina a opção --testbed para o nome do Testbed. Isso provavelmente deve corresponder à máquina selecionada em imagem. Veja os docs da opção --tested para mais detalhes. (ex.: --testbed debian:bullseye)
  11. Defina a opção --adapter para o adaptador de suporte de benchmark desejado. Veja adaptadores de suporte de benchmark para uma visão geral completa. (ex.: --adapter json)
  12. Defina a bandeira --err para falhar o comando se um Alerta for gerado. Veja Limite & Alertas para uma visão geral completa. (ex.: --err)
  13. Especifique os argumentos do comando de benchmark. Veja comando de benchmark para uma visão geral completa. (ex.: bencher mock)

Merge Requests

Para capturar regressões de desempenho em Merge Requests, você precisará executar seus benchmarks em MRs. O exemplo abaixo deve ser usado apenas para branches dentro do mesmo repositório.

benchmark_mr_branch:
rules:
- if: $CI_PIPELINE_SOURCE == "merge_request_event"
when: always
image: debian:bullseye
before_script:
- curl --proto '=https' --tlsv1.2 -sSfL https://bencher.dev/download/install-cli.sh | sh
script:
- |
bencher run \
--project save-walter-white-1234abcd \
--token "$BENCHER_API_TOKEN" \
--branch "$CI_COMMIT_REF_NAME" \
--branch-start-point "$CI_MERGE_REQUEST_TARGET_BRANCH_NAME" \
--branch-start-point-hash "$CI_MERGE_REQUEST_TARGET_BRANCH_SHA" \
--branch-reset \
--testbed debian:bullseye \
--adapter json \
--err \
bencher mock
  1. Crie ou atualize um arquivo GitLab CI/CD. (ex: .gitlab-ci.yml)
  2. Crie um CI/CD job do GitLab. (ex: benchmark_mr_branch)
  3. Execute if o pipeline foi acionado por um merge_request_event. Veja a documentação das regras do GitLab CI/CD e a documentação das variáveis predefinidas do GitLab CI/CD para uma visão completa. (ex: rules: - if: ...)
  4. Defina a image em que o job será executado. Veja a documentação das imagem do GitLab CI/CD para uma visão completa. (ex: image: debian:bullseye)
  5. Instale o Bencher CLI usando o script de conveniência. (ex: before_script: ...)
  6. Use o subcomando CLI bencher run para executar os benchmarks do seu branch de merge request. Veja o subcomando bencher run CLI para uma visão completa. (ex: bencher run)
  7. Defina a opção --project para o slug do Projeto. Veja a documentação da opção --project para mais detalhes. (ex: --project save-walter-white-1234abcd)
  8. Defina a opção --token para a variável de ambiente mascarada BENCHER_API_TOKEN. Veja a documentação da opção --token para mais detalhes. (ex: --token "$BENCHER_API_TOKEN")
  9. Defina a opção --branch para o nome do branch do MR usando uma variável predefinida do GitLab CI/CD. Veja seleção de branch para uma visão completa. (ex: --branch "$CI_COMMIT_REF_NAME")
  10. Defina a opção --branch-start-point para o ponto de início do Branch de destino do MR usando uma variável predefinida do GitLab CI/CD. Veja seleção de branch para uma visão completa. (ex: --branch-start-point "$CI_MERGE_REQUEST_TARGET_BRANCH_NAME")
  11. Defina a opção --branch-start-point-hash para o hash do ponto de início do Branch de destino do MR usando uma variável predefinida do GitLab CI/CD. Veja seleção de branch para uma visão completa. (ex: --branch-start-point-hash "$CI_MERGE_REQUEST_TARGET_BRANCH_SHA")
  12. Defina a flag --branch-reset para sempre resetar o Branch para o ponto de início. Isso evitará desvio de dados de benchmark. Veja seleção de branch para uma visão completa. (ex: --branch-reset)
  13. Defina a opção --testbed para o nome do Testbed. Isso provavelmente deve coincidir com a máquina selecionada em image. Veja a documentação da opção --testbed para mais detalhes. (ex: --testbed debian:bullseye)
  14. Defina a opção --adapter para o adaptador de harness de benchmark desejado. Veja adaptadores de harness de benchmark para uma visão completa. (ex: --adapter json)
  15. Defina a flag --err para falhar o comando se um Alerta for gerado. Veja Threshold & Alerts para uma visão completa. (ex: --err)
  16. Especifique os argumentos do comando de benchmark. Veja comando de benchmark para uma visão completa. (ex: bencher mock)


🐰 Parabéns! Você aprendeu como usar o Bencher no GitLab CI/CD! 🎉


Continue: Visão Geral do Benchmarking ➡

🤖 Este documento foi gerado automaticamente pelo OpenAI GPT-4. Pode não ser preciso e pode conter erros. Se você encontrar algum erro, abra um problema no GitHub.


Published: Fri, October 27, 2023 at 8:40:00 AM UTC | Last Updated: Mon, April 1, 2024 at 7:00:00 AM UTC