Модель
вариантов использования (Use—Case
Model).
Эта модель определяет требования к ПО
— то, что система должна делать — в виде
набора вариантов использования. Каждый
вариант использования задает сценарий
взаимодействия системы сдействующими
лицами (actors)или ролями, дающий в
итоге значимый для них результат.
Действующими лицами могут быть не только
люди, но и другие системы, взаимодействующие
с рассматриваемой. Вариант использования
определяет основной ход событий,
развивающийся в нормальной ситуации,
а также может включать несколько
альтернативных сценариев, которые
начинают работать только при специфических
условиях.
Примером варианта использования может
служить сценарий действий клиента
Интернет-магазина по отношению к сайту
этого магазина, в результате которых
клиент заказывает товар, например,
книги. Такой вариант использования
можно назвать «Заказ товара». Если
нас интересует сайт магазина только
как программная система, результатом
можно считать то, что запись о сделанном
заказе занесена в базу данных, а оператору
заказов отправлено электронное письмо,
содержащее всю информацию, которая
необходима для того, чтобы можно было
сформировать заказ. В нее входит
контактная информация покупателя,
идентификатор заказа и, например, список
заказанных книг с их ISBN, их количество
для каждого наименования и номера партий
для удобства их поиска на складе. При
этом выполнение остальной части варианта
использования — это дело других
составляющих системы под названием
«Интернет-магазин». Эта работа
может включать звонок или письмо клиенту
и подтверждение, что именно он сделал
заказ, вопрос об удобных для него форме,
времени и адресе доставки и форме оплаты,
формирование заказа, передача его для
доставки курьеру, доставка и подтверждение
получения заказа и оплаты. В нашем
примере действующими лицами являются
клиент, делающий заказ, и оператор
заказов.
Альтернативные
сценарии в рамках данного варианта
могут выполняться, если, например,
заказанного пользователем товара нет
на складе или сам пользователь находится
на плохом счету в магазине из-за
неоплаченных прежних заказов, или,
наоборот, он является привилегированным
клиентом или представителем крупной
организации.
Характеристики
и атрибуты качества программного
обеспечения по ISO 9126
Определения
характеристик и субхарактеристик
качества (ISO 9126-1)
Функциональные
возможности —
способность программного средства
обеспечивать решение задач, удовлетворяющих
сформулированные потребности заказчиков
и пользователей при применении комплекса
программ в заданных условиях.
Функциональная
пригодность —
набор и описания субхарактеристики и
ее атрибутов, определяющие назначение,
номенклатуру, основные, необходимые и
достаточные функции программного
средства, соответствующие техническому
заданию и спецификациям требований
заказчика или потенциального пользователя.
Правильность
(корректность) —
способность программного средства
обеспечивать правильные или приемлемые
для пользователя результаты и внешние
эффекты.
Способность
к взаимодействию —
свойство программных средств и их
компонентов взаимодействовать с одной
или большим числом компонентов внутренней
и внешней среды.
Защищенность —
способность компонентов программного
средства защищать программы и информацию
от любых негативных воздействий.
Надежность —
обеспечение комплексом программ
достаточно низкой вероятности отказа
в процессе функционирования программного
средства в реальном времени.
Эффективность —
свойства программного средства,
обеспечивающие требуемую производительность
решения функциональных задач, с учетом
количества используемых вычислительных
ресурсов в установленных условиях.
Практичность
(применимость) —
свойства программного средства,
обусловливающие сложность его понимания,
изучения и использования, а также
привлекательность для квалифицированных
пользователей при применении в указанных
условиях.
Сопровождаемость —
приспособленность программного средства
к модификации и изменению конфигурации
и функций.
Мобильность —
подготовленность программного средства
к переносу из одной аппаратно-операционной
среды в другую.
Стандарт
ISO
9126 предлагает использовать для описания
внутреннего и внешнего качества ПО
многоуровневую модель. На верхнем уровне
выделено 6 основных характеристик
качества ПО. Каждая характеристика
описывается при помощи нескольких
входящих в нее атрибутов. Для каждого
атрибута определяется набор метрик,
позволяющих его оценить. Множество
характеристик и атрибутов качества
согласно ISO
9126 показано на рисунке.
1. Функциональность
(functionality) —
способность ПО в определенных условиях
решать задачи, нужные пользователям.
Определяет,
что именно делает ПО, какие задачи оно
решает.
-
Функциональная
пригодность (suitability)
— способность решать нужный набор задач. -
Точность
(accuracy)
— способность выдавать нужные результаты. -
Способность
к взаимодействию (interoperability)
— способность взаимодействовать с
нужным набором других систем. -
Соответствие
стандартам и правилам (compliance)
— соответствие ПО имеющимся индустриальным
стандартам, нормативным и законодательным
актам, другим регулирующим нормам. -
Защищенность
(security)
— способность предотвращать
неавторизированный, т.е. без указания
лица, пытающегося его осуществить, и
неразрешенный доступ к данным и
программам.
2. Надежность
(reliability)
—
способность
ПО
поддерживать
определенную
работоспособность
в заданных условиях.
-
Зрелость,
завершенность (maturity)
— величина, обратная частоте отказов
ПО. Обычно измеряется средним временем
работы без сбоев и величиной, обратной
вероятности возникновения отказа за
данный период времени. -
Устойчивость
к отказам (fault
tolerance)
— способность поддерживать заданный
уровень работоспособности при отказах
и нарушениях правил взаимодействия с
окружением. -
Способность
к восстановлению (recoverability):
Способность восстанавливать определенный
уровень работоспособности и целостность
данных после отказа, необходимые для
этого время и ресурсы. -
Соответствие
стандартам надежности (reliability
compliance).
3. Удобство
использования (usability)
или практичность —
способность ПО быть удобным в обучении
и использовании, а также привлекательным
для пользователей.
-
Понятность
(understandability)
— показатель, обратный к усилиям, которые
затрачиваются пользователями на
восприятие основных понятий ПО и
осознание их применимости для решения
своих задач. -
Удобство
обучения (learnability)
— показатель, обратный усилиям,
затрачиваемым пользователями на
обучение работе с ПО. -
Удобство
работы (operability)
— показатель, обратный усилиям,
предпринимаемым пользователями для
решения своих задач с помощью ПО. -
Привлекательность
(attractiveness)
— способность ПО быть привлекательным
для пользователей. -
Соответствие
стандартам удобства использования
(usability
compliance).
4. Производительность
(efficiency)
или эффективность —
способность ПО при заданных условиях
обеспечивать необходимую работоспособность
по отношению к выделяемым для этого
ресурсам. Можно определить ее и как
отношение получаемых с помощью ПО
результатов к затрачиваемым на это
ресурсам всех типов.
-
Временная
эффективность (time
behaviour)
— способность ПО выдавать ожидаемые
результаты, а также обеспечивать
передачу необходимого объема данных
за отведенное время. -
Эффективность
использования ресурсов (resource
utilisation)
— способность решать нужные задачи с
использованием определенных объемов
ресурсов определенных видов. Имеются
в виду такие ресурсы, как оперативная
и долговременная память, сетевые
соединения, устройства ввода и вывода
и пр. -
Соответствие
стандартам производительности
(efficiency
compliance).
5. Удобство
сопровождения (maintainability) —
Удобство проведения всех видов
деятельности, связанных с сопровождение
программ.
-
Анализируемость
(analyzability)
или удобство проведения анализа —
удобство проведения анализа ошибок,
дефектов и недостатков, а также удобство
анализа необходимости изменений и их
возможных последствий. -
Удобство
внесения изменений (changeability)
— показатель, обратный трудозатратам
на выполнение необходимых изменений. -
Стабильность
(stability)
— показатель, обратный риску возникновения
неожиданных эффектов при внесении
необходимых изменений. -
Удобство
проверки (testability)
— показатель, обратный трудозатратам
на проведение тестирования и других
видов проверки того, что внесенные
изменения привели к нужным результатам. -
Соответствие
стандартам удобства сопровождения
(maintainability
compliance).
6. Переносимость
(portability) —
способность ПО сохранять работоспособность
при переносе из одного окружения в
другое, включая организационные,
аппаратные и программные аспекты
окружения.
Иногда эта характеристика называется
в русскоязычной литературе мобильностью.
Однако термин «мобильность» стоит
зарезервировать для перевода «mobility»
— способности ПО и компьютерной системы
в целом сохранять работоспособность
при ее физическом перемещении в
пространстве.
-
Адаптируемость
(adaptability)
— способность ПО приспосабливаться
различным окружениям без проведения
для этого действий, помимо заранее
предусмотренных. -
Удобство
установки (installability)
— способность ПО быть установленным
или развернутым в определенном
окружении. -
Способность
к сосуществованию (coexistence)
— способность ПО сосуществовать с
другими программами в общем окружении,
деля с ними ресурсы. -
Удобство
замены (replaceability)
другого ПО данным — возможность применения
данного ПО вместо других программных
систем для решения тех же задач в
определенном окружении. -
Соответствие
стандартам переносимости (portability
compliance).
Помимо перечисленных характеристик и
атрибутов качества, стандарт ISO
9126:2001 определяет наборы метрик для
оценки каждого атрибута. Вот
некоторые примеры таких метрик.
-
Полнота
реализации функций —
процент реализованных функций по
отношению к перечисленным в требованиях.
Используется
для измерения функциональной пригодности. -
Корректность
реализации функций —
правильность их реализации по отношению
к требованиям. Используется
для измерения функциональной пригодности. -
Отношение
числа обнаруженных дефектов к
прогнозируемому.
Используется
для определения зрелости. -
Отношение
числа проведенных тестов к общему их
числу.
Используется
для определения зрелости. -
Отношение
числа доступных проектных документов
к указанному в их списке.
Используется
для измерения удобства проведения
анализа. -
Наглядность
и полнота документации.
Используется для оценки понятности.
17
вопрос+18 вопрос(Вопрос 2 темы Качество
ПО и методы его контроля)
Качество
программного обеспечения определяется
в стандарте ISO 9126 [1] как
вся совокупность его характеристик,
относящихся к возможности удовлетворять
высказанные или подразумеваемые
потребности всех заинтересованных лиц.
Тот же стандарт ISO 9126 [1-4]
дает следующее представление качества.
При рассмотрении качества ПО различаются
понятия внутреннего качества, связанного
с характеристиками ПО самого по себе,
без учета его поведения, внешнего
качества, характеризующего ПО с точки
зрения его поведения, и качество ПО при
использовании в различных контекстах
— то качество, которое ощущается
пользователями при конкретных сценариях
работы ПО. Для всех этих взглядов на
качество введены метрики, позволяющие
оценить его. Кроме того, при создании
качественного ПО существенно качество
технологических процессов его разработки.
Взаимоотношения между этими аспектами
качества по схеме, принятой в ISO
9126
Методы
контроля качества
Как
контролировать качество системы? Как
точно узнать, что программа делает
именно то, что нужно, и ничего другого?
Как определить, что она достаточно
надежна, переносима, удобна в использовании?
Ответы на эти вопросы можно получить с
помощью процессов верификации и
валидации.
-
Верификация обозначает
проверку того, что ПО разработано в
соответствии со всеми требованиями к
нему, или что результаты очередного
этапа разработки соответствуют
ограничениям, сформулированным на
предшествующих этапах. -
Валидация —
это проверка того, что сам продукт
правилен, т.е. подтверждение того, что
он действительно удовлетворяет
потребностям и ожиданиям пользователей,
заказчиков и других заинтересованных
сторон.
Эффективность
верификации и валидации, как и эффективность
разработки ПО в
целом, зависит от полноты и корректности
формулировки требований к программному
продукту.
Основой
любой системы обеспечения качества
являются методы его обеспечения и
контроля. Методы
обеспечения качества [9]представляют
собой техники, гарантирующие достижение
определенных показателей качества при
их применении. Мы будем рассматривать
подобные методы на протяжении всего
курса.
Методы
контроля качества позволяют
убедиться, что определенные
характеристики качества
ПО достигнуты.
Сами по себе
они не могут помочь их достижению, они
лишь помогают определить, удалось ли
получить в результате то, что хотелось,
или нет, а также найти ошибки, дефекты
и отклонения от требований. Методы
контроля качества ПО можно
классифицировать следующим образом:
-
Методы
и техники, связанные с выяснением
свойств ПО во время его работы.
Это,
прежде всего, все виды тестирования,
а также профилирование и
измерение количественных показателей
качества, которые можно определить по
результатам работы ПО — эффективности
по времени и другим ресурсам, надежности,
доступности и пр.
-
Методы
и техники определения показателей
качества на основе симуляции работы
ПО с помощью моделей разного рода.
К
этому виду относятся проверка
на моделях (model
checking),
а также прототипирование
(макетирование),
используемое для оценки качества
принимаемых решений.
-
Методы
и техники, нацеленные на выявление
нарушений формализованных правил
построения исходного кода ПО, проектных
моделей и документации.
К
методам такого рода относится инспектирование
кода,
заключающееся в целенаправленном поиске
определенных дефектов и нарушений
требований в коде на основе набора
шаблонов, автоматизированные методы
поиска ошибок в
коде, не основанные на его выполнении,
методы проверки документации на
согласованность и соответствие
стандартам.
-
Методы
и техники обычного или формализованного
анализа проектной документации и
исходного кода для выявления их свойств.
К
этой группе относятся многочисленные методы
анализа архитектуры ПО,
о которых пойдет речь в следующей лекции,
методы формального доказательства
свойств ПО и формального анализа
эффективности применяемых алгоритмов.
Без технической душноты исследуем сценарии «пользователь <—> система». Для продактов, дизайнеров и аналитиков — оставили готовый шаблон
Всем привет! Я Ната, UX/UI дизайнер в Red Collar. В этой статье я расскажу о методологии, которая улучшит коммуникацию внутри команды, а значит и работу над продуктом — Use Case или «юзкейсе», а также поделюсь шаблоном для тех, кто сталкивается с ней впервые.
В идеальном мире юзкейсы составляет системный аналитик на основе правил, сформулированных бизнес-аналитиком после общения с заказчиком. В реальном мире таких позиций в команде может не быть из-за ограничений по времени и бюджету, но проблема передачи знаний внутри команды на проекте остается. В таких случаях писать юзкейс может дизайнер, тестировщик, продакт и другие люди.
Польза юзкейсов — единое представление о продукте
Если в команде более 5 человек, а проект длится более 3 месяцев, то может возникнуть дискоммуникация. Например:
-
разработчики неправильно поняли сценарий взаимодействия и реализовали фичу не так, как планировалось;
-
в ходе долгих обсуждений внутри команды вы сильно отклонились от первоначальной идеи и точно воспроизвести её не можете;
-
дизайнеры спроектировали функциональность, которая изначально не планировалась;
-
один и тот же кейс в разных местах реализован по-разному, что увеличивает время разработки и усложняет UX;
-
при тестировании пропускаются значительные ошибки;
- сменился состав команды: к проекту подключились новые участники, а ведущие члены команды ушли.
Сценарии юзкейсов — как игра в теннис между пользователем и системой
Use Case — это описание взаимодействия с системой в виде последовательности действий для достижения конкретного результата. По сути, это метамодель, которая иллюстрирует не саму систему, а набор функциональных требований к ней.
Методология была разработана в 80-х Иваром Якобсоном. Для всех желающих погрузиться в тему глубже есть бесплатная книга Use-Case 2.0, также другие ссылки по теме оставлю внизу статьи.
Для наглядности юзкейс можно сравнить с игрой в теннис, где один игрок это пользователь, другой — система. Удар ракеткой это действие, которое совершает пользователь, после чего мяч переходит системе, и далее система ему отвечает. Разница только в том, что в юзкейсе пользователь или система могут подряд совершить несколько действий.
Юзкейсы существуют в двух равнозначных видах: UML-диаграмма или текстовый документ. По желанию их можно совмещать
«Основной юзкейс» — сценарий успеха: участники + действия + результат + доп. условия
Единого формата для написания юзкейсов не существует. Каждая компания сама определяет для себя формат и уровень детализации. Опишу основной принцип написания.
Основные элементы юзкейса:
1. Понятный заголовок, желательно, чтобы он содержал результат юзкейса. Пример, «Создание заявки».
2. Действующие лица или участники. Можно выделить такие варианты:
- «Пользователь и система». Например, при авторизации.
-
«Несколько пользователей и система». Например, если мы описываем общение в чате.
- «Система и система». Например, если мы описываем внутренние процессы внутри системы.
- «Несколько систем и система».
3. Описание последовательности действий в виде сценария.
4. Результат, то есть то, к чему должны прийти пользователь или система.
Ниже показан простой вариант юзкейса на примере регистрации. В нем есть все основные элементы. Также добавлена нумерация шагов, чтобы проще было ссылаться на конкретный шаг в коммуникации.
Пример простого юзкейса
Выглядит понятно, но в реальности кейсы могут оказаться сложнее, поэтому к юзкейсу добавляют дополнительную уточняющую информацию:
- контекст использования;
- откуда происходит переход к юзкейсу;
- дополнительные условия;
- триггер;
- цель;
- изменения в технологии.
В описание юзкейса могут добавлять перечисление инпутов (полей ввода), если это необходимо для понимания сценария.
«Альтернативный юзкейс» — сценарий ошибки
Рассмотрели вид основных сценариев юзкейсов, а что если возникла ошибка или пользователь столкнулся со сложностями? Для этого создается альтернативный юзкейс: когда результат основного не был достигнут. Например, пользователь не смог зарегистрироваться, так как имя уже занято или с указанной почты уже создана учетная запись.
Альтернативные юзкейсы прописывают отдельно, в нашем случае будет создана отдельная таблица, но если сценарий короткий, то мы описываем его в рамках основного юзкейса. Пример ниже.
Пример юзкейса с альтернативными сценариями внутри основного
Чеклист для написания юзкейсов
Разобрались, что юзкейс нам нужен в первую очередь для улучшения коммуникации внутри команды при разработке продукта. Теперь вы можете легко его написать, но важно, чтобы его также было легко читать. Ниже найдете критерии, которые помогут вам написать легкий для восприятия юзкейс.
Вначале сделайте единый шаблон и заведите словарь
В идеале юзкейсы пишутся на этапе проектирования, при планировании фичей или продукта в целом, но бывает так, что необходимость в юзкейсах обнаруживается позже, когда дизайн готов, а часть продукта уже вышла в прод.
Если вы на начальной стадии проекта, рекомендую начать с составления пути пользователя, а позже переходить к юзкейсам.
Если у вас уже готов дизайн, то перед написанием юзкейсов внимательно изучите все материалы, составьте список разделов и взаимодействий с ними в связке с продактом, дизайнером и другими лицами, участвовавшими в планировании и проектировании продукта.
Советы, которые ускорят написание юзкейсов:
- Создайте один шаблон для всех юзкейсов на проекте. Не страшно, если он будет видоизменяться со временем. Главное, чтобы не приходилось для каждого юзкейса придумывать уникальный формат, так как их будет сложно писать и еще сложнее читать.
- Создайте словарь терминов. Если внутри вашей команды активно используется определенная терминология или вы работаете над узкоспециализированным продуктом, создайте словарь с расшифровкой терминов и ссылайтесь на него при написании юзкейса.
Так нужен ли вам юзкейс?
Важно понимать, что юзкейс — это инструмент, а цель любого инструмента — упростить и улучшить работу. Если после внедрения юзкейсов в проект вы не видите изменений, а ресурсы расходуются все больше на ведение документации, то, вероятно, вам стоит пересмотреть процесс ведения документации и протестировать другие инструменты, например, User Story.
Всем крутых продуктов!
Ната Нефедьева
Шаблон юзкейса + дополнительные материалы
Подготовила для вас шаблон юзкейса, открыт всем в гуглдоке.
1. Статьи и бесплатные книги о юзкейсах от создателя методологии Ивара Якобсона — даст более полное представление об инструменте «из первых рук» (en)
2. Короткое видео с простым объяснением инструмента от бизнес-аналитика + ссылка в описании к видео на их шаблон юзкейсов (en)
3. Короткое видео о юзкейсах для новичков от UX/UI дизайнер в Siemens (ru)
4. Статья от Usability.gov с краткой информации о юзкейсах и примером их заполнения (en)
5. Статья от системного аналитика, где подробно рассказывается о методологии и опыте ее применения в QIWI (ru)
-
Что такое диаграмма вариантов использования?
Диаграммы вариантов использования UML являются основной формой требований к системе/программному обеспечению для новых разрабатываемых программ. Цель диаграммы прецедентов — визуализировать, что система должна делать (что); на данном этапе не рассматривает, как (как) это сделать.
Как только вариант использования определен, его можно представить в текстовом и визуальном представлении (т. е. в виде диаграммы вариантов). Ключевой концепцией моделирования вариантов использования является то, что оно помогает нам проектировать систему с точки зрения конечного пользователя. Это эффективный способ сообщить о поведении системы с точки зрения пользователя, указав все внешне видимые варианты поведения системы.
Другими словами, использование системы необходимо рассматривать извне, то есть систему следует рассматривать не изнутри, а с более высокого уровня, чтобы определить функциональность, которую система должна предоставлять внешним акторам.
Назначение диаграмм вариантов использования
Диаграммы вариантов использования обычно разрабатываются на ранних стадиях разработки, и люди часто используют моделирование вариантов использования для следующих целей.
- Укажите контекст системы
- Зафиксируйте требования системы
- Проверить архитектуру системы
- Управляйте внедрением и создавайте тестовые примеры
- Совместная разработка аналитиками, экспертами в предметной области и целевыми конечными пользователями
Стандартная форма диаграммы прецедентов определена в унифицированном языке моделирования, как показано в примере диаграммы прецедентов ниже.
ИЗМЕНИТЬ ЭТОТ ПРИМЕР ДИАГРАММЫ ВАРИАНТОВ ИСПОЛЬЗОВАНИЯ
Элементы диаграммы вариантов использования
Актеры
Каждый вариант использования будет иметь как минимум одного действующего лица, под которым можно понимать как минимум одного участника (роль), который не обязательно является человеком, но может быть другой системой или устройством. Актер может взаимодействовать с более чем одним вариантом использования, а вариант использования может взаимодействовать с более чем одним актером.
Действующие лица не обязательно являются людьми, т.е. пользователями, но на самом деле они могут быть и не людьми, т.е. системами или временем.
Чаще всего пользователями являются люди, вовлеченные в диаграмму вариантов использования, такие как клиенты, сотрудники, руководители и т. д.
Люди против нечеловеческих актеров
Время от времени на систему воздействуют различные события для выполнения определенных функций в той или иной ситуации. Например, при прохождении аудита система заранее отправляет письмо, чтобы уведомить людей; так отправка письма осуществляется системой автоматически? Этот вариант использования на самом деле запускается по времени, тогда действующим лицом является Таймер; например, этот вариант использования можно рассматривать как «автоматически отправлять письмо в 5:00 каждый день», тогда актор, который запускает это событие — отправку письма — не система, а на самом деле актор-таймер
Первичные и второстепенные актеры
A primary actor is an actor that uses the system to achieve a goal. Use cases document the interactions between the system and actors to achieve the goals of the primary actor. Secondary actors are the actors that the system needs to assist in order to achieve the goals of the primary actor.
- Actors may be primary or secondary. Primary actors initiate interactions with the system.
- Secondary actors are typically called upon by the system for help and a secondary actor never initiates the use case.
Note that: The symbol for an actor does not differentiate between a primary actor and a secondary actor; the difference must be inferred from the use case descriptions (also called use case narratives).
For Example:
A bank loan officer wants to review a customer’s loan application, and part of the process involves a real-time credit rating check.
ИЗМЕНИТЬ ЭТОТ ПРИМЕР ДИАГРАММЫ ВАРИАНТОВ ИСПОЛЬЗОВАНИЯ
- Используйте имя дела. Рассмотреть заявку на кредит
- Главный актер. Кредитный специалист
- Второстепенный актер. Система кредитного рейтинга
Как определить актеров?
Поскольку действующее лицо не обязательно является человеком, а может быть внешней системой, устройством или таймером, мы находим более конкретное действующее лицо, задавая следующие вопросы.
- Кто будет использовать систему после ее разработки?
- От кого или от каких других систем система должна будет получать данные?
- Для кого или для каких других систем система будет предоставлять данные?
- С какими другими системами будет связана система?
- Кто будет поддерживать и администрировать систему?
Эти вопросы помогают нам абстрагироваться от действующих лиц системы. Используя банкоматы в качестве примера, ответы на эти вопросы позволяют нам найти больше действующих лиц, т.е.
- Оператор несет ответственность за техническое обслуживание и управление системой банкоматов.
- Банкоматы также должны взаимодействовать с внутренними серверами для получения информации об учетных записях пользователей.
Вариант использования
Вариант использования представляет собой функциональность (обычно требование), которая, как ожидается, будет реализована системой. Детали варианта использования, кроме его уникального имени, визуально не представлены на диаграмме; эти детали приведены в описательной части (текстовом описании) варианта использования.
Вариант использования — это список действий или шагов события, которые обычно определяют взаимодействие между ролями действующих лиц и системой для достижения цели. Сценарии использования — полезный метод для выявления, уточнения и организации системных требований. Вариант использования состоит из набора последовательностей возможных взаимодействий между системой и пользователем, которые определяют функциональные возможности, которые должны быть достигнуты, и решения для любых ошибок, которые могут возникнуть.
Как определить варианты использования?
Как только мы найдем акторов, мы можем определить варианты использования системы на основе акторов, в основном глядя на то, какие услуги нужны каждому актору от системы или как акторы используют систему. Идентификацию вариантов использования можно начать со следующих вопросов (для каждого участника).
- Почему актеры используют систему?
- Создает ли участник, изменяет, удаляет, получает доступ и хранит данные в системе? Если да, то как актор выполняет эти операции?
- Уведомляет ли актор систему об определенных внешних событиях?
- Уведомляет ли система актора об определенных внутренних событиях?
Собрав все вышесказанное, диаграмму вариантов использования системы банкоматов можно представить следующим образом.
Вариант использования представлен многоточием чего-то статического или динамического, задачи или системы.
Системная граница
Границы системы описывают систему, группируя варианты использования в прямоугольные границы, а границы системы в Visual Paradigm обеспечивают поведение ограничения вариантов использования.
Актеры — это роли (актеры-люди или актеры, не являющиеся людьми), которые взаимодействуют с разрабатываемой системой. Следовательно, акторы должны быть размещены за пределами системных границ и взаимодействовать с вариантами использования, размещенными внутри системных границ.
Обратите внимание, что:
Актер определяется границами системы. Если граница системы, которую мы хотим определить, ограничена самим банкоматом, то внутренний сервер является внешней системой и может быть абстрагирован как действующее лицо.
Если граница системы, которую мы хотим определить, распространяется на всю банковскую систему, где и банкоматы, и внутренние серверы являются частью всей банковской системы, то внутренний сервер больше не абстрагируется как действующее лицо.
Отношение
Узнав об этих трех ключевых символах, продолжайте изучать отношения и рисовать диаграммы вариантов использования. Рисуется прямая связь между участником и пользовательским вариантом, и эта связь используется в виде линии без стрелок, указывающей на двустороннюю связь, называемую линией связи.
Вариант использования можно разбить на несколько вариантов использования, которые связаны отношениями <<включить>>, <<расширить>> или <<обобщить>> (описано далее в этом посте).
Связь канала связи
Это представляет собой двустороннюю связь между действующим лицом и вариантом использования и, следовательно, является бинарным отношением.
ИЗМЕНИТЬ ЭТОТ ПРИМЕР ДИАГРАММЫ ВАРИАНТОВ ИСПОЛЬЗОВАНИЯ
<<Включить>> Связь
Отношение включения означает, что вариант использования будет включать в себя другие варианты использования. Цель Include Relationship состоит в том, чтобы использовать Include Relationship, чтобы уменьшить повторение повторного описания одного и того же варианта использования. Если во многих прецедентах используется одна и та же функция части, то функция может быть выделена, а другие прецеденты могут быть включены в прецедент.
Например, библиотекарю необходимо прочитать код для записи одолженной книги, когда книга выдается, а также необходимо прочитать код для записи возвращенной книги, когда книга возвращается, поскольку чтение кода является повторяющейся частью действия. , его можно сделать отдельным вариантом использования, и пусть заимствованная книга и возвращенная книга включают этот вариант.
ИЗМЕНИТЬ ЭТОТ ПРИМЕР ДИАГРАММЫ ВАРИАНТОВ ИСПОЛЬЗОВАНИЯ
Если вариант использования A включает в себя другой вариант использования B, то реализация A требует реализации B для выполнения своей задачи. Однако B не зависит от самого себя. То есть B не нужно ничего знать об A. B также может быть включен в любой другой вариант использования.
<<Расширить>> отношения
Если вариант использования B расширяет другой вариант использования A, то реализация A может условно включать реализацию B для выполнения своей задачи. То есть в некоторых случаях А может выполнить свою задачу без В. Однако в зависимости от описанных условий А может потребовать В. В этом случае В зависит от В. Однако в зависимости от описанных условий А может потребовать В В этом случае В зависит от А и не может существовать отдельно. По этой причине B нельзя распространить более чем на один вариант использования. Описание варианта использования A будет включать этапы выполнения, требуемые от B; эта точка называется точкой расширения.
ИЗМЕНИТЬ ЭТОТ ПРИМЕР ДИАГРАММЫ ВАРИАНТОВ ИСПОЛЬЗОВАНИЯ
Давайте рассмотрим еще один пример, когда система автоматически заказывает товары при отсутствии запасов, чтобы менеджеру не приходилось выполнять заказ напрямую. См. диаграмму вариантов использования ниже:
ИЗМЕНИТЬ ЭТОТ ПРИМЕР ДИАГРАММЫ ВАРИАНТОВ ИСПОЛЬЗОВАНИЯ
Отношение обобщения
Обобщенное отношение похоже на обобщенное отношение объектно-ориентированного языка на диаграммах классов и может применяться к обобщению ролей (акторов) и вариантов использования.
Например, в системе бронирования есть два типа методов бронирования: «забронировать билет по телефону» и «забронировать билет через Интернет», а также базовый вариант использования «забронировать билет», поэтому вы можете использовать обобщение для формирования случая, и добавьте <<essential>> к родительскому варианту использования (бронирование), чтобы указать обобщенную связь.
ИЗМЕНИТЬ ЭТОТ ПРИМЕР ДИАГРАММЫ ВАРИАНТОВ ИСПОЛЬЗОВАНИЯ
Обсудите отношения в диаграмме вариантов использования
- На общей диаграмме вариантов использования мы представляем только отношения между действующими лицами и вариантами использования, т. е. коммуникационные связи между ними.
- Кроме того, мы также можем описать обобщение между участниками и действующими лицами, а также отношения включения, расширения и обобщения между вариантами использования.
- Мы используем эти отношения для адаптации существующей модели вариантов использования и извлечения некоторой общей информации для повторного использования, что упрощает поддержку модели вариантов использования.
- Однако мы должны быть осторожны при выборе этих отношений в приложении. Как правило, эти отношения увеличивают количество вариантов использования и отношений, тем самым увеличивая сложность модели вариантов использования.
- Кроме того, модель вариантов использования обычно корректируется после ее завершения, поэтому нет необходимости спешить с абстрагированием отношений между вариантами использования на ранней стадии моделирования вариантов использования.
Вариант использования — поток событий
Диаграмма вариантов использования дает нам общее представление о функциональности системы, мы можем знать, какие участники будут взаимодействовать с системой и какие услуги каждый участник должен получить от системы.
Вариант использования описывает диалог между субъектами и системой, но детали этого диалога не представлены на диаграмме вариантов использования, поэтому для каждого варианта использования мы можем описать детали этого диалога в терминах потока событий.
Сценарии использования и поток событий – снятие денег через банкомат
Например, кейс «Снятие денег» в банкомате можно представить потоком событий следующим образом:
Обычный сценарий – вывод средств – основной ход событий:
- Пользователь вставляет кредитную карту
- Введите PIN-код
- Введите сумму вывода
- Снимает наличные
- Выйдите из системы и получите кредитную карту
Но это описывает только обычный сценарий использования вывода средств. Как реальная система банкоматов, мы также должны учитывать различные другие сценарии, которые могут возникнуть, такие как:
- недействительные кредитные карты,
- неправильные пароли,
- недостаточный остаток денежных средств на счету пользователя и т. д.
Все эти возможные ситуации (как нормальные, так и нештатные) называются сценариями варианта использования, а сценарии также называются экземплярами варианта использования. Сценарии также называют экземплярами вариантов использования. Среди различных сценариев варианта использования наиболее распространенный сценарий описывается базовым процессом, тогда как другие сценарии описываются альтернативными процессами.
Альтернативные сценарии
Для варианта использования «Снятие средств» в системе банкомата мы можем получить несколько альтернативных процессов следующим образом.
Снятие – альтернативные процессы событий.
- Альтернативный сценарий I: Пользователь может отказаться на любом шаге основного процесса и перейти к шагу 5 основного процесса.
- Альтернативный процесс II: на шаге 1 основного процесса пользователь вставляет недействительную кредитную карту, система отображает ошибку и закрывает кредитную карту, и вариант использования заканчивается.
- Альтернативный процесс III: на шаге 2 основного процесса пользователь вводит неверный пароль, система отображает ошибку и предлагает пользователю повторно ввести пароль и вернуться к шагу 2 основного процесса; после трех неправильных вводов пароля кредитная карта конфискуется системой, и вариант использования заканчивается.
- …
Комбинируя базовый сценарий и альтернативные сценарии, можно четко описать все различные ситуации, которые могут возникнуть в прецеденте. При описании потока событий варианта использования мы хотим максимально подробно описать все возможные сценарии, чтобы обеспечить полноту требований.
Модель вариантов использования и диаграммы вариантов использования
Важно избежать неправильного представления о том, что диаграмма вариантов использования, состоящая из действующих лиц и вариантов использования, является моделью вариантов использования, потому что диаграмма вариантов использования — это просто визуальное представление услуг, которые может предоставить система, дающая нам общее представление о функциональность системы.
Модель вариантов использования состоит из диаграммы вариантов использования и подробного описания каждого варианта использования, спецификации варианта использования, которая предоставляется в виде шаблона в RUP.
Краткое описание
Краткое описание роли и цели варианта использования.Поток событий
Поток событий должен представлять все сценарии, включая основные и альтернативные сценарии.Сценарии вариантов использования
Включают сценарии успеха и сценарии отказа, а сценарии в основном представляют собой комбинацию основных и альтернативных потоков.Специальные требования
Опишите нефункциональные требования (включая производительность, надежность, доступность, масштабируемость и т. д.) и проектные ограничения (операционная система, средства разработки и т. д.), связанные с вариантом использования.Предварительное условие
Состояние, в котором должна находиться система перед выполнением варианта использования.Постусловия
Набор состояний, в которых может находиться система после выполнения варианта использования.Спецификация варианта использования — это, по сути, текстовое представление с возможностью использования диаграмм состояний, диаграмм действий или диаграмм последовательности, чтобы помочь более четко описать поток событий. Любое графическое представление пользовательских интерфейсов и процессов или другая графика, например каркасы, могут быть присоединены к варианту использования, если они помогают улучшить ясность представления.
Например:
- диаграммы деятельности полезны для описания сложных процессов принятия решений,
- диаграммы перехода состояний полезны для описания поведения системы, связанного с состоянием, и
- диаграммы последовательности подходят для описания обмена сообщениями на основе времени.
Используйте инструменты кейса
Онлайн-версия
Бесплатная версия бесплатного инструмента для рисования Visual Paradigm Online (VP Online) поддерживает UML, ERD и организационные диаграммы. Вы можете быстро нарисовать диаграммы вариантов использования с помощью интуитивно понятного редактора чертежей UML. В этом бесплатном инструменте UML нет рекламы, нет ограниченного периода доступа и нет ограничений, таких как количество диаграмм, количество фигур и т. д. Рисуйте UML свободно. Рисуйте UML свободно. вам принадлежат диаграммы, которые вы создаете для личных и некоммерческих целей.
Настольная версия
Версия Visual Paradigm Community Edition , доступная с 2004 года, предоставляет бесплатное программное обеспечение UML только для некоммерческих целей, поддерживая пользователей, которые делают первые шаги в моделировании UML, а также тех, кому требуется бесплатное кроссплатформенное программное обеспечение для моделирования UML для личное использование, например применение UML в студенческих проектах.
использованная литература
- Что такое диаграмма вариантов использования?
- Типы актеров в модели вариантов использования
- Определите требования пользователя с помощью диаграмм вариантов использования
- Что такое спецификация варианта использования?
- История пользователя и вариант использования для гибкой разработки программного обеспечения
- Используйте подход, основанный на прецедентах, для гибкой разработки
UML-ресурсы
- Что такое УМЛ?
- Почему UML-моделирование?
- Обзор 14 типов диаграмм UML
- Что такое юзкейс
- Из чего состоит
- Как написать
- Пример
- Диаграммы
- Польза для команды
Что такое юзкейс
Use case (также юзкейс, сценарий использования) – это сценарий взаимодействия пользователя (или пользователей) с программным продуктом для достижения конкретной цели.
Юзкейсы содержат следующие сведения:
- кто использует сайт или приложение
- что пользователь хочет сделать
- цель пользователя
- шаги, которые делает пользователь, чтобы совершить определенное действие
- описание того, как сайт или приложение реагируют на действия пользователя.
Юзкейсы не содержат детали реализации, а также описания пользовательского интерфейса или экранов.
В общем, в юзкейсе описывается не каким образом программа делает что-либо, а что именно она делает. Именно этого подхода и нужно придерживаться, создавая юзкейсы.
В отличие от user story, которая излагается от имени какого-то конкретного пользователя, в use case может быть описано взаимодействие (с определенной целью) нескольких участников. Например:
- покупка товара в магазине (Покупатель – Продавец);
- отправка письма по электронной почте (Отправитель – Почтовый клиент);
- запрос страницы браузером (браузер – веб-сервер).
Элементы use case
Юзкейсы могут содержать следующие элементы (их количество зависит от сложности сценария):
- Актор (actor) — тот, кто использует систему. Если взять за пример онлайн-магазин, там может быть несколько акторов: покупатели, продавцы, компании, занимающиеся доставкой, компании, проводящие платежи.
- Стейкхолдер (stakeholder) — тот, кто заинтересован в определенном поведении системы. Зачастую это не конечный пользователь, а кто-то, получающий выгоду от функционирования системы. В случае с онлайн-магазином это может быть партнер — платежная платформа.
- Первичное действующее лицо (primary actor) — человек или система, чьи цели достигаются при помощи нашего продукта. В онлайн-магазине это может быть основной дистрибьютор, чьи товары продаются на этой онлайн-платформе.
- Предусловия и постусловия — что должно быть в наличии или должно произойти до и после запуска сценария использования.
- Триггеры — события, запускающие юзкейс.
- Успешный сценарий — юзкейс, при котором все идет по плану, без ошибок и неожиданностей.
- Альтернативные пути — вариации основного успешного сценария на случай, если что-то пойдет не так на уровне системы.
Как написать use case?
Шаги в юзкейсе описываются максимально понятно. Что касается самих шагов, они могут быть следующими:
- Определите, кто будет использовать сайт.
- Выберите одного из этих пользователей.
- Определите, что этот пользователь хочет делать на сайте. Все, что пользователь делает на сайте, становится юзкейсом.
- Для каждого use case определите нормальный ход событий.
- Опишите основной путь пользователя: что именно делает пользователь и каков ожидаемый ответ системы.
- Далее рассмотрите альтернативные варианты развития событий и добавьте их, чтобы «расширить» use case.
- Повторите шаги 2-6 для всех остальных пользователей.
Пример use case
В этом юзкейсе изложен сценарий входа пользователя в школьную систему.
Название use case | Login |
Описание use case | Пользователь входит в систему, чтобы получить доступ к ее функционалу. |
Акторы | Родители, Ученики, Учитель, Админ |
Предусловия | Система должна быть подсоединена к сети |
Постусловия | После успешного входа пользователю отсылается уведомление на mail id |
Основные сценарии | Номер | Шаги |
Акторы/пользователи | 1 | Ввод username Ввод пароля |
2 | Проверить имя пользователя и пароль | |
3 | Разрешить на вход в систему | |
Расширения | 1a | Неверное имя пользователя Система выбрасывает сообщение об ошибке |
2b | Неверный пароль Система выбрасывает сообщение об ошибке |
|
3c | Неверный пароль введен 4 раза Приложение закрывается |
Юзкейс-диаграммы
Для визуализации юзкейсов используют диаграммы. В них система обозначается прямоугольником, use case — овалом, актор — схематическим человечком.
Пример диаграммы для юзкейсов входа в школьную систему:
Зачем нужны use case?
Давайте рассмотрим, в чем ценность юзкейсов для участников проекта разработки ПО.
- Заказчики
В юзкейсе отражается конечная бизнес-ценность, понятная заказчику. Реализация сценария использования в системе очевидна даже для нетехнического специалиста. Наличие готового use case позволяет заказчику своевременно дать старт дальнейшей работе тестировщиков и разработчиков.
- Разработчики
В сценарии использования указываются основной и альтернативные потоки событий. Вся информация в нем подается максимально структурированно и понятно, в привязке к конечному результату. Это удобно для понимания запутанных требований. Если сценарий поведения пользователя в системе сложный, use case просто необходим.
- Тестировщики
Юзкейсы — отличная основа для формирования тест-кейсов. Это, по сути, пригодные для тестирования требования с понятной целью и путями ее достижения. Тестирование по сценариям использования (use case testing) позволяет обнаружить в приложении недостатки, которые сложно найти, например, при юнит-тестировании.
NB: For the purpose of this question, alternate scenarios are scenarios that aside from the main scenario also lead to the completion of the user goal; exceptional scenario are scenarios that do not lead to the completion of the user goal.
I’ve been having a conversation with my professor regarding one of his statements in class. He claims that «extend» should be used to model use cases that derives from exceptional scenarios. As an example:
(UC1: Publish blog post)
^
-- <<extend>> -- (UC2: Error, empty blog post)
At this point given the definition of use case:
A use case is a set of scenarios (sequences of steps) that aim at accomplishing a end-goal for an user (actor).
I’m a little confused. If the error is a use case, what end-goal is it aiming at accomplishing? Does a user access the system to see the error message as an end-goal?
I’ve also went ahead and read about «extend» on the internet and I can’t seem to find an example where the extension use case is an actual use case according to that definition. For example here we are given:
(UC1: Deposit funds)
^
-- <<extend>> -- (UC2: Calculate bonus)
Again, what user end-goal is «Calculate bonus» trying to achieve? It almost seems as by definition, something that is only triggered by another case in certain situations cannot be considered a «use case» because it’s not an end-goal.
Where am I wrong?
NB: For the purpose of this question, alternate scenarios are scenarios that aside from the main scenario also lead to the completion of the user goal; exceptional scenario are scenarios that do not lead to the completion of the user goal.
I’ve been having a conversation with my professor regarding one of his statements in class. He claims that «extend» should be used to model use cases that derives from exceptional scenarios. As an example:
(UC1: Publish blog post)
^
-- <<extend>> -- (UC2: Error, empty blog post)
At this point given the definition of use case:
A use case is a set of scenarios (sequences of steps) that aim at accomplishing a end-goal for an user (actor).
I’m a little confused. If the error is a use case, what end-goal is it aiming at accomplishing? Does a user access the system to see the error message as an end-goal?
I’ve also went ahead and read about «extend» on the internet and I can’t seem to find an example where the extension use case is an actual use case according to that definition. For example here we are given:
(UC1: Deposit funds)
^
-- <<extend>> -- (UC2: Calculate bonus)
Again, what user end-goal is «Calculate bonus» trying to achieve? It almost seems as by definition, something that is only triggered by another case in certain situations cannot be considered a «use case» because it’s not an end-goal.
Where am I wrong?
Когда какая-либо IT-компания начинает разработку программного продукта, ей приходится задумываться о том, как быстрее и проще начать реализацию проекта и создать прототип, с помощью которого можно передать все функциональные возможности ПП. Что такое Use Case, для чего он нужен, чем он может помочь в разработке — расскажет наша статья.
Что такое Use Case
Use Case — это сценарный план взаимодействия пользователя с программным продуктом, в котором четко прописаны шаги для достижения того или иного результата. Последовательность действий, при этом, может быть расписана не для одного, а для нескольких юзеров.
В юзеркейсах для программных продуктов прописываются разные манипуляции. Это может быть покупка товаров через мобильное приложение, отправка данных, рассылка электронных писем и так далее.
Главной задачей юзеркейса является улучшение коммуникации среди членов команды при разработке программы или мобильного приложения. Пишутся эти кейсы на этапах проектирования и при планировании внедрения каких-либо функций.
Вообще, отвечать за составление юзеркейсов должны системные аналитики, имеющие опыт в ведении переговоров с заказчиками и проведении анализа ЦА. Но так как у многих компаний бюджет не всегда позволяет нанимать для этого сторонних специалистов, разработкой Use Case могут заниматься тестировщики, дизайнеры, разработчики ПП и даже продакт-менеджеры.
В каких ситуациях может помочь Use Case
Грамотно составленный юзеркейс может помочь в тех случаях, когда:
- при проведении подготовительных работ разработчики не могут правильно составить ТЗ;
- после долгих обсуждений функциональных возможностей команда отклонилась от первоначальной идеи продукта;
- команда разработчиков неправильно поняла начальный сценарий взаимодействия юзера и ПП;
- команда разработчика неправильно внедрила ту или иную функцию;
- в процессе тестирования программы появляется много непредвиденных ошибок;
- к команде подключились новые специалисты, которых нужно в кратчайшие сроки посвятить в курс дела.
Также Use Case незаменим в тех случаях, когда один и тот же кейс по-своему реализован в разных местах, тем самым затягивая процесс разработки ПП.
В чем польза юзеркейса
Качественно составленный Use Case может решать разные задачи. Например:
- облегчение коммуникации между разнопрофильными членами команды (дизайнеры, тестировщики, разработчики, менеджеры, аналитики);
- фиксирование принятых решений, что позволяет в дальнейшем не сбиваться с курса;
- быстрое возвращение к заданному сценарию с целью проверки его корректности на разных этапах разработки;
- упрощение порядка передачи информации между членами команды;
- определение самых важных аспектов сценария взаимодействия.
Use Case играет важную роль, когда необходимо подготовить прототип ПП, который покажет особенности и преимущества проекта.
Из каких элементов состоит Use Case
В зависимости от сложности сценария, юзеркейсы могут содержать порядок действий следующих лиц:
- Actor — человек, который пользуется созданной системой. В качестве примера можно привести какой-нибудь интернет-магазин, где в качестве actor выступают продавцы, покупатели, поставщики и все те, кто взаимодействует с этим интернет-магазином.
- Primary actor — это человек, у которого получается достигнуть поставленных целей с помощью созданного программного продукта. Если вернуться к тому же интернет-магазину, то primary actor в нем может быть производитель вещей, у которого получается реализовывать эти вещи с помощью функционала онлайн-площадки.
- Stakeholder — человек, который заинтересован в том, чтобы созданы ПП выполнял те или иные действия. В интернет-магазине это может быть какой-нибудь партнер, получающий доход от приведенных покупателей, или подключенная к магазину платежная платформа, через которую совершаются онлайн-платежи.
Также к элементам юзеркейса относятся:
Арбитраж трафика на крипту [2022] — ОПРОС ЭКСПЕРТОВ
- понятный заголовок, содержащий конечный результат Use Case;
- описание последовательности действий;
- результат, к которому должен привести юзеркейс;
- предусловия — это то, что должно произойти до или после запуска кейса;
- триггеры, влияющие на запуск кейса.
А еще в любом Use Case должны быть прописаны альтернативные пути — события, к которым прибегают в том случае, если кейс не сработал.
Какими должен качественный быть Use Case
Высокое качество юзеркейса определяют следующие критерии:
- Правильная детализация. При составлении Use Case нет смысла описывать каждый шаг пользователей и состояние элементов ПП в этот момент. Главная задача юзеркейса — всего лишь дать общую картину.
- Простота изложения. Чтобы содержимое юзеркейса было понятным даже новым членам команды, его необходимо писать максимально простым языком. Не стоит использовать для Use Case сложные термины и вставки кода.
- Единый стиль. Старайтесь использовать для всех юзеркейсов один и тот же шаблон. Это поможет сэкономить время на изучении ПП.
- Важен контекст. В каждом юзеркейсе должны быть уточнения по поводу тех или иных действий. Так разработчики смогут разобраться в том, какая задача перед ними стоит.
- Целенаправленность. Не стоит использовать юзеркейса для того, чтобы описать весь путь пользователя. Лучше представить конкретные шаги (регистрация, покупка, отправка заявки и так далее).
Когда сценарий будет обновляться, не стоит забывать о своевременном внесении изменений в юзеркейс.
Какую пользу несет Use Case для определенных специалистов в команде
Для каждого из участников команды юзеркейс несет свою ценность. Например, для заказчика Use Case полезен тем, что на простой языке отображает конечную бизнес-ценность. Как правило, сценарий взаимодействия составляется таким образом, чтобы даже далекие от программной разработки пользователи могли понять, что написано в кейсе. Чем проще для заказчика будет составлен юзеркейс, тем быстрее он с ним ознакомиться и даст добро на продолжение разработки.
Для разработчика же ценность заключается в другом. В первую очередь речь идет о структурированных блоках информации, что упрощает создание ПП. Особенно это касается сложных проектов с жесткими требованиями. Также структурированная информация привязывается к конечному результату, благодаря чему разработки гораздо проще понять, что должно получиться в итоге.
Польза в юзеркейсах есть и для разработчиков. Во-первых, благодаря Use Case они могут тестировать программные продукты по заранее заданному сценарию. Это экономит время и избавляет от необходимости искать способы проверки на ошибки. Во-вторых, грамотно составленный кейс помогает находить в программе минусы, которые вряд ли удастся найти с помощь unit-тестирования.
Как составить Use Case
Как говорилось ранее, составлять юзеркейсы нужно на этапах проектирования ПП. Также кейс пересматривается в тот момент, когда команда начинает внедрять новые или улучшать уже имеющиеся фичи. При этом писать юзеркейсы стоит только после того, как будет составлен путь пользователя.
Чтобы составить юзерйкейс, необходимо выполнить следующие действия:
- В первую очередь определяем, какие пользователи будут работать с программным продуктом. Помочь в этом может обычный анализ рынка и ЦА.
- Выявляем определенную группу пользователей, которые будут работать с ПП.
- Рисуем портрет группы пользователей и приблизительно определяем, что они будут делать разрабатываемой программе. Каждое действие в рамках ПП — потенциальный Use Case.
- Определяем последовательность действий для каждого юзеркейса.
- Приблизительно описываем основной путь пользователя.
- Прогнозируем ответ системы на действия пользователя.
- Разрабатываем альтернативные пути для расширения юзеркейса.
- Повторяем перечисленные шаги для каждой группы пользователей.
Есть пара советов, которые помогут в составлении юзеркейсов. Во-первых, для экономии времени следует разработать шаблон. Такой подход позволит выработать единый стиль и экономить время при разработке других кейсов.
Во-вторых, если идет работа над Use Case под узкоспециализированный продукт, тогда необходимо разработать словарь с терминами. Также это может помочь в том случае, когда члены команды часто используются определенные термины, требующие расшифровки.
Чтобы читатели могли ознакомиться с приблизительным видом кейсов, мы решили разобрать несколько примеров.
Пример 1: регистрация на сайте
Результат кейса: пользователь создает аккаунт с личным кабинетом.
Номер шага | Действующее лицо | Действие |
1 | Пользователь | Пользователь нажимает на кнопку регистрации |
2 | Система | Открывает форма регистрации |
3 | Пользователь | Пользователь заполняет форма, указывает данные, подтверждает регистрацию |
4 | Система | Идет проверка корректности заполнения, пользователь вносится в базу данных, на почту отправляется письмо со ссылкой для активации акк |
5 | Пользователь | Пользователь открывает письмо, переходит по ссылке |
6 | Система | Система активирует аккаунт, высылает инструкцию по работе с сервисом |
Это из самых простых кейсов. Как правило, большая часть юзеркейсов имеют более сложно схему взаимодействия.
Пример 2: регистрация в интернет-магазине по сложной схеме
- цель: зарегистрироваться в интернет-магазине;
- действующее лицо: незарегистрированный пользователь;
- триггер: пользователь увидел рекламу интернет-магазина и решил зарегистрироваться;
- результат: у пользователя появляется аккаунт с бонусной системой.
Шаги юзеркейса выглядят следующим образом:
- Пользователь нажимает на кнопку регистрации.
- Система открывает форму регистрации, запрашивает контактные данные и платежные реквизиты.
- Пользователь заполняет поля, отправляет на проверку.
- Система проверяет инфу на корректность, вносит пользователя в базу, отправляет письмо со ссылкой активации.
- Пользователь открывает письмо, переходит по ссылке.
- Система активирует аккаунт.
Также может указываться переход к юзеркейсу. Например, с главной страницы.
Пример 3: кейс по взаимодействию с сайтом вуза на примере диаграммы
Некоторым специалистам проще делать юзеркейсы в виде диаграммы. Они удобны и практичны, однако в них нельзя отследить последовательность действий. Один из примеров – диаграмма юзеркейса, в котором прописаны шаги разных групп пользователей в рамках сайта ВУЗа.
Как видно на рисунке, студенты могут просматривать темы и записываться на курсовые проекты. Руководители могут просматривать уже имеющиеся и вносить новые темы. Система же отвечает за предоставление информации и внесения указанных сведений в базу данных.
Эксперты отвечают
ССергей Галоген
Что такое сценарий Use Case?
Сценарий или спецификация ВИ (use case scenario or specification) – тестовое формальное описание последовательности действий, которые происходят внутри ВИ для достижения некой цели актера.
ЮЮрий Булуй
Можно ли считать юзеркейс фукнцией?
ВИ – это не функция, это некая последовательность действий, которая приносит пользу для основного актера, инициирующего данный ВИ. ВИ – это скорее цель Пользователя, чем отдельная функция. ВИ теоретически может быть разбит на несколько функций, и как правило не является одной лишь функцией.
Вывод
Use Case — это инструмент, созданный для упрощения взаимодействия с разрабатываемым ПП. Перед созданием этого инструмента стоит тщательно изучить все материалы, заранее подготовить список разделов и обсудить все шаги с членами команды. Если юзеркейс будет составлен правильно, появится возможность не только наладить коммуникации, но и упростить процессе ведения технической и пользовательской документации.
Приходилось сталкиваться с Use case?
1 голос
Да — 100%
Нет — 0%