8 августа 2016 8135
О том, что у тестировщиков и программистов разный склад ума, говорили немало. Само собой разумеется, что тестировщики смотрят на продукт иначе, чем программисты, и что обнаружить чужую ошибку зачастую бывает легче, чем свою собственную, именно поэтому и необходимо более-менее независимое тестирование. 
Стили мышления, стили работы



О том, что у тестировщиков и программистов разный склад ума, говорили немало. Само собой разумеется, что тестировщики смотрят на продукт иначе, чем программисты, и что обнаружить чужую ошибку зачастую бывает легче, чем свою собственную, именно поэтому и необходимо более-менее независимое тестирование.

Кроме того, есть еще одно важное отличие – в стиле работы. Работа тестировщика обычно связана с частыми переключениями внимания, за день тестировщик порой может выполнить не один десяток разных, не слишком связанных между собой задач. У программистов всё иначе – им свойственно работать «в потоке». Эту особенность работы программистов описали Том Демарко и Тимоти Листер в замечательной книге «Человеческий фактор: успешные проекты и команды»: «Поток – это состояние глубокого, почти медитативного погружения в работу. В этом состоянии человек испытывает легкое чувство эйфории и не замечает течения времени: «Я начал работать. Когда оторвался, прошло уже три часа». Человек не прикладывает сознательных усилий, потому что работа, кажется, идет потоком.» Именно такое состояние необходимо для написания качественного кода.

Это состояние нельзя включать по желанию, требуется не менее 15 минут погружения и концентрации, чтобы оно возникло. А вот «выдернуть» человека из него, увы, очень легко. И если дергать постоянно, то войти в это продуктивное состояние просто не получится… В итоге снижается эффективность работы, а раздражение к тем, кто мешает, нарастает.

Важно учитывать эту особенность при общении с программистами. По возможности стоит выбирать максимально ненавязчивый способ общения. Так, отправить эмэйл лучше, чем сообщение в чат, а написать в чат – лучше, чем позвонить или внезапно прийти. Впрочем, некоторых раздражают и отвлекают даже сообщения в чат, так как часто люди считают, что от них в таком случае ждут немедленного ответа.

Разумеется, я не призываю отказаться от живого общения, но лучше его планировать заранее, чтобы не мешать процессу работы коллег.


А если вы работаете с программистами в одном помещении, помните, что и шум тоже мешает сосредоточению и погружению в поток. Впрочем, поддержание тишины – это проявление уважения ко всем вашим коллегам, не только к программистам. В одной компании, где я работала, было правило – если нужно поговорить по телефону, выходить в коридор. Мне кажется, это очень хорошее правило для IT-компаний.


Конструктивная критика

Скажем честно – никому не приятна критика. Люди разные, кто-то более чувствителен к ней, кто-то менее, но вряд ли кто-то ее любит. Переживать раздражение, огорчение, подавленность, когда вам указывают на ошибки – совершенно нормально и естественно. Однако, у тестировщика такая работа – искать недостатки, проблемные места, дефекты и сообщать о них. В принципе, все участники проекта это понимают, по крайней мере, теоретически, но все же никуда не деться от этой особенности человеческой психики…

Порой бывает, что между тестировщиками и программистами возникает совершенно ненужный и даже вредный антагонизм, это разрушает командный дух, портит отношения между людьми, создает конфликты. В идеале все участники проекта должны помнить, что цель у них общая, и они не враги и не оппоненты, а коллеги, в конце концов, все мы в одной лодке. Но на практике так бывает не всегда.

О важности конструктивной критики сказано немало, но далеко не всё из множества советов подходит к нашей работе. Нет, я не собираюсь предлагать вам писать баг-репорты, используя знаменитый «метод бутерброда» (похвала в начале и в конце критического замечания), тем более, что даже 5-летнего ребенка не получится провести таким образом более чем один-два раза :) В целом, сама форма баг-репорта в значительной степени защищает нас от неконструктивной критики, так что применительно к описаниям дефектов можно вспомнить только об одном принципе: конструктивная критика должна быть аргументированной. Объясните, почему вы считаете, что это дефект. Идеально – ссылка на требования или стандарты, которым должна соответствовать программа. Если вам сложно объяснить, почему вы считаете это дефектом – что-то здесь не так. Если вам просто кажется, что «лучше было бы по-другому», может быть, правильнее занести ваше замечание как улучшение или feature request.

