Метрики качества программного обеспечения

Метрики программного обеспечения можно разделить на три категории:

  • Product metrics - Описывает характеристики продукта, такие как размер, сложность, конструктивные особенности, производительность и уровень качества.

  • Process metrics - Эти характеристики можно использовать для улучшения разработки и сопровождения программного обеспечения.

  • Project metrics- Эта метрика описывает характеристики и исполнение проекта. Примеры включают количество разработчиков программного обеспечения, структуру персонала на протяжении жизненного цикла программного обеспечения, стоимость, график и производительность.

Некоторые показатели относятся к нескольким категориям. Например, метрики качества в процессе проекта - это как метрики процесса, так и метрики проекта.

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

Метрики качества программного обеспечения можно разделить на три категории:

  • Показатели качества продукции
  • Метрики качества в процессе
  • Метрики качества обслуживания

Показатели качества продукции

Эти показатели включают следующее:

  • Среднее время до отказа
  • Плотность дефекта
  • Проблемы клиентов
  • Удовлетворенность клиентов

Среднее время до отказа

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

Плотность дефекта

Он измеряет дефекты относительно размера программного обеспечения, выраженного в строках кода или функциональных точках и т. Д., То есть он измеряет качество кода на единицу. Эта метрика используется во многих коммерческих программных системах.

Проблемы клиентов

Он измеряет проблемы, с которыми сталкиваются клиенты при использовании продукта. Он содержит взгляд клиента на проблемное пространство программного обеспечения, которое включает в себя проблемы, не связанные с дефектами, вместе с проблемами, связанными с дефектами.

Метрика проблем обычно выражается в виде Problems per User-Month (PUM).

PUM = Total Problems that customers reported (true defect and non-defect oriented 
problems) for a time period + Total number of license months of the software during 
the period

Где,

Number of license-month of the software = Number of install license of the software × 
Number of months in the calculation period

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

Удовлетворенность клиентов

Удовлетворенность клиентов часто измеряется данными опросов клиентов по пятибалльной шкале:

  • Очень доволен
  • Satisfied
  • Neutral
  • Dissatisfied
  • Очень недовольны

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

  • Процент полностью довольных клиентов
  • Процент довольных клиентов
  • Процент недовольных клиентов
  • Процент недовольных клиентов

Обычно используется этот процент удовлетворенности.

Метрики качества в процессе

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

  • Плотность дефектов при машинных испытаниях
  • Схема появления дефекта во время машинного тестирования
  • Схема устранения дефектов по фазам
  • Эффективность устранения дефектов

Плотность дефектов при машинных испытаниях

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

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

Схема появления дефекта во время машинного тестирования

Общая плотность дефектов во время тестирования предоставит только сводку дефектов. Схема поступления дефектов дает больше информации о различных уровнях качества в полевых условиях. Он включает в себя следующее -

  • Поступления или дефекты, зарегистрированные на этапе тестирования, по временным интервалам (например, неделям). Здесь всего не будет действительных дефектов.

  • Шаблон поступлений действительных дефектов, когда определение проблемы выполняется по сообщенным проблемам. Это истинный образец дефекта.

  • Образец невыполненной работы по дефектам. Этот показатель необходим, поскольку организации-разработчики не могут немедленно исследовать и исправить все обнаруженные проблемы. Это заявление о рабочей нагрузке, а также о качестве. Если в конце цикла разработки накопилось большое количество дефектов, а в систему еще предстоит интегрировать множество исправлений, это повлияет на стабильность системы (а значит, и на ее качество). Повторное тестирование (регрессионный тест) необходимо для обеспечения достижения целевого уровня качества продукции.

Схема устранения дефектов по фазам

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

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

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

Эффективность устранения дефектов

Это можно определить следующим образом -

$$ DRE = \ frac {Дефект \: удален \: во время \: a \: development \: phase} {Дефекты \: скрытый \: в \: \: продукте} \ times 100 \% $$

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

Метрики качества обслуживания

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

  • Исправить отставание и индекс управления невыполненными работами
  • Исправьте время отклика и исправьте отзывчивость
  • Процент просроченных исправлений
  • Исправить качество

Исправить отставание и индекс управления невыполненными работами

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

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

$$ BMI = \ frac {Количество \: из \: проблем \: закрыто \: в течение \: \: месяца} {Количество \: из \: проблем \: прибыло \: в течение \: \: месяца} \ раз 100 \% $$

Если ИМТ больше 100, это означает, что отставание сокращено. Если ИМТ меньше 100, значит отставание увеличивается.

Исправьте время отклика и исправьте отзывчивость

Метрика времени отклика исправления обычно рассчитывается как среднее время всех проблем от открытия до закрытия. Короткое время отклика на исправление приводит к удовлетворению запросов клиентов.

Важными элементами быстрого реагирования на исправления являются ожидания клиентов, согласованное время исправления и способность выполнить свои обязательства перед клиентом.

Процент просроченных исправлений

Он рассчитывается следующим образом -

$ Percent \: Delinquent \: Fixes = $

$ \ frac {Количество \: из \: исправлений \: которые \: превышены \: \: ответ \: время \: критерии \: по \: ceverity \: level} {Количество \: из \: исправлений \: доставлено \: in \: a \: указано \: time} \ times 100 \% $

Исправить качество

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

Дефектное исправление можно записать двумя способами: записать его в месяц, когда оно было обнаружено, или записать в месяц, когда исправление было доставлено. Первый - это оценка потребителя; второй - это измерение процесса. Разница между двумя датами - это латентный период дефектного исправления.

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