Определение основных исполнителей и задач

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

1. Кто запускает и выключает систему?

2. Кто является системным администратором?

3. Кто осуществляет управление пользователями и безопасностью?

4. Относится ли время к числу исполнителей, другими словами, должна ли система выполнять какие-либо действия в ответ на события времени?

5. Существует ли процесс мониторинга, благодаря которому система перезапускается в случае сбоя?

6. Кто контролирует деятельность и производительность системы?

7. Как выполняется обновление программного обеспечения?

8. Кто анализирует журналы регистрации? Можно ли обеспечить удаленный доступ к ним?

9. Могут ли в качестве исполнителей выступать внешние программы или автоматические системы?

10. Кого следует уведомлять при ошибках или сбоях системы?

После определения основных исполнителей необходимо провести анализ каждого из них для определения требований, которые они могут предъявить. Для решения этой задачи требуется задать для каждого исполнителя эти 10 вопросов (данные вопросы носят общий характер и должны быть пересмотрены в рамках предметной области проектируемой системы). На основе анализа данных вопросов для каждого исполнителя можно выявить задачи.

Составим перечень исполнителей и задач в виде таблицы.

Таблица

Основные исполнители и задачи

Исполнитель Задачи
Студент Регистрируется на экзамене Получает билет
Преподаватель Включает и выключает систему Уточняет участие студента в сдаче экзамена Анализирует информацию о вытянутых билетах Анализирует информацию о времени получения билетов
Ассистент (деканат) Формирует списки студентов
Система промежуточной оценки знаний Предоставляет информацию для выставления автоматической оценки за экзамен

 

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

Описание прецедентов

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

Таким образом, прецедент (use case)— это набор взаимосвязанных успешных и неудачных сценариев, описывающий использование системы исполнителем для решения одной из задач. Например, рассмотрим свободный формат прецедента, включающего некоторые альтернативные сценарии.

Пояснения к полям:

Рамки (границы системы): отделяют систему от всего остального мира.

Уровень: «Задача, определенная пользователем» или «Нефункциональное требование» (возникает только тогда, когда есть сложное нефункциональное требование, которое надо описывать отдельным прецедентом, встречается редко).

Основной исполнитель (главный актер): исполнитель, инициирующий прецедент.

В зависимости от сложности прецедента он может иметь или не иметь альтернативные потоки (расширения) и специальные требования.

Частота использования: Необходимо определить произвольные категории (например, всегда\часто\иногда\редко) и описать их в словаре.

В качестве примера рассмотрим развернутое описание прецедента Получение билета.