В общем, сделать отчет о дефекте объективным и конструктивным не слишком трудно, вот в живом общении бывает гораздо сложнее. Необходимость обсудить что-то вживую время от времени возникает, да и в целом это полезно. Часто бывает, что 5-10 минут живого общения заменяют недели переписки по эмэйлу. И здесь-то как раз важно наладить конструктивный диалог.

Итак, какие принципы хорошей критики применимы в нашем контексте:

Выбирайте место и время. Не стоит нападать на программистов с вопросом: «Когда пофиксишь баг AB-123?!» в коридоре или когда они пьют кофе на кухне. Люди более адекватно воспринимают критику там и тогда, где и когда они ожидают ее услышать. Запланированные регулярные митинги с участием команд тестирования и разработки – хорошая идея.

Избегайте перехода на личности. Само собой, критика должна быть нацелена на ситуацию, а не на конкретного человека. Иначе критикуемый уходит в глухую оборону, и конструктивный диалог уже невозможен.

Контролируйте невербальные проявления. Это бывает сложно, особенно для людей эмоциональных, а уж тем более, если они принимают свою работу близко к сердцу и реально переживают за продукт и проект. Однако, стоит приложить усилия и следить за этим. Громкость голоса, мимика, интонации – все это так же важно, как и смысловое содержание вашей речи. Даже если вы выражаетесь нейтральными фразами, но невербально передаете свои отрицательные эмоции, это может задеть ваших коллег, и тогда ваши слова уже не будут воспринимать по существу, а будут реагировать так же эмоционально, и не особенно позитивно.

Концентрируйтесь на главном. Выделите основные пункты, к которым вы хотите привлечь внимание, и говорите о них, оставьте в стороне малозначимые мелочи. Если вы выльете на человека слишком много информации, то запомнится далеко не всё, и не факт, что именно то, что вы считаете наиболее важным.

Всегда давайте собеседнику возможность ответить. Выслушайте возражения и объяснения. Даже если вы не согласны – дайте другой стороне шанс высказаться.

Покажите, что вы тоже открыты для критики. Это важный психологический момент – показать, что это не односторонний процесс, что и вы готовы принимать и учитывать критику вашей работы. Вы можете предложить разработчикам поучаствовать в peer review вашей тестовой документации (тест-кейсов, тест-плана и т.д.). Если они согласятся и найдут для этого время, это будет действительно полезно, даже и не только с психологической точки зрения, у них могут быть действительно хорошие идеи, как улучшить тестирование. Если не согласятся – по крайней мере, вы предложили.

Помните, что вы – одна команда. Банальность, конечно, и все же полезно держать это в голове, а иногда и напоминать другим, когда вы видите, что на ваши критические замечания реагируют отрицательно.

И еще один момент, важный, если вы делите с программистами общее пространство. Когда вы находите классный баг, ваша радость вполне понятна (другим тестировщикам), но постарайтесь все же не слишком бурно ее демонстрировать – вас могут неправильно понять, это может быть воспринято как злорадство.

Проблемные баги
Часто недоразумения, а то и конфликты, между тестировщиками и программистами возникают по поводу конкретных багов. Бывает, что программисты отклоняют дефект или выражают недовольство его описанием. Теперь уж очередь тестировщиков адекватно и конструктивно воспринимать критику. Рассмотрим несколько типичных ситуаций.




«Это не баг, это фича»
Наверно, каждый тестировщик сталкивался с такой ситуацией. Вы считаете, что это баг, а разработчик так не считает. Что делать? Согласиться или спорить?


Возможно, вы недостаточно хорошо аргументировали описанный вами дефект. Подумайте, что именно заставляет вас считать, что это именно баг. Вернитесь к вашему базису тестирования, перечитайте требования, загляните в матрицу трассировки. Возможно, перечитав внимательно, вы согласитесь с программистом. Если вы все же не согласны – попробуйте настоять на своей точке зрения, добавив дополнительные аргументы.

