
Test IT поддерживает интеграцию с Bamboo. Для настройки используется все несколько строк кода и поддерживаются любые тестовые фреймворки и платформы.
Вы можете интегрировать как простые проекты (только с запуском тестов), так и сложные проекты (несколько отдельных проектов), которые запускаются в несколько независимых потоков.
Независимо от ваших требований процесс интеграции всегда будет одинаков:
- Запуск автоматизированных тестов в пайплайнах Bamboo.
- Генерация Junit XML отчета с результатами автоматизированных тестов.
- Загрузка результатов с помощью Test IT CLI
Не забывайте передавать приватный токен через переменную окружения
TMS_TOKEN
для корректной работы утилиты Test IT CLI. Как это сделать безопасно смотрите ниже.
Стандартный запуск
В данном разделе показано как запускать простые проекты в Bamboo. В качестве примера мы выбрали тестовый фреймворк Pytest для Python. Но данная инструкция будет актуальна для любых тестовых фреймворков и платформ.
Мы будем использовать утилиту Test IT CLI
для быстрой и простой интеграции с нашей системой управления тестированием. С помощью одной команды мы загрузим все результаты автоматизированных тестов.
Ниже представлен пример файла bamboo.yaml
, который отвечает за работу пайплайнов в Bamboo:
# bamboo-specs/bamboo.yaml
plan:
project-key: <PROJECT_KEY>
key: BI
name: Bamboo Integration
stages:
- Test:
- Tests
Tests:
tasks:
- script:
# Install project dependencies
- pip install -r requirements.txt
# Execute test and generate report
- pytest --junitxml=results/test-results.xml src/tests.py
final-tasks:
- script:
# Install Test IT CLI
- pip install testit-cli
# Submit test results to TMS
- testit
--url <YOUR_INSTANCE_URL> \
--project-id 5236eb3f-7c05-46f9-a609-dc0278896464 \
--configuration-id 15dbb164-c1aa-4cbf-830c-8c01ae14f4fb \
--testrun-name "Bamboo test run" \
--results results/test-results.xml
Простым добавлением необходимых шагов вы можете запускать множество необходимых вам тестов и загружать их в Test IT. Больше информации вы можете найти в официальной документации.
Параллельный запуск
Мы так же полностью поддерживаем параллельный запуск автоматизированных тестов в Bamboo. Добавляются дополнительные независимые шаги для создания, завершения тестрана и запуска тестов.
Ниже представлен пример файла bamboo.yaml
, который отвечает за работу пайплайнов в Bamboo:
# bamboo-specs/bamboo.yaml
version: 2
plan:
project-key: <PROJECT_KEY>
key: BI
name: Bamboo Integration
stages:
- Create:
- Create testrun
- Test:
jobs:
- Tests 1
- Tests 2
- Complete:
- Complete testrun
Create testrun:
tasks:
- script:
# Install Test IT CLI
- pip install testit-cli
# Create testrun
- testit
--mode create \
--url <YOUR_INSTANCE_URL> \
--project-id 5236eb3f-7c05-46f9-a609-dc0278896464 \
--testrun-name "Bamboo test run" \
--output output.txt
artifacts:
-
name: Reports
location: .
pattern: 'output.txt'
shared: true
Tests 1:
tasks:
- script:
# Install project dependencies
- pip install -r requirements.txt
# Execute test and generate report
- pytest --junitxml=results/test-results.xml src/tests.py
final-tasks:
- script:
# Install Test IT CLI
- pip install testit-cli
# Submit test results to TMS
- testit
--mode upload \
--url <YOUR_INSTANCE_URL> \
--configuration-id 15dbb164-c1aa-4cbf-830c-8c01ae14f4fb \
--testrun-id "$(cat output.txt)" \
--results results/test-results.xml
Tests 2:
tasks:
- script:
# Install project dependencies
- pip install -r requirements.txt
# Execute test and generate report
- pytest --junitxml=results/test-results.xml src/tests.py
final-tasks:
- script:
# Install Test IT CLI
- pip install testit-cli
# Submit test results to TMS
- testit
--mode upload \
--url <YOUR_INSTANCE_URL> \
--configuration-id 15dbb164-c1aa-4cbf-830c-8c01ae14f4fb \
--testrun-id "$(cat output.txt)" \
--results results/test-results.xml
Complete testrun:
tasks:
- script:
# Install Test IT CLI
- pip install testit-cli
# Complete testrun
- testit \
--mode finish \
--url <YOUR_INSTANCE_URL> \
--testrun-id "$(cat output.txt)"
Безопасное хранение данных
Для работы утилиты Test IT CLI вам необходимо использовать приватный токен для авторизации. Хранение данного токена и другой чувствительной информации в коде строго не рекомендуется, так как доступ к этой информации будет иметь любой у кого есть доступ к коду.
Используйте переменные Bamboo для хранения чувствительной информации. Подробнее с секретами вы можете ознакомится в официальной документации.