Pull to refresh

Comments 23

А реально ли как-то совместить такой принцип Agile testing с досками Agile на youtrack? Программно? Или только вербально можно?
Привет! Я думаю, это вполне совместимо )

Основная работа происходит, когда задача еще лежит в бэклоге. При попадании на доску — это уже задача с описанными критериями, соответственно, переход в InProgress означает и разработку автотестов.
Если у вас есть колонка «Test», то можно перемещать туда задачи на исследовательское тестирование, либо совсем исключить колонку и пользоваться только «InProgress» — что как раз отражает радикальный Agile testing.

Насчет программного метода не совсем поняла — не пользовалась этим инструментом. Если я не ответила на ваш вопрос — опишите, пожалуйста, что именно вы бы хотели перенести программно.

В бэклоге спринта или в основном? И что у вас означает in progress? In development или in testing?

Имею в виду основной бэклог. То, что взято в спринт — уже должно быть описано.
Сейчас у нас in progress означает разработку, написание автотестов и их прогон. Колонку in development не используем. In testing — это задачи, готовые к исследовательскому тестированию.

На самом деле, это скорее вопрос к процессам. Они могут сильно отличаться от наших. Главное, что вы не тестируете руками кейсы, которые полезно было бы заранее покрыть автотестами.

Были у вас какие-то трудности с вот этим всем? А то слишком гладко всё выглядит

Привет! Я описала несколько проблем в абзаце «С какими сложностями столкнулись» и в комментарии ниже. Кажется, что это основное :)
Таки да, поддерживаю предыдущего оратора. Чет многовато терминов и вот этого эльфийского «PBR-встречи», «feature-team» и т.д… Новичку уж точно не разобраться в статье…
Вопросы:
Кто был инициатором введения данной методики тестирования и какие стадии согласования вам пришлось пройти? Потому что бывает очень чопорное руководство, до которого не достучаться без предъявления очевидных преимуществ и выгоды…
Были ли те кто против? И как их лечили?

Так привыкла к этим терминам, что не заметила, как плотно они вошли в мою речь — у нас давно ввели Scrum )

В моем случае внедрение подхода прошло спокойно — в соседней команде уже успешно его применяли, и мы это видели. Какой-то формальной процедуры согласования у нас нет. Только если на прохождение мастер-класса. У нас всё просто: если ты хорошо выполняешь свою работу и в срок — то делай её хоть с помощью бубна (немножко утрированно, но в целом подход такой).

Но, тем не менее, я считаю, что аргументировать преимущества — важно. В чем плюсы:

1. Увеличение скорости тестирования. Скорость будет увеличиваться за счет уменьшения итераций, поскольку очевидные кейсы будут покрыты автотестами, а крайние моменты будут обсуждены в момент описания задачи, и разработчик сможет их предусмотреть.
2. В перспективе, активное уменьшение регрессионного тестирования. Регресс автотестами в разы стабильнее и быстрее ручного — думаю, это очевидно.
3. Стабильный уровень качества. Он также будет зависеть от ваших автотестов, но если бизнес-логика постоянно пересекается — автотесты гарантируют прохождение основных кейсов.

В моей команде никто не сопротивлялся. Но по опыту ребят из нашего внутреннего комьюнити, скажу, что для разработчика преимущества не всегда очевидны. Мотивировать его можно уменьшением итераций тестирования. Это действительно так (в моем случае — от нуля до двух итераций максимум). Мало кому нравится переключаться обратно на задачу для фикса.
Можете более подробно описать, каким в итоге стал флоу?
И если можно сказать, сколько времени примерно проходит от постановки задачи до вашего собрания PBR и до того как вы начнете разработку?

И если
Agile testing — это такой подход к процессу тестирования, при котором тестировщик гораздо больше участвует на первых этапах проработки задачи
, то как это стыкуется с тем, что у вас тестировщик более не проводит ревью постановки и включается только на PBR, т.е позже чем было до этого?
Конечный флоу:
1. Постановка задачи.
2. PBR-встреча, или по-русски: встреча, на которой мы оцениваем задачи, обсуждаем их постановку, задаем друг другу вопросы, проговариваем риски.
3. Задача следует в бэклог.

Мне понятно, почему возникло непонимание. Действительно, не все осветила. Спасибо за этот вопрос. Дело в том, что мы решили, что ответственный за постановку задачи теперь тот, кто ее пишет, а не тестировщик. А уже на PBR встрече я (или другой член команды) можем внести коррективы. Это, скорее, про работу команды: можно это и не вводить, но с какого-то момента задача просто стала лучше описываться.