Впрочем, иногда случается так, что программист и тестировщик читали одни и те же документы, но поняли их по-разному. Кто понял правильно, а кто неправильно – еще вопрос. Может быть, неправы оба. Это стоит прояснить в живом общении. Если к согласию прийти не удается, подключайте третьих лиц – это может быть бизнес-аналитик, руководитель проекта или какой-нибудь другой человек, чей авторитет признаете вы оба и чье решение готовы принять.



«Не воспроизводится»

Любой тестировщик терпеть не может, когда баг отклоняется с такой резолюцией. Такая ситуация всегда требует дальнейших разбирательств.
Для вас это может быть сигналом того, что проблема в окружении.

Хотя возможно, что разработчик перепроверял на какой-то другой версии продукта, где были внесены какие-то изменения – это стоит уточнить.




Также возможно, что вы недостаточно подробно описали шаги или забыли упомянуть какое-то предусловие. Или же дефект воспроизводится не всегда, но вы этого не заметили. Это еще одна всеми нелюбимая ситуация….

В общем, надо разбираться. Но аргумент «а у меня работает» - это очень слабый аргумент, и это совершенно не повод не разбираться с багом. Если дефект действительно стабильно воспроизводится в тестовой версии и в вашем тестовом окружении, придется настаивать на том, чтобы разработчик все же уделил ему внимание. Добавьте доказательства – скриншоты и особенно логи. В некоторых сложных случаях бывает необходимость в расширенном логировании.

Плохое описание дефекта

Распространенная причина, по которой вокруг бага возникает конфликт – плохое описание. Особенно часто пропускают пункт «expected results» - ожидаемые результаты. Разработчик смотрит и не понимает – почему это баг? А как вообще правильно? А чего вы ждали? Старайтесь всегда добавлять этот пункт, даже если вам кажется, что это тривиально и «и так понятно». Много времени это не займет, но поможет избежать лишних споров.

Неправильный приоритет


Очень много недовольства у разработчиков вызывает завышение приоритета или severity дефектов. Естественно, если приходит баг с «severity: critical», программист часто бросает все и начинает разбираться. Если в итоге оказывается, что дефект не тянет и на «major» - раздражение и возмущение вполне объяснимо, так как человека отвлекли из-за пустяка. Честность очень важна в работе тестировщика. Не завышайте приоритеты! Но и занижать, конечно, не стоит, иначе важная проблема может остаться без внимания.


Лучше всего, чтобы в проекте была общепринятая, согласованная между тестировщиками и разработчиками система классификации дефектов по серьезности. Можно взять стандартную или разработать свою, главное, чтобы все были с ней согласны. Ну и, конечно, чтобы все тестировщики ее знали и умели ею пользоваться.

Не указана воспроизводимость

Еще одна ситуация, когда разработчики недовольны описанием дефекта – если не указано, что он воспроизводится не всегда. Особенно, когда у бага довольно высокий приоритет.

«Reproducibility» как стандартное поле в описании дефекта существует не во всех баг-трекинговых системах. Она есть, например, в Mantis. Там можно указать один из следующих вариантов:
  • Always – Всегда;
  • Sometimes - Иногда;
  • Random - Произвольно;
  • Have not tried - Не проверялась;
  • Unable to duplicate — Не удалось воспроизвести.
Возможно, стоит подумать о том, чтобы добавить такое опциональное поле в свой баг-трекер. В любом случае, даже если отдельного поля у вас нет, стоит указывать воспроизводимость дефекта в описании, если она отличается от «always/всегда».

Также один из вариантов – временно назначить дефект на себя и продолжить разбираться, пока не получится выявить закономерности и/или накопить достаточно информации об условиях проявления проблемы.

Курсы по тестированию ПО.

Последние статьи в блоге

«Аниматор с провалами памяти»: 6 ограничений ИИ, которые не дают вам писать качественный код

