Национальный исследовательский ядерный университет «МИФИ»
Опубликован: 28.11.2007 | Доступ: свободный | Студентов: 5153 / 804 | Оценка: 4.53 / 3.65 | Длительность: 22:18:00
ISBN: 978-5-94774-825-3
Специальности: Программист, Тестировщик
Лекция 13:

Системное тестирование

22.3. Системное тестирование, приемо-сдаточные и сертификационные испытания при разработке сертифицируемого программного обеспечения

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

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

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

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

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

Заявитель - это организация, подающая заявку в соответствующий сертифицирующий орган на получение сертификата (соответствия, качества, годности и т.п.) изделия.

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

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

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

В случае сертификации бортовой системы по стандарту DO-178B (или его аналогам КТ-178, JB-12 и т.п.) план дополнительно определяет уровень влияния отказа программной системы на безопасность полета (уровень отказобезопасности) по которому будет проводиться сертификация. Любые вопросы, которые возникают у сертифицирующего органа относительно содержания плана сертификационных испытаний, должны быть разрешены до начала самих испытаний.

Согласно требованиями DO-178B план сертификационных испытаний (план программных аспектов сертификации) должен включать:

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

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

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

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

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

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

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

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

Для программного обеспечения установка базиса производится по рассмотрению итогового заключения о программном обеспечении и свидетельств соответствия.

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

Сертификаты на программное обеспечение можно отнести к двум типам: сертификаты соответствия и сертификаты качества.

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

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

Илья Макаренко
Илья Макаренко

Добрый день.

Вопрос №1

Какова стоимость получения диплома о мини-МБА по данному курсу? Или ориентироваться на указанную на сайте?

Вопрос №2

Возможно ли начать обучение без потери результатов, не отправив документы на зачисление, а отправку выполнить позже?

Александр Медов
Александр Медов

Здравствуйте, какова полная сумма предоставленной услуги с печатью документа и отправкой по почте?