А сколько в среднем длится PBR встреча и сколько в среднем вы успеваете разобрать историй по этому списку? Со стороны выглядит длительным занятием, т.е. задачи подготавливаются не на следующий спринт, а на будущее.

Гм, непонимание unit тестов.
Читая статью почему вспоминается Егор Бугаенко с его «экстримистскими» взглядами на роль тестировщика. Как бы помянялся процесс, если бы тестировщик был уровня senior developer, и не только тестировал код, но и принимал участие в его review?
Не знакома со взглядами Егора Бугаенко, но обязательно ознакомлюсь. Спасибо!
Но против такого подхода не имею ничего против. Как минимум, если не писать автотесты, то ревьюить точно надо. Так ты уверен, что конкретно тест проверяет, а что он мокает.

Насчет код-ревью вопрос спорный. С одной стороны, тратится больше времени (тестировщик будет читать код медленнее, если не рассматривать вариант с senior developer’ом), с другой — повышение компетенции. Почти уверена, что если бы тестировщики участвовали в ревью кода — выхлоп в нахождении багов на этом уровне точно был бы. Остается оценить затраты на обучение тестировщика и применение этого навыка в будущем.
А если рассматривать такой вариант, то выгода компании тоже спорная, ведь senior developer в тестировании, как мне видится, будет элементарно дороже.

Это вопрос на «поразмышлять» и немного выходит за рамки темы. Кажется, что каждому своё :)

Добрый день.
В статье полностью подменено понятие юнит-тестов.
То что у вас нарисовано на картинке — это интеграционное тестирование сервисов на бэкэнде.
Не ясно почему этим занимается/занимался разработчик. QA у вас не пишет автотесты на бэкэнд?
Не могу понять, какая связь между темой статьи и этими тестами? Это какая-то обязательная часть методологии?

Привет!
На картинке нарисована не схема тестирования, а общее взаимодействие сервиса. Тесты на ней не обозначены. Мы нарисовали её для общего понимания, что нам нужно будет покрыть.
Unit-тесты выделены в статье, так как с пониманием остальных уровней тестов проблем не возникло. То есть мы выделили интеграционные, компонентные, e2e тесты, а вот с пониманием, что можно опустить на юниты, возникли трудности.
QA, не пишет unit-тесты, поскольку они зависят от структуры кода. Если у вас есть практика, где такое происходит, то мне было бы интересно узнать, как это работает.
Обязательная часть методологии — это практика движения тестов на более низкие уровни. Изначально у нас было много e2e тестов, потому мы их опускаем.
Знаю, что на теме уровней автотестов возникает много столкновений. Под юнит-тестом мы понимаем атомарную проверку внутренней работы сервиса :)

Вы сами себе противоречите.
Подпись под картинкой: "Одна выделенная стрелочка — один поход — одна проверка в unit тесте"
Практика есть у вас, судя по статье(хотя я спрашивал про интеграцию, а не про юнит, ну да ладно):
"В итоге спустя пару месяцев, я сама немного пишу юнит тесты и удаляю избыточные проверки на верхних уровнях"
Это тоже очень сильное заявление, которое больше запутывает, чем дает понимания того, что вы делаете и зачем это надо.
В отрыве от контекста и без понимания как эффективно(а не тестировщик глазами) мапить юниты на, как минимум, интеграционные говорить о целесообразности такого подхода нельзя(если только мы не говорим о продукте где не предъявляются высокие требования к качеству).

Давайте отвечу на ваш вопрос по частям.

«Вы сами себе противоречите.
Подпись под картинкой: «Одна выделенная стрелочка — один поход — одна проверка в unit тесте»»
— На картинке обозначено взаимодействие сервиса, со стрелочкой лишь пример, как это можно применить. При желании, на ней можно добавить обозначения тестов разных уровней, но я этого не делала и такого смысла в неё не вкладывала.

«Это тоже очень сильное заявление, которое больше запутывает, чем дает понимания того, что вы делаете и зачем это надо.»
— Я действительно опускала датасеты из e2e-тестов на уровень юнит-тестов. Этот пункт в разделе статьи «как решали сложность в понимании unit-тестов», так мы повышали компетенцию в том, что можно опустить на этот уровень. На новую функциональность, когда кода еще нет, QA unit-тесты не пишет.

