• разработка системы по несформировавшимся требованиям, что может ограничить гибкость в будущем.
Разработать новую систему
Разработка специализированной системы. Если это вообще возможно, то, как правило, подобного развития событий нужно избежать.
Основное достоинство:
• систему можно целиком настроить и сконфигурировать для данной организации.
Основные недостатки или проблемы:
• значительные расходы и время разработки, а также текущие эксплуатационные затраты;
• риски проекта включают задержку сроков сдачи, низкое качество и повышенные расходы.
Аутсорсинг приложений
Этот вариант приобретает все более широкое распространение и должен быть серьезно изучен.
Основные достоинства:
• используются существующие знания и процессы разработчика;
• синергия и экономия на объемах.
Основные недостатки или проблемы:
• расходы по передаче стороннему подрядчику;
• недостаточная гибкость.
(См. Приложение L, где более подробно рассматривается аутсорсинг бизнес-процессов).
Количество систем
Автоматизированное решение почти наверняка будет содержать не один компонент, например модуль-систему рабочих потоков, автоматизированный модуль бизнес-правил и систему управления документами. В ситуации с несколькими автоматизированными компонентами следует обратить внимание на тот факт, что с ростом количества систем существенно растет число интерфейсов, как и объем усилий, необходимых для разработки и поддержки этих интерфейсов.
Шаг 4. Обновление функционально-технических спецификаций
Должен быть структурированный подход к спецификациям (функциональным, техническим и системным или проектировочным), разработке и тестированию решения BPM, как это изображено на рис. 19.5. V-схема показывает «недостающие звенья» между самими спецификациями и техническими условиями и тестированием. В недостающих звеньях, представленных на этом рисунке, зачастую скрываются коренные причины провалов многих проектов разработки систем в прошлом.
В левой части рисунка показаны бизнес-требования и соответствующая документация по разработке, а в правой части – тестирование, которое должно подтвердить соответствие продукта группы разработчиков этим требованиям и документам разработки. Проблема заключается в обеспечении соответствия ожиданиям с точки зрения бизнеса, и именно бизнес определяет, удалось ли этого достичь. Прямоугольники над пунктирной линией относятся к функциональным возможностям, а ниже этой линии – к техническим аспектам.
Общая проблема на этапе разработки – конфликт между желаниями бизнеса и тем, как разработчики интерпретируют требования. Часто это зависит от взаимодействия и совместной работы двух заинтересованных сторон и понимания того, что подразумевают такие отношения.
Сколько раз приходилось слышать о ситуациях, когда бизнес вырабатывает спецификационные требования, технический персонал перерабатывает их в технические функциональные спецификации на языке, малопонятном бизнесу, и чтобы уложиться в сроки, дает бизнес-подразделению три дня на утверждение. Бизнес-подразделению не просто трудно понять технический язык, ему нужно одновременно вести обычную деятельность, поэтому уложиться в трехдневный срок практически невозможно. Чтобы избежать задержек, бизнес-подразделение утверждает функциональные спецификации, не отдавая себе отчет о последствиях. Группа разработчиков теперь создает новую систему BPM и сдает ее бизнес-подразделению. На стадии тестирования заинтересованные стороны заявляют, что система не отвечает их ожиданиям, утверждая, что «это не то, что они хотели!» Ответ группы разработчиков: «Это не так. См. с. 179 утвержденных технических условий разработки». Бизнес-подразделение отвечает: «Но это совсем не то, что мы имели в виду», после чего проект переходит на стадию переделывания, а это, в свою очередь, ведет к затягиванию сроков, увеличению затрат и упущенным потенциальным бизнес-возможностям.
Так выглядит традиционный подход цикла разработки SDLC, и при этом создается ситуация повышенного риска проекта BPM.
Риски можно минимизировать несколькими способами:
1. Проведите анализ «что если…».
2. Проведите имитационное моделирование.
3. Определите, что не входит в объем проекта.
4. Бизнес-требования разрабатываются на этапе инноваций, а функциональная схема – на этапе разработки. Однако чрезвычайно важно обеспечить тесное сотрудничество бизнеса с техническим персоналом и совместно составить функциональную схему. У бизнес-подразделения должна быть возможность утвердить документ, полностью осознавая последствия и обеспечив соответствие и содействие требований бизнес-стратегии и целям. Хороший способ добиться понимания бизнес-требований – составить их, исходя из процессной точки зрения.
5. Разделите функциональную схему и техническую разработку.
6. Определите последствия разработки и добейтесь согласия по ним.
7. Как указано в главе 14, важно применять архитектуру гибко. Например, что делать, если появилось срочное бизнес-требование, а решение не укладывается в архитектуру? Один из вариантов – дать возможность проработать требование и установить строгие правила работы с таким исключением (например, решение должно быть выведено из эксплуатации в течение Х месяцев или соответствовать архитектуре в течение N месяцев). Такой механизм «клапана скороварки» очень важен, поэтому окончательный тест архитектуры – способ обработки исключений. Отвергать или игнорировать все исключения может показаться выигрышным подходом, однако это ведет к конечному проигрышу, поскольку люди будут все больше игнорировать архитектуру.
8. Критично включение требований к программному и аппаратному обеспечению, поскольку в большинстве случаев между ними есть взаимозависимость.
Кейс: неверный «быстрый путь»
Оператор связи хотел ввести новую систему для поддержки биллинговых процессов и обслуживания клиентов, и разработал требования только на основе действующей бизнес-модели: предоставление услуг наземной связи населению. Когда нам показали исходные спецификации, мы указали, что они полностью лишают систему гибкости. Исходя из обобщенной бизнес-модели, мы предложили оператору пойти по пути создания системы на основе переменного комплекса бизнес-параметров, а не жесткого программирования функциональности в системе. Например, вместо обеспечения услуг только населению, следует предусмотреть и другие типы клиентов: предприятия и дистрибьюторы, а вместо только одной роли организации (провайдер услуг) – допустить различные типы (сетевой оператор и дистрибьютор). Оператор совет проигнорировал, и после двух крупных перемен в его стратегии система стала безнадежно сдерживать бизнес; в такой степени, что была упущена редкая возможность увеличить долю рынка, и огромные усилия прилагались для сохранения рентабельности.