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

На примере нашего проекта я расскажу как мы отлично с этим справились и какие практики выработали.

С докладом на эту тему я выступил на SECR-2016, слайды приложены в конце статьи.

Суть проблемы


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

Исходные данные


Наше приложение помогает клиентам одного известного инвестиционного банка управлять внесением и изъятием залогов для осуществления клиринга их сделок.

Приложение поддерживает две бизнес линии:

  • Биржевой клиринг (Listed Derivatives)
  • Внебиржевой клиринг (Cleared Over-the-Counter)

Клиенты представлены тремя регионами с уникальной финансовой регуляцией:

  • US — США
  • EUR — Европа
  • UK — Соединенное Королевство

Таким образом, одна и та же фича должна быть сделана с учетом всех тонкостей каждой бизнес-линии и региона.

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

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

А на этапе UAT нас ждал полный провал. Консультанты настолько мастерски смешали правила погашения залогов в EUR и UK регионах, что полученный функционал оказался неприемлем ни для одних ни для других. Это, а также прочие неучтенные ими моменты, перечеркнули около полугода нашей работы.
Консультантов выгнали, а нас отправили в свободное плавание с новым PM'ом.

Что мы сделали


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

Организационные изменения

Раньше, мы работали с заказчиками через BA, теперь, мы работаем с ними напрямую. Заказчиков пять человек. Для каждой пары бизнес линия + регион. PM участвует только на этапе определения плана работ и сортировки клиентских хотелок по приоритету.

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

Благодаря этому мы максимально эффективно используем время общения с заказчиками, без промежуточных этапов и сопутствующих искажений. Мы успеваем узнать всё что нам нужно, не задерживая разработку.

Пользовательские истории

Мы стали задавать не только вопрос «Зачем?», но и «Кто?» и «Как?». Специфика работы клиентов под разными регуляторами отличается и жизненно важно знать как именно будет использовать новые возможности клиенты тех регионов которые это затрагивает.

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

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

Impact analysis

Для управления требованиями мы используем JIRA + Confluence. По этому при заведении Story мы указываем метки всех бизнес-линий и регионов на которые влияют описываемые в ней требования.

Благодаря тому, что JIRA интегрирована со Stash, при проведении анализа воздействия, мы сначала находим все задачи связанные с объектом поиска, видим что именно эти задачи затрагивали и потом уже по commit'ам разработчики гораздо точнее выявляют зависимости и нежелательные воздействия.

Данный метод работает гораздо лучше чем просто оптимистичный поиск по коду.

Интеграция

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

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

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

QA

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

UAT (приемка пользователями)

Мы стали делать избыточный UAT. Раньше, если у нас, допустим, было 30 кейсов мы делили их поровну между заказчиками и получалось по шесть на каждого. Теперь же, каждый заказчик получает полный набор кейсов которые влияют на его комбинацию линия+регион.

Т.е. при тех же 30 кейсах, у одного могло быть 25 кейсов, у другого 20, а у третьего всего 5 и так далее. Чем больше регионов и линий затрагивал кейс, тем больше он дублировался среди заказчиков. Это, конечно, увеличило на них нагрузку при приёмке, но мы смогли убедить их в пользе именно такого подхода.

Итог


Применив все описанные выше методы, мы успешно работаем уже почти год, провели три релиза и не получили ни одного UAT или PROD инцидента за всё это время.

Поделиться с друзьями
-->

Комментарии (7)


  1. amarao
    11.11.2016 16:44
    +1

    А где разработка-то?

    Здравствуйте, меня зовут Вася и я пишу КОД.
    Спрашивайте меня вопросы.


    1. davvol
      11.11.2016 18:42

      Разработка — это не только код.


  1. belonesox
    11.11.2016 18:39
    +1

    Видео того доклада с SECR: http://0x1.tv/20161029CF


  1. polifill
    11.11.2016 20:37

    Обыски закончились?


    1. davvol
      12.11.2016 00:48

      Они и не начинались.


  1. vvagr
    13.11.2016 14:12

    Так репозиторий кода у вас Stash? А там удобно хранить 6 конфигураций? Есть ли общие компоненты кода для всех шести?


    1. davvol
      13.11.2016 22:17

      Если под «шестью» вы имеете ввиду линия+регион, то с этой точки зрения у нас всё в одном репозитории и соответственно один код.
      Но есть локальные окружения, в которых ведется разработка, потом всё мерджится на SIT и дальше UAT, а в конце PROD