«Практика есть у вас, судя по статье(хотя я спрашивал про интеграцию, а не про юнит, ну да ладно)».
— Я не пишу интеграционные тесты на бэкэнд, поэтому и не приводила их в пример.

«В отрыве от контекста и без понимания как эффективно(а не тестировщик глазами) мапить юниты на, как минимум, интеграционные говорить о целесообразности такого подхода нельзя(если только мы не говорим о продукте где не предъявляются высокие требования к качеству).»
— Как маппить автотесты разного уровня — тема для отдельной статьи, моя статья на этот вопрос не отвечает, а рассказывает о процессах внедрения подхода agile-тестирования.

Хорошего дня!
Harddreamer Спасибо за статью, как раз очень актуальна для меня сейчас.
Подскажите, как Вы ведете документирование тестов на разных уровнях? Пользуетесь ли TMS для этих целей?
Привет! Да, мы используем TMS. Правда, у нас свой собственный инструмент. Отдельная команда подпиливает его для наших нужд.
Мы стараемся хранить тест-кейсы всех уровней в одном месте, чтобы видеть общую картину. При создании (ручном или автоматическом) мы указываем тип тесткейса — e2e/component/integration/unit, там же у нас видно покрытие. Пропорции пирамид смотрим уже в Grafana.
На данный момент столкнулись с тем, что некоторые unit тесты не содержат никакой бизнес-логики, и вопрос об их хранении в общем месте — спорный. Это уже на ваше усмотрение, зависит от цели хранения тесткейсов.

Некоторые другие TMS, насколько я знаю, тоже имеют поле «Тип тесткейса». Например, PractiTest, либо можно пользоваться любой другой удобной маркировкой.
Если захотите узнать чуть больше про нашу тестохранилку, то советую почитать статью моего коллеги Вадима Шашина What Does Our Test Case Management System Look Like?
Чем же отличается тестирование / QC / QA в рамках Agile-методов от механик прочих методологий (любые на ваш выбор)?
Интересно узнать особенности, которые применяются именно в Agile, при этом не применяются в прочих методологиях по каким-либо причинам: неэффективность по трудозатратам для достижения полезности, невозможность исполнения, нецелесообразность (бесполезность) и т.д.
В статье я сравнила подходы Waterfall и Agile. Agile в нашем случае сработал лучше: мы научились предотвращать ошибки на более ранних этапах и избавили тестировщика от монотонной работы. По времени, конечно, ускорились не сразу. Вначале и вовсе замедлились. Но мы понимали, что этот подход увеличивает скорость в долгосрочной перспективе — за счет хорошего покрытия автотестами.
Сравнить с какими-то другими методологиями я не могу — их не использовала. Если напишите пример из методики, которая вас интересует, или применение таких же практик, в другом подходе, то смогу вам ответить точнее :)
Так чем же отличается тестирование / QC / QA в рамках Agile-методов от механик знакомого вам подхода Waterfall? Дополню предыдущий комментарий ~примером ожидаемой трактовки на каждое отличие: «X следует использовать в Agile и не нужно использовать в Waterfall потому, что <…>»
Давайте действительно попробуем сформулировать таким образом (тут есть смысл говорить про практики Agile-testing):

«Shift left следует использовать в Agile и не нужно использовать в Waterfall потому, что это противоречит принципу последовательности процессов в Waterfall.»

В то же время, если говорить о другой практике, например, про пирамиду тестирования, то её вполне можно использовать и в waterfall подходе. Есть и другие, часть которых противоречит, часть подразумевает включение тестировщика в начальные этапы, например, «встреча 3-х амиго», а часть вполне можно использовать в отрыве от подхода, например, исследовательское тестирование.

Т.е. Некоторые практики, применяемые в Agile, которые мы хотели включить в свои процессы, противоречат последовательному построению этих процессов, и в целом у нас не было идеи удержаться в рамках какого-либо подхода.

Agile-подход это грубо говоря набор практик и ценностей, которые, конечно, можно применять еще где-либо, но по нашему опыту, вместе они работают вполне эффективно. И нет необходимости применять отдельно практику из этого подхода, когда можно перейти на методологию в целом. Но если вам так удобно, и вы хотите сохранить подход, прикрутив к нему другие практики, то мне было бы интересно узнать как это работает и почему именно так.
Sign up to leave a comment.