вторник, 21 декабря 2010 г.

Правильный багрепорт 2: точность описания и исследование проблем

Разработчики любят понятные багрепорты, четко описывающие, в чем заключается проблема. С понятным и простым сценарием воспроизведения. С логами, относящимися к описываемой проблеме. С дополнительными данными, доказывающими, что дело не в кривой настройке окружения. Идеальный багрепорт - тот, прочитав который разработчик сразу знает, что нужно починить (по крайне мере на уровне бизнес логики). Идеал редко достижим, но можно к нему стремиться. Если разработчики редко жалуются на недостаток (или, наоборот, избыток) информации в багрепортах, то мы на верном пути.

В прошлом посте про качество багрепортов я писал, как не забыть упомянуть в описании проблемы важную информацию, которая в момент описания бага кажется очевидной (для тестировщика, находящегося в контексте собственных действий). Я тогда предлагал простое техническое решение, которое напоминало, что помимо самой проблемы нужно еще упомянуть ряд параметров окружения и ожидания тестировщика от поведения приложения. Однако подобным образом можно перечислить только небольшой набор самых общих параметров, упоминание которых необходимо, но зачастую недостаточно для исследования/понимания сути проблемы. Набор данных, которые стоит упомянуть в описании проблемы, разнится от проблемы к проблеме - где-то достаточно сделать скриншот, где-то нужно добавить логи, нередко и в базу данных заглянуть полезно. Как же понять, что писать, а что нет? Ведь избыток информации тоже может запутать разработчика.

четверг, 16 декабря 2010 г.

Авралы как производная от качества планирования

Долгое время я считал авралы/переработки делом обычным - как в IT без этого? Но со временем я стал задумываться и понял, что все не так просто. В целом, понятно, что аврал - производная от планирования. Если мы что-то хотим сделать, но не успеваем, то приходится работать дополнительно по вечерам и/или в выходные. Нюанс в том, почему сложилась такая ситуация. Я выделил для себя три причины авралов со следующими условными названиями: ошибка планирования, тенденция планирования и отсутствие планирования.

Подробнее о каждом из типов.

вторник, 14 декабря 2010 г.

Аттестация в жизни технического человека.

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

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

среда, 1 декабря 2010 г.

[HDI] Увеличение своп-файла Linux без изменения разделов диска

Если вдруг потребовалось увеличить swap раздел на Linux'овой машинке, а править текущее разбиение диска на разделы не хочется, то можно поступить так:

# dd if=/dev/zero of=/var/swap bs=1M count=1048
# chmod 0 /var/swap
# mkswap /var/swap
# echo "/var/swap none swap defaults 0 0" >> /etc/fstab
# swapon -a


Собственно, тут создается файл, который в дальнейшем используется как swap-раздел.
Ключевой момент тут count=1048 - этот параметр определяет, какого размера файл будет создан.

P.S. честно своровано отсюда

Статистика дефектов. Спросите "Почему?"

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

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

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

четверг, 18 ноября 2010 г.

[HDI] Поиск и очистка inodes в Linux

Как известно, каждому файлу в Linux'е соответствует не только место на диске, но и некоторое количество inode. Как и место на диске, inode'ы тоже могут заканчиваться, и результат примерно тот же - создавать новые файлы становится невозможно.

Узнать, сколько inodes уже использовано можно с помощью команды
df -i

Но если узнать, кто занял все место - несложно, то понять, кто съел inode'ы чуть посложнее. Обычно они пропадают из-за большого количества мелких, как правило, временных файлов, которые кто-то не убрал за собой.

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

#!/bin/bash
# count_em - count files in all subdirectories under current directory.
echo 'echo $(ls -a "$1" | wc -l) $1' >/tmp/count_em_$$
chmod 700 /tmp/count_em_$$
find . -type d -print0 | xargs -0 -n1 /tmp/count_em_$$ | sort -n
rm -f /tmp/count_em_$$


Скрипт показывает, сколько inode использованы различными папками. Анализируются папки, начиная с той, откуда был запущен скрипт. То есть для поиска по всей файловой системе нужно запускать скрипт из корня.

P.S. своровано отсюда: http://stackoverflow.com/questions/653096/howto-free-inode-usage

вторник, 16 ноября 2010 г.

Рунглиш. Новояз. Жаргон.

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

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

Профессиональный жаргон - дело не новое, и думаю большинство с ним сталкивалось в своей работе, а уж в сфере IT - просто все. Жаргон свойственен любой профессии; где-то его больше, где-то меньше. В IT обилие жаргона связано, на мой взгляд, прежде всего с тремя аспектами:

