Skip to content

alkhamush/tech-testing-ha1

 
 

Repository files navigation

Домашнее задание №1

Окружение для разработки

В целях унификации окружения для разработки под различными OS предлагается использовать Vagrant.

Зависимости

Следующие программы необходимо скачать и установить:

Ещё понадобится аккаунт на GitHub.

Развёртывание и настройка окружения

Сначала нужно сделать форк проекта, о том как это можно сделать описано здесь, после этого:

git clone https://github.com/${USER}/tech-testing-ha1.git # где ${USER} — имя вашего пользователя на GitHub
cd tech-testing-ha1
vagrant up # Запуск Vagrant и подготовка виртуальной машины (с Ubuntu 12.04)
vagrant ssh # Получить доступ по ssh к виртуальной машине. После этого все команды будут выполняться в виртаульной машине

Документация на Vagrant

Структура проекта

  • ./provision/ — скрипт для установки зависимостей и конфигурационные файлы
  • ./source/ — код тестируемых приложений
  • ./source/config/ — примеры конфигурационных файлов для приложений
  • ./source/tests/ — директория c тестами
  • ./run_tests.py — скрипт для запуска тестов
  • ./.coveragerc — конфигурация сборки покрытия

Разработка

Примеры команд указаны относительно корня проекта.

  • Тесты должны находиться в директории ./tests/, можно добавлять тесты к уже существующим в файлы test_notification_pusher.py и test_redirect_checker.py
    • При создании новых файлов/классов с тестами нужно указать их в скрипте запуска тестов: ./run_tests.py
  • Запустить все тесты: ./run_tests.py
  • Запустить тесты и измерить покрытие: coverage run ./run_tests.py
  • Получить информацию о покрытии:
    • В консоли: coverage report
    • Создать отчёт в формате html: coverage html. По умолчанию будет создана директория htmlcov, чтобы просмотреть отчёт нужно в браузере открыть файл htmlcov/index.html
  • Запустить один тест:
export PYTHONPATH=$PYTHONPATH:./source # добавление пути до директории source в PYTHONPATH
python -m unittest source.tests.test_notification_pusher.NotificationPusherTestCase.test_create_pidfile_example

Pull Requests (PR)

Пример PR:

Пример PR

На нём зелёная стрелка указывает на сборку на Travis CI, а красная на анализ покрытия (по строкам) для сборки на Coveralls.

Статья о PR

About

Home assignment #1

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 65.9%
  • Lua 33.1%
  • Shell 1.0%