Вы когда-нибудь просили ИИ написать метод на Spring Boot, получали красивый, идеально отформатированный код, а он не работал? Потом вы копали глубже и находили, что нейросеть использовала RestTemplate вместо WebClient, забыла про @Transactional, а в методе с @PreUpdate пыталась изменить данные, которые уже ушли в SQL. И вы думали: «Ну, нейросеть же глупая». Нет. Не глупая. Она просто пишет код не как человек.

Новости
28 мая 2026

Роль и место России в мировой гонке в сфере ИИ

По масштабу амбиций и геополитическому значению гонку в сфере искусственного интеллекта все чаще сравнивают с космической гонкой эпохи холодной войны. Соревнование разворачивается одновременно по нескольким осям: вычислительные мощности, данные, кадры, модели и регулирование. В настоящее время ни одну из мировых держав нельзя назвать ведущей по всем направлениям, что оставляет возможность для разных подходов и стратегий в достижении лидерства. О положении России в этом глобальном соревновании, ее стратегических целях, инфраструктурных ограничениях и потенциале для развития рассказывает Денис Воденеев, заместитель директора центра перспективных разработок IBS.

Новости
21 мая 2026

Систематизация ИИ-компетенций: курсы под роли, карты эффективности и модули в комплексных программах

Учебный центр IBS систематизировал подход к развитию навыков работы с искусственным интеллектом. Хаотичное использование нейросетей, как показала практика, не даёт измеримого эффекта. Новое направление построено так, чтобы ИИ решал конкретные бизнес-задачи, а не просто ускорял рутину.

Новости
18 мая 2026

Как защитить бизнес и данные при внедрении ИИ

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

Новости
13 мая 2026

Искусственный архитектор: как нейросети справляются с проектированием ПО

В этой статье расскажем про большие языковые модели в приложении к работе архитектора ПО. Вместе мы посмотрим, насколько хорошо GPT понимает ИТ-архитектуру и сможет ли уже сегодня заменить архитектора. Пора разобраться, насколько глубоко ИИ может встроиться в рабочие процессы архитектора ПО — и стоит ли ему там оставаться.

Новости
24 апреля 2026

Бабушка с долгом в полмиллиона, однопоточное ядро и другие грабли: как не повторить чужие архитектурные ошибки

Любая система рано или поздно проверяется на прочность: нагрузкой, ростом бизнеса или человеческим фактором. Именно в эти моменты всплывают решения, которые казались безобидными на старте. Ниже — реальные кейсы из практики, где небольшие архитектурные допущения со временем превращались в ощутимые проблемы. Разберем, какие сигналы можно было заметить сразу и что стоит учитывать, чтобы не повторить эти сценарии в своих проектах.

Новости
16 апреля 2026

Как защитить информацию в приложениях, использующих ИИ

Представим, что системы контроля и анализа транзакций в банке начинают игнорировать 30% мошеннических операций. Система управления энергосетью выводит из строя ключевой узел подачи электроэнергии в город. Чат-бот службы поддержки начинает массово раскрывать персональные данные клиентов. К сожалению, это новая реальность, с которой может столкнуться любая компания, интегрирующая ИИ-системы в бизнеспроцессы.

Новости
08 апреля 2026

Java без розовых очков: какие знания отделяют грейды

Почти каждый разработчик рано или поздно задается вопросом: «Я уже Middle или все еще уверенный Junior?» Опыт растет, задач становится больше, стек шире — но вместе с этим появляется и иллюзия, что раз ты пишешь на Java каждый день, значит, язык знаешь.

Новости
23 марта 2026

ИИ против джуна: как победить нейросети при устройстве на работу

Начинающим разработчикам и раньше было непросто найти первую работу, а сейчас и подавно: конкуренция выросла кратно, а рынок окончательно стал «рынком работодателя».

11 марта 2026

Мартовский апгрейд: обновляем компетенции со скидкой 20% и приятными бонусами

Март — традиционное время не только для обновления природы, но и для профессионального роста. С 1 по 31 марта 2026 года у нас действует акция «Мартовский апгрейд».

05 марта 2026

Февраль 2026: Разбираем тренды, прокачиваем архитектуру и учимся договариваться с ИИ. Бесплатные вебинары для ИТ-специалистов

