Два с половиной года назад, когда мы с командой (точнее её тогда еще не было) начинали разрабатывать наш продукт, мы не задумывались о методологиях, процессах и прочих, казавшихся нам тогда не нужными, бюрократических вопросах. Время шло, продуктов становилось больше, команда росла. Постепенно, все начали понимать, что образовывается некий хаос, который все сложнее контролировать, а главное, который серьезно ограничивает наши возможности. На самом деле, незаметно для нас ситуация приближалась к критической.
Под катом длинная реальная история внедрения Scrum в процес разработки, который переживал не лучшие времена. Надеюсь эта история будет вам интересна и, возможно, поможет вам решиться или решить какие-то проблемы.
Чтобы лучше оценить ситуацию:
Команда состоит из пяти человек (1 фронт, 3 бэка и я — менеджер продукта) + один DevOps инженер, обеспечивающий нас первоклассной настройкой серверов.
Также есть отдельная команда по разработке нашей RTB платформы, но в данном рассказе она не фигурирует.
Итак, ситуация:
Осень 2014. Команда поддерживает две небольших системы и активно разрабатывает три других, объединенных в один комплекс с общей архитектурой. По сути это даже не команда. В процессе разработки, исторически сложились люди ответственные за каждую систему и только ею занимающиеся. Поддержкой двух маленьких систем и разработкой одной занимается один программист, еще две системы распределены по двум другим членам команды и, наконец один фронтендер занимается разработкой единого интерфейса, который могут использовать все системы.
Кодовая база на тот момент составляла уже сотни тысяч строк, тестов было минимальное количество, автоматизации никакой. В Git-e использовалось две ветки master на продакшене и dev в разработке, естественно было множество проблем при больших сливаниях и т.д. Постепенно скорость внедрения новых фич упала практически до нуля. Руководство просило хоть как-то оценивать сроки, но по сути, любые оценки были пальцем в небо.
Большой проблемой было еще и то, что мы не могли даже как-то балансировать между проектами и приоритетами. При попытке выделить больше людей на систему А, приостановив, например разработку системы B, мы сталкивались с тем, что программист абсолютно не знал чужой код, слабо представлял бизнес-задачи системы и, по сути, тормозил разработку еще на долгое время.
Почему все было так плохо? Все просто. Когда мы начинали, главным было сделать все быстро, а как известно в погоне за скоростью всегда страдает качество. В глубине души каждый понимал, что это неправильно, но казалось, что нету времени подумать об этом. Да, мы сами виноваты, но что есть, то есть.
Было понятно, что надо что-то менять.
Начало
Идея использования Scrum давно витала в воздухе. Основные ее преимущества были ровно такими, как нам нужны: короткий релизный цикл, гибкий бэклог, быстрая обратная связь. Однако существовали и проблемы. Во-первых, у нас хоть и один комплекс, но разных систем, у каждой свой бэклог, свои приоритеты и нету возможности обеспечить каждую систему своей командой. Во-вторых, программисты очень инертный класс сотрудников, они привыкли работать, как раньше и, хотя и сами понимали, что не все гладко — опасались кардинально что-то менять. В-третьих, Scrum — это не только ведение проекта, это автотесты, CI, чистый код и многое из того, что у нас на тот момент не было.
Но время пришло, было понятно, что медлить больше нельзя и мы начали готовиться к тому, чтобы глобально изменить то, как мы работаем.
Внедрение
Для начала, нужно было решить главную проблему, без которой никакие следующие шаги не представлялись возможными.
Обмен знаниями
К этому мы готовились долго. Доделали все крупные задачи, которые на тот момент были начаты, составили описания бизнес-функций систем, а каждый разработчик подготовил рассказ про тонкие или неочевидные места в его коде.
Когда все было готово, мы на две недели приостановили любые новые разработки, только баг фиксинг и только в крайних случаях. За две недели каждый член команды презентовал свой код, а я в мельчайших деталях рассказывал о пользовательских потребностях.
Две недели люди изучали код, пытались фиксить «чужие» баги и задавали много вопросов.
Когда с этим было покончено и каждый хотя бы примерно представлял о чем речь в каждом проекте — настало время менять процесс.
Тут надо упомянуть, что в начале всего я был и Scrum мастером и Product owner. Я отлично понимал, что это не правильно, но в тот момент, просто невозможно было работать иначе. Я единственный из команды качественно знал принципы и правила скрама, но я же и должен был представлять продукт.
Процесс
Если до этого момента все шло относительно хорошо, то тут начались проблемы. Программисты в целом поддерживали Scrum, но когда дошло дело до планирования — начались возражения вида «Зачем столько времени тратить на болтовню?», «Целый день бестолку сидим в переговорке», но конечно самый шок был у всех, когда я заикнулся о Daily Scrum — «Каждый день болтать — ужасно», «Каждый сам может посмотреть все в джире/битбакете», «Если кому интересно — он спросит».
Было понятно, что вводить что-то надо постепенно, и дело тут не в том, что процесс был навязан «сверху», нет, люди хотели изменений, но такое было выше их сил.
Мы начали с введения спринтов и да, планирования.
Мы объединили бэклоги всех подсистем в один и постарались расставить приоритеты. Наши первые user-story представляли из себя старые таски, они могли быть чисто техническими и тд. Оценивали в story points, за основу взяли шкалу степеней двойки, но конечно изначально оценки разнились в разы. Первые спринты у нас длились неделю, некоторые не одобряли такие короткие спринты, и такую частую «болтовню», но те, кто меня поддерживали, понимали, даже на неделю мы пока не могли запланировать все точно, о больших спринтах пока не могло быть и речи.
Мы начали наш первый спринт в среду вечером и решили, что ретроспектива будет через неделю в среду утром, таким образом, она займет полдня, потом планирование и новый спринт. Ни о каких демо тогда, конечно не могло быть и речи, нам по сути нечего было показывать, кроме того это еще один пункт увеличения эмоциональной нагрузки на программистов.
Итак, в среду утром, придя на ретроспективу мы дружно поняли, что у нас в работе еще несколько задач из спринта, которые «осталось чуть-чуть доделать» (на самом деле чуть-чуть могло означать целый день работы). Тут обнаружилась еще одна непонятка, на ретроспективе мы должны были обсуждать проблемы и возможности улучшить наш процесс, но программисты дружно заявляли, что «никаких проблем нет». Они не чувствовали, что что-то не успели, да сегодня они все по обсуждают, а потом закончат. Не было ощущения цикличности процесса.
Еще несколько недель мы продолжали работать в таком режиме, я старался обратить внимание на то, что спринт это именно итерация, а не просто отрезок на пути. В конце концов было найдено более менее хорошее решение. Мы разделили ретроспективу и планирование и разнесли их на разные дни, во вторник ретро, в среду планирование, между этими встречами, программисты решали разные RND задачи, те, которые было еще рано как-то оценивать, посколько было не ясно, что делать. Но самое главное, между ретро и планированием было запрещено работать над задачами прошедшего спринта. Это тоже сначала не понравилось, потому что незаконченный код оставался и забывался, однако эта мера принесла свои плоды. Команда начала понимать, что незаконченные в спринте задачи — реально не закончены, они могут быть забыты, оставлены на неопределенный срок и т.д.
Тем временем, надо было обратить внимание и на работу с кодом. Раньше тесты писались только на ключевые функции и, по сути, они покрывали крайне малую часть кода. С этого момента мы решили, что каждый кусок кода, который затрагивает решаемая задача, должен быть покрыт тестами. Тут тоже были свои моменты, например на планировании первые спринтов пять, надо было часто напоминать при оценке «А с тестами эта задача сколько баллов займет?». Но это внедрялось все-таки довольно просто, все слишком хорошо понимали зачем это надо.
Другой большой бедой стало то, что несмотря на две недели изучения, люди все-таки плохо знали «чужие» проекты.
Во-первых, на планировании задачу по проекту А человек, который его разрабатывал оценивал в 4 балла, а остальные в 16 и 32. Приходилось долгое время объяснять, что оценка должна учитывать то, что задача может оказаться у человека, который раньше с этим проектом не работал.
Во-вторых, разработчики стали активно пользоваться тем, что Scrum предлагает членам команды самим выбирать себе задачи.Таким образом, программист обычно старался взять себе задачу по «своему» проекту, чтобы не заморачиваться с чужим кодом. На несколько недель, нам пришлось в вести правило, что тебе запрещено брать задачу из «своего» проекта, если на доске есть другие. Было недовольство, но, надо сказать, оно быстро сошло на нет, как только люди достаточно изучили весь код.
Но конечно главное и, безусловно лучшее, что произошло во время этого перехода, так это то, что несколько хороших ребят, которые раньше просто работали за одним столом, наконец-то стали становиться командой. До этого они, разве что вместе ходили на обед, да и то редко, а тут стала возникать реальная взаимопомощь, совместная работа и ответственность.
Развитие
Медленно, но верно, мы двигались в сторону правильного и хорошего процесса, который помогал нам работать.
Через пару месяцев мы ввели Daily Scrum (стендап), назначили его на 12:00, потому что к этому времени обычно все уже были на работе (у нас очень гибкий график). Долгое время на стендапе каждый просто называл задачи над которыми работал, и это было не очень полезно, но прошел какой-то период адаптации и команда стала реально обмениваться полезной актуальной информацией о проблемах и прогрессе.
Спринты стали двухнедельными, мы научились лучше оценивать задачи и смогли себе это позволить. Оценки на планировании стали совпадать в большинстве случаев, а когда они не совпадали мы могли все обсудить и, чаще всего, придти к общему мнению.
Процент чисто технических задач в бэклоге стал постепенно падать. И все чаще задача представляла из себя именно User Story.
Слабым местом в процессе, все еще была ретроспектива, на большинстве из них команда не могла предложить тем для обсуждения. «У нас все хорошо» — довольно распространенное утверждение. Исполняя роль Scrum мастера, я прочитал большое количество материалов на эту тему и стал использовать некоторые методики, однако есть все-таки большая разница между теорией и практикой, например стандартный метод поиска корневой проблемы — очень хорош, но на практике, он показывал, что у нас есть проблема в неделимости некоторых задач, о которой мы и так знали, но ни один хитрый метод не мог нам помочь решить эту проблему. Однако все-таки со временем у ребят начала проявляться инициатива, которая безусловно была крайне полезна.
Мы стали использовать Git Flow, настроили Jenkins чтобы прогонять автотесты при каждом коммите, стали мерить покрытие кода и стараться его улучшать. Количество хотфиксов, которые в начале могли занимать пол спринта, стало сокращаться. Качество продукта, а главное настроение наших пользователей существенно улучшилось. Мы проанализировали где у нас слабые места в процессе разработки и придумали как поступить с долгими Code Review.
Наши дни
Прошло больше полугода с тех пор, как мы начали эту эпопею. Сегодня мы все еще развиваемся и собираемся делать это всегда. Однако уже можно сказать о результатах.
- Мы работаем одной командой над всеми задачами, а значит, если кто-то заболеет — ни один проект не останется без поддержки.
- Скорость разработки в количестве внедренных фич за период времени выросла в несколько раз, если сравнивать с осенью прошлого года.
- Количество багов и хотфиксов, на данный момент у нас от нуля до одного за спринт, что говорит о том, что качество системы увеличилось на порядок.
- За эти полгода мы разгребли бэклог от накопившихся задач, убрали лишнее и сейчас это полноценный динамично-меняющийся список фич, которые мы реально внедрим в ближайший квартал.
- Кроме этого, благодаря реалистичным оценкам, мы, зная скорость команды, можем строить более долгосрочные планы и расчитывать, что примерно сделаем в следующие полгода.
Впереди у нас еще много работы над собой. Недавно мы наконец дошли до того, что пора ввести демо, посмотрим к чему это приведет. Кроме того, мы понимаем, что мы просто далеки еще от идеала и можем работать на порядок быстрее и стараемся этого достичь. Однако главное, что я могу сказать, что никто из команды не жалеет о том, что мы начали это, и несмотря на многие трудности, многие из которых, возможно были связаны еще и с нашей неопытностью в agile процессах, мы-таки достигли порядка в процессах и реально спаслись из ситуации, в которую нас завели погоня за скоростью и боязнь бюрократии.
Спасибо за прочтение, буду рад ответить на любые вопросы, а также принять любую критику.
Комментарии (28)
velvetcat
05.10.2015 23:54+3Scrum — это не только ведение проекта, это автотесты, CI, чистый код и многое
Золотые слова :)
ZZZ_Sochi
08.10.2015 13:03+1У вас фулл-стек программисты, или есть разделение на бэк и фронт?
Если разделяете, то как описываете user story для двух программистов?dmitriyabr
08.10.2015 13:43Два похожих вопроса, этот и следующий
Тут, конечно же, тоже не все было гладко
Изначально у нас бэк и фронт программисты. Немного и те и другие умеют соседнюю область. Мы очень стараемся, чтобы user story были и на бэк и на фронт, так часто получается, если это новый функционал, с новым интерфейсом и тд. Описание user story для двух программистов — не проблема, она на то и user story, описывается то, что хочет получить пользователь, там вполне может быть как интерфейс, так и бизнес логика бэка.
Но, конечно, часто бывают случаи чисто-фронт и чисто-бэк задач, в этом случае оцениваем их всей командой, но рассчитываем, что с большей долей вероятности делать эту задачу будет фронтендер/бэкендер. Если в течении спринта становиться ясно, что фронтенд не справляется — бэкенд старается помочь. Собственно проблемы были в начале внедрения именно тут, бэкендеры не хотели особо помогать фронтеду (бэкендеров больше), а в случае неудач, пытались свалить ответственность, но постепенно все наладилось.
Как правильно заметил jee — всё-таки не полная взаимозаменяемость, но мы стараемся.clockworkbird
08.10.2015 13:46У нас одна user story включает полный цикл — от проектирование — дизайн — верстка — программирование — тестирование.
Пока разбиваем на подзадачи, выставляем зависимости и оцениваем каждую.dmitriyabr
08.10.2015 14:00+1Ну мы так делали только в самом-самом начале, все-таки это противоречит принципам скрама, оценивать надо задачу целиком, так как отдельные стадии не создают законченного функционала, кроме того — надо стараться избавляться от зависимостей. Мы тоже делим на подзадачи, в том числе часто разделяем фронт и бэк, но надо стремиться, чтобы делать можно было их в любом порядке, а не так, что мы не начинаем бэк, пока не готов фронт.
ZZZ_Sochi
08.10.2015 14:10+1У меня в этом месте проблемы.
Полной взаимозаменяемости в моём проекте быть не может. Дело в том, что у нас очень большое клиентское приложение. Single page, конечно же. Это как другая Вселенная и перемешивать совсем не хочется.
И получается так, что пока бекенд не даст API, фронту делать особо нечего. Нет, не сказать, чтобы фронт простаивал, задач у них очень много. Тут проблема в другом: очень трудно в один недельный спринт впихнуть целую user story, потому что сначала два дня работают бекендеры, а потом два дня работают фронтендеры.
Пробовал извращаться, сначала описывая API, чтобы фронт мог всё сделать, просто замочив его, но часто получалось так, что некоторые вещи менялись в процессе работы бека и смысла в этом большого не было.dmitriyabr
08.10.2015 14:14+1Я верю, что не знаю вашей ситуации, НО
У нас тоже single page, и тоже по началу были такие проблемы, но со временем все решилось очень просто.
1) Бэк делает хендлер для API, который возвращает тестовые данные, это просто заглушка, делается за 10 минут.
2) Profit — фронт работает с этой заглушкой, бэк спокойно делает API
Насчет изменений в процессе работа бэка — надо больше обсуждать на планировании, это решает 85% «внезапных» изменений в ходе работы, в остальных 15% случаев — да, придется потерпеть, но и то вряд ли меняется прям всеZZZ_Sochi
08.10.2015 14:30Возможно, но пока это у нас не работает. Касательно заглушки, то у нас ровно то же самое, только на стороне фронта. Принципиальной разницы не вижу. Будем экспериментировать дальше… :-)
P.S. Спасибо за статью.Fedot
08.10.2015 14:48Как правильно заметил автор статьи, вам вероятно стоит попробовать глубже разбирать задачи на планировании/грумминге. В этот момент как правило и будет достигнут какой-то компромисс.
В этом процессе грумминг имеет очень важное значение, так как позволяет уточнять различные детали до планирования и уже на планировании можно +- определиться с тем как новая функциональность должна работать.
jee
08.10.2015 13:19А как у вас фронтендер стал работать с серверной частью и наоборот? Или всё-таки не полная взаимозаменяемость?
clockworkbird
08.10.2015 13:44Очень знакомо. Практически 1 в 1.
Тоже вводится не все сразу, а постепенно. Проходим по тем же граблям.
У нас проблемное место — несколько разных проектов и с этим реально головная боль. Одной большой командой работать не получается.dmitriyabr
08.10.2015 13:57А сколько человек в «одной большой команде»?
У нас наоборот была команда — по количеству идеально для скрама, а вот проектов было столько же, сколько людей. Но тут помогло то, что проекты все — все-таки одна большая платформа, если бы это были совсем разные системы — наверно бы не вводили именно скрам, хотя бы канбан, чтобы не было спринт-коммитов (не буквально имею в виду, но все-таки задачи в спринте не меняются)clockworkbird
08.10.2015 18:34в «большой команде» — 10.
Проектов — крупных 4, но есть еще мелкие, они пока вне скрама. Проекты не пересекаются. По каждому проекту свой бэклог и свои спринты.
Часть разработчиков (тестировщики, верстальщики) работают по разным проектам (либо целый спринт, либо полспринта тут, полспринта там).
Программисты выделенные под проект.
Есть ощущение, что команды по проектам должны вырасти и тогда уже каждая команда сама по себе + скрам над скрамом.dmitriyabr
09.10.2015 12:58Часть разработчиков (тестировщики, верстальщики) работают по разным проектам (либо целый спринт, либо полспринта тут, полспринта там).
Ну вот это по идее может очень вредить скраму.
Про увеличение команд — да, все верно, раз проекты разные нужны и полностью независимые команды, обычно, правда, все упирается в ресурсыclockworkbird
09.10.2015 13:57Все упирается в ресурсы заказчиков. 4-5 разработчиков в штат фуллтайм под проект не каждый хочет/тянет.
heoh
08.10.2015 14:02> Тут надо упомянуть, что в начале всего я был и Scrum мастером и Product owner.
А сейчас как? Вы больше не ScrumMaster?dmitriyabr
08.10.2015 14:07+1Один из программистов, который больше всех поддерживает и разбирается в scrum, сейчас постепенно перенимает на себя эти полномочия (Scrum мастера). Пока что переходный период.
Andrew_Den
08.10.2015 22:01+1Через пару месяцев мы ввели Daily Scrum (стендап), назначили его на 12:00, потому что к этому времени обычно все уже были на работе (у нас очень гибкий график)
У нас была похожая ситуация: часть разработчиков приходила к 10-ти, часть в 11, часть в 12, а уходили обедать в районе 13:30 +- все вместе. Сначала были дэйлики в 12 и вроде бы всем в команде удобно. Потом пришло понимание того, что мы сильно разбиваем время девелоперов, ведь те, кто пришел в 10, уже давно в работе и сейчас их лучше было бы не дергать, а те, кто пришел в 11, только полноценно в работу включились, получается рваный ритм. Т.к. все ходили в обед примерно в одно время, то мы перенесли время на 13:15 и получили другой результат. Во-первых, мы избежали этого рваного ритма и люди стали успевать больше, во-вторых, сами дэйлики начинали проходить продуктивнее, команда до всех доносила исключительно нужную информацию с минимум оффтопа и шуточек, ведь все понимали, что как закончим, так и пообедать можно будет и весь оффтоп перенести уже туда.
Если у вас девелоперы тоже ходят обедать +- в одно время, попробуйте подобную схему.dmitriyabr
09.10.2015 12:44Спасибо за комментарий и идею, надо будет попробовать!
На самом деле в начале у нас была скорее проблема с тем, что дэйли занимал примерно 50 секунд =), но сейчас да, возможно будет полезно.
clockworkbird
09.10.2015 13:59Интересно.
Но по ощущениям — более продуктивно с утра — в самом начале рабочего дня — настраивает разработчиков на работу.Andrew_Den
09.10.2015 14:36Конечно начинать день с дэйлика это самый продуктивный вариант, но в таком случае все члены команды должны приходить вовремя к дейлику и не сильно раньше его, иначе это время просто может потеряться из рабочего дня. Это, в свою очередь, может сильно повлиять на лояльность и настроение сотрудников, т.к. не всем удобно приходить, например, к 10-ти: транспортные причины, личные причины, много их. Из-за снижения лояльности и настроения продуктивность, как показывает практика, обычно падает. Значит в сумме мы не только не повысим продуктивность, но и еще можем получить проблемы с конкретными сотрудниками.
Если в вашей компании принято приходить в одно время, то конечно лучше начинать день с дэйлика. Если же на данный момент у вашей команды гибкий график начала рабочего дня, то стоит десять раз подумать перед тем, как это отменять, опросить сотрудников, посмотреть как они к этому отнесутся, если не будет явных возражений, то попробовать и изучить результаты, если же будут явные возражения — продумать последствия и взвесить полученные результаты.
У нас как раз гибкое начало дня и поговорив с людьми я понял, что ни к чему хорошему эта перемена не приведет, поэтому решил остановиться на предобеденных дэйликах.
Вообще Scrum относительно молодое и активно развивающееся направление. В нем можно пробовать разные гипотезы, главное тестировать их по одной и смотреть на результаты, при этом заранее просчитывать все точки невозврата относительно текущих процессов. Не всегда стоит искать от добра добра )
byria
Могли бы вы написать про набор, связку и последовательность внедрения программных продуктов для работы по Scrum в вашей команде кратко в пару строчек? С комментариями. Почему это или то, если возможно, применительно к вашей команде.
Пример: PM + Git + тестирование…
dmitriyabr
Про программные продукты у нас все довольно стандартно:
Bitbucket использовали с самого начала, выбрали его из-за цены и удобства, через какое-то время начали использовать JIRA для ведения бэклога. С началом внедрения Scrum немного переконфигурили JIRA, настроили там доску и прочие прелести, стали заводить ветки в Git через интеграцию JIRA+Bitbucket, что оказалось очень удобно.
Через какое-то время добавился Confluence, как хранилище документации, однако на данный момент качество документации у нас еще страдает (описано мало и очень поверхностно)
Мы пишем на питоне, поэтому в качестве тестов используем стандартные библиотеки. Для прогонки этих тестов настроен Jenkins.
Итоговая связка у нас JIRA+Confluence+Bitbucket+Jenkins+Slack
Slack начали использовать, когда всех окончательно достал скайп, оказалось это шикарнейший месенджер, с которым мы интегрировали все, что только можно и практически забросили почту. Пробовали HipChat потому что он от Атлассиана, как и остальные продукты, но он оказался для нас слишком сырым и неудобным.
В JIRA используем модули JIRA Agile для скрам доски и бэклога, JIRA Portfolio для долгосрочного планирования и JIRA Service Desk для баг репортов от пользователей.
Вроде все
byria
Благодарю!
А территориально все сотрудники в одном месте или есть те кто вообще в офисе не появляется?
dmitriyabr
Все сотрудники в одном месте и это очень важный момент. Я, конечно, слышал, но реально никогда не видел успешных, полноценных scrum-команд в удаленными сотрудниками. Все-таки находиться в одном месте, постоянно общаться в живую — очень важно для командного духа и мотивации.
Единственное исключение — наш DevOps инженер, он не входит в скрам команду и работает из другого офиса, но это работает, потому что у него абсолютно другая специфика работы. По сути, ему крайне редко надо синхронизироваться с нами.
byria
МЫ вот только присматриваемся к Scrum. Какую методологию или особенности можете посоветовать для команды 5 человек без единого места работы? Все удаленно, но продуктивно.
dmitriyabr
Ну это очень сильно зависит от обстоятельств, то, что я сказал про распределенные команды — это мой опыт, и он не только про скрам, а вообще про командообразование. Если вы успешно работаете удаленно — отлично. Scrum стоит выбирать, наверное, исходя из других условий таких как жесткость сроков, гибкость бэклога, необходимая частота релизов.
Также надо учесть, что и Scrum и другие методологии всегда подстраиваются под команду. Их надо кастомизировать.