четверг, 11 ноября 2010 г.

[HDI] Создание ISO-файла в Linux

Создание ISO файла из CD/DVD диска

dd if=/dev/cdrom of=/cdrom_image.iso
где
  • dd == "disk dump" - утилита для побитового копирования
  • if == "input file" - устройство, откуда читать
  • of == "output file" - файл, куда писать

Создание ISO файла из папки

mkisofs -D -iso-level 4 -o ./myimage.iso ./myfolder/
где
  • -D - позволяет работать с деревьями папок глубокой вложенности
  • iso-level 4 - позволяет работать с длинными именами файлов
  • /myimage.iso  - путь к создаваемому ISO-файлу
  • ./myfolder/ - путь к папке, содержимое которой надо поместиьт в ISO-файл.

воскресенье, 7 ноября 2010 г.

Скучная работа

Disclaimer.
Есть несколько классических холиваров, в которых рано или поздно (а чаще - время от времени) должен поучаствовать каждый тестировщик. Как-то: важность тестирования в процессе разработки ПО; уровень квалификации, небходимый тестировщику; место и роль автоматического тестирования и т.д.
Чтобы уже не возвращаться больше к холиварам в этом году, сегодня пост на одну из таких вечных тем, а именно - насколько интересна работа в отделе тестирования.

Необходимое классическое вступление.
Бытует мнение, что тестирование ПО - занятие скучное и нетворческое. Сидят, дескать, тестировщики, кликают кнопки, ползают по интерфейсу, растрачивают молодость впустую. Нет у них ни свободы-воли, ни силы воли, ни способности сделать нечто, не упомянутое в тест-кейсе. Были бы они чуть умнее - давно бы робот вместо них работал, но нет среди них умных. Убогое царство.

А что, не так, что ли?

пятница, 15 октября 2010 г.

Правильный багрепорт для всех и каждого.

Умение доносить свои мысли до другого человека - качество, необходимое тестировщику. Оно включает в себя способность и внятно сформулировать свои мысли, и выразить одну и ту же мысль разными словами, и выбрать верную интонацию (неважно,  в письме или устной речи), и много что еще.

Если тестировщик не может ясно сформулировать, что он имеет в виду; если он путается в терминах, забывает указать важные нюансы и не может совладать с эмоциями, то из его багрепорта зачастую мало что можно понять. Баг возвращается обратно (а их и так уже много вернулось), начинается пинг-понг, все нервничают и не любят друг друга.

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

С другой стороны работать с неясными багрепортами не хочется никому. Как же выходить из ситуации? Ну, вариантов может быть масса - наказание кнутом любителей навести тумана, поощрение пряником способных дать зацепки, проверка ясности изложения при приеме на работу... Все эти методы имеют право на жизнь (имхо, недолгую, но сейчас не об этом), однако все они содержат одну родовую травму: все они стремятся изменить человека так, чтоб он всегда говорил ясно, говорил то, что нужно, и не говорил при этом лишнего. Люди же, как известно, меняются небыстро. Хуже того: люди могут меняться в разные стороны. Совсем плохо: люди подвержены настроению и болезням, так что даже самый лучший тестировщик может однажды написать багрепорт, из которого на следующий день сам ничего не поймет. Хороший метод, который работает: менять не людей, а рабочее окружение.

четверг, 7 октября 2010 г.

Почему их так много?

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

Вот что получилось.

вторник, 25 мая 2010 г.

Почему-то не я, а он

В дни перемен, в дни тяжких раздумий практически всегда находятся недовольные. Причин для недовольсства обычно находится масса - неудобные новые утилиты или процессы, заброшенные старые инструменты, необходимость учить новое и так далее.
В данный момент речь пойдет о недовольстве карьерными решениями.
"Почему на место ушедшего руководителя назначили Михаила? Ему даже и тридцати еще нет, а мне уже 32, а я простой инженер. Не ценят меня."
"Саше присвоили новую категорию, а мне нет. А ведь вместе пришли сюда, и работу примерно одинаковую делаем."
"Ну вот, опять зарплату не повысили. Ишачишь тут, ишачишь..."
Зачастую, если спросить такого недовольного: "а почему продвигать надо было тебя?", ответ будет примерно "Ну я же хорошо работаю". Довольно странное обоснование на самом деле. Человека наняли на работу, очертили ему круг деятельности. Зачем его продвигать, если он всего лишь хорошо делает свою работу? Работа разная бывает, но в часто в ней много рутины, которая уже через полгода не требует участия мозга. Так чем заслужил поощрение человек, который просто сидит и не включая мозг повторяет день за днем примерно одни и те же действия?
Вот если человек растет, экономит свое и чужое время, упрощая рутинную работу, изучает новое (полезное для работы) и рассказывает другим узнанное, если он думает на шаг вперед - тут уже есть повод для продвижения и поощрения. Но почему-то не так уж много народу додумывается до этой простой мысли. Обычно наоборот: "Вы мне зарплату увеличьте, тогдя я может и подумаю, а не пошевелиться ли мне тут".
Тут есть еще один нюанс - важно, чтобы руководитель знал о достижениях своего подчиненного. Иначе у руководителя так и не появится повода похвалить :).

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