Февраль — месяц, когда уже видны цели на год, но еще есть время скорректировать курс и зарядиться новыми знаниями.

Новости
06 февраля 2026

Как ИТ-компании могут компенсировать до 10 млн ₽ на обучении сотрудников в 2026 году

Как аккредитованный учебный центр, специализирующийся на подготовке ИТ-специалистов, мы не только проводим программы дополнительного профессионального образования, но и помогаем корпоративным клиентам корректно оформить документы для участия в программе «Субсидия на обучение сотрудников» Департамента предпринимательства и инновационного развития города Москвы. В этой статье — структурированный обзор условий, требования к компаниям и сотрудникам, а также как мы можем помочь вам при подаче заявки.

Жизнь компании
20 января 2026

Архитекторы vs Рутина: Как открытый вебинар за 2 недели превратился в кастомный ИИ-интенсив

В Учебном центре IBS мы регулярно проводим бесплатные вебинары для ИТ-специалистов. Это наша философия — делиться реальными знаниями, а не просто давать рекламу. Один из таких вебинаров, посвященный практическому применению ИИ в инженерии, посетили сотрудники крупной компании — лидера в спортивном ритейле.

12 января 2026

Чистая выдумка: Как придумать класс, которого нет, и спасти проект от хаоса

Знакомо: вы описываете требования, рисуете сущности — Клиент, Заявка, Документ… А потом система превращается в «комок» с сильной связанностью (big ball of mud), где любое изменение стоит как полпроекта?

Новости
16 декабря 2025

Федеральное признание: нашу программу по системному анализу признали лучшей ИТ-программой в стране

Программа Учебного центра IBS «Системный аналитик. Уровень Специалист» признана лучшей ИТ-программой онлайн-обучения в России по итогам премии «СМАРТ ПИРАМИДА — 2025»!

16 декабря 2025

Бизнес-аналитик 2.0: как меняется профессия и какие навыки теперь нужны

Когда-то бизнес-аналитик ассоциировался с человеком, который «пишет ТЗ». Сегодня этого явно недостаточно. Современный БА — это стратег, коммуникатор и системный мыслитель, который одинаково уверенно чувствует себя в бизнес-контексте и технических деталях. Чтобы не застрять в прошлом, важно понимать, как эволюционирует роль аналитика и какие компетенции становятся критически важными.

Новости
05 декабря 2025

Обратная сторона Event-Driven: Почему Мартин Фаулер призывает к осторожности?

Вы узнаете один из 4 ключевых паттернов EDA и поймете, как избежать главной ловушки, в которую попадают многие команды.

Новости
25 ноября 2025

Скидка 30% на 8 курсов декабря

Год близится к завершению, и пока другие подводят итоги, вы можете сделать самую выгодную инвестицию — в себя. Мы собрали 8 курсов со скидкой 30%*, которые стартуют в начале декабря, чтобы вы могли точно успеть пройти обучение до конца года и прийти к новым карьерным целям с обновлённым стеком технологий.

Новости
20 ноября 2025

Осенний апдейт карьеры: от -30% до -50% на курсы ноября!

Только сейчас: скидки от 30% до 50%* на ноябрьские курсы для тех, кто хочет быть на шаг впереди в IT. Практические программы помогут укрепить ключевые навыки и выйти на новый уровень профессиональной зрелости. Успейте подать заявку, чтобы воспользоваться предложением.

Новости
23 октября 2025

Как одновременно заварить кофе для 10 000 сотрудников — и еще 7 неожиданных вопросов архитектору ПО

Как убедить заказчика отказаться от Excel, зачем архитектору опыт кодинга и почему эволюция ПО похожа на эволюцию живых существ?

Новости
21 октября 2025

Нужна помощь? Оставьте заявку, и мы свяжемся с вами в ближайшее время

Согласен получать на e-mail информационные рассылки о новостях Учебного центра IBS
Корпоративное обучение Оценка персонала Сертификация О нас Стать тренером Блог Личный кабинет
Пользователь только что записался на курс ""
Спасибо!
Форма отправлена успешно.