Мысли не новые, но банальные истины не перестают быть истинами :)

суббота, 20 марта 2010 г.

Никто не любит "инвалиды". А зря?

Нередкая претензия к  тестировщикам со стороны разработчиков:
- Сколько можно плодить "инвалиды"? Достали уже. Вы б хоть немного думали перед забиванием багов!
Ситуация неприятная для всех. Тестировщики чувствуют себя идиотами, разработчики плачут о времени потерянном на такие баги, все это ухудшает отношения между разработчиками и тестировщиками (и без того не безоблачные). Завести все это далеко может, но сейчас не об этом.
Что делать, если число багов с резолюцией (resolution) INVALID зашкаливает? Очевидно, что такого быть не должно, но как бороться? Для начала - понять, в чем причина такого положения и бороться уже с причинами. А они могут быть разными, "тестировщики идиоты" - не единственная.

Небольшой список возможных причин:

пятница, 5 февраля 2010 г.

Окно в работу

Каждый день мы работаем над своими задачами, и каждый день нас от них отвлекают. То начальник, то коллега; то аська, то письмо; то вопросом, то ссылкой на видеоролик.

Нередко из-за этого не получается начать толком работать, весь день уходит в пыль вопросов, ответов, чтения почты и мелких обсуждений. И это бывает обидно: и вроде при деле, и устал, а дело не сдвинулось вообще. Одна из техник, которые могли бы помочь – так называемые «коммуникационные окна».

Если по-простому, то коммуникационное окно – это время, когда человека дергают по минимуму. Идеальное коммуникационное окно – время с пяти утра и до девяти. Все спят, отвлекать некому, можно спокойно работать. Тут только одна проблема – проснуться :). Впрочем, это из разряда крайностей и экстрима. Вариант попроще – например, не читать почту сразу после получения. Если возможно – вообще открывать почту примерно раз в час. E-mail по определению несрочный вид общения, и час промедления обычно не так уж важен. Опять же, если человеку так уж нужен срочный ответ, а запрос проще послать почтой, он может прийти ногами или позвонить и попросить срочного ответа. Не стоит, кстати, впадать в другую крайность и прекращать читать почту вообще. За это тоже спасибо не скажут.

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

С другой стороны, при желании можно выбить себе час спокойствия в день; может поэтому многие программисты и любят несколько сдвинутые относительно «с 9 до 18» графики. Основная проблема с этими коммуникационными окнами в другом: они хороши, если работа не требует участия других людей – дополнительной информации, консультаций, результатов чужой работы и так далее. А такое случается далеко не всегда. Но если случилось – техника полезная :)

четверг, 4 февраля 2010 г.

Граничные условия

Развиваясь и становясь лучше, человек все лучше видит то, относительно немногое, зло и недостатки, что все еще остаются в нем. Человек, который не развивается, деградирует, наоборот, подчеркивает свои «плюсы» – тем более очевидные на общем мерзостном фоне («мы хоть и выпиваем каждый день, но не до беспамятства, как Сидоровы»).

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

Успешные компании постоянно совершенствуют все, что можно – процессы, логистику, людей (тренинги, а как же), схемы продаж и т.д.

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

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

С людьми сложнее – никто не оценивает человека, не учитывая этическую сторону. Человек ограничен моралью, а мораль весьма размыта и у разных слоев общества разная. Чай не в Древней Руси живем. Так что при желании ( желание обычно есть) и наимерзейший тип докажет себе, что он-то не так уж плох, а проще сказать – молодец и все правильно делает. И наоборот, хороший, но нервный человек раздавит себя за малейший, может даже и мнимый, огрех. Но в целом, человек, учитывающий ограничения морали, закона и физического пространства лучше человека, который не принимает их во внимание. То есть тут тоже ограничения способствуют улучшению.

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

Ну и, конечно, не надо выдумывать новые бессмысленные ограничения. Вполне достаточно следования тем, что проверены веками :)