Сертификация програмного обеспечения

Автор работы: Пользователь скрыл имя, 26 Декабря 2013 в 20:11, курсовая работа

Краткое описание

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

Содержание

Введение…………………………………………………...……….……………….5
1 Основные понятиясертификации……………………..………...…………….…6
1.1 История развития сертификации……………….……….….………..…6
2. Понятия сертификация………………………….………..….……….…....7
1.3 Сертификация в системе УкрСЕПРО………….……….…….…….……...8
2 Программное обеспечение…………………………………….…….……………9
2.1 Механизм работы персонального компьютера…….………….……......9
2.2 Элементы программного обеспечения…………….………….………..11
2.3 Работа системного ПО…………………………….…………….……....12
2.4 Значение прикладного ПО……………………….……………..……….13
2.5 Инструментальное ПО………………………….……………….………16
3 Сертификация программного обеспечения…………………………….………19
3.1 Общие положения ……………………………………………….……...19
3.2 Проверка и тестирование программного обеспечения ……….……...20
3.3 Стандарты для сертификации программного обеспечения ….….…….22
3.4 Стандарты и нормативные докуметы, регламентирующие защищенность программного обеспечения.……………………………………...................24
3.5 Порядок проведения сертификации программного обеспечения..…...25
3.6 Перечень информации предоставляемой заявителем для прохождения процедуры сертификации……………………………………………………….…27
3.7 Требования к программному обеспечению……………………………28
3.8 Сертификационные испытания программных средств……………….30
3.9 Приемка и эксплуатация программного обеспечения………………...32
3.10 Организационные процессы жизненного цикла……………………..36
Заключение………………………………………………………………………….38
Перечень ссылок……………………………………………………………………39

Прикрепленные файлы: 1 файл

yo .docx

— 92.23 Кб (Скачать документ)

3.7 Требования к программному обеспечению

Анализ  требований к программному обеспечению предполагает определение следующих характеристик для каждого компонента ПО.

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

Требования  к ПО оцениваются исходя из критериев  соответствия требованиям к системе, реализуемости и возможности  проверки при тестировании.

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

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

Кодирование и тестирование ПО охватывает задачи: 
      · - разработку и документирование каждого  компонента ПО и базы данных а также  совокупности тестовых процедур и данных для их тестирования; 
      - · тестирование каждого компонента ПО и базы данных на соответствие предъявляемых к ним требованиям. Результаты тестирования компонентов должны быть документированы;  
      - обновление (при необходимости) пользовательской документации; 
      - обновление плана интеграции ПО. 

3.8 Сертификационные испытания программных средств

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

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

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

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

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

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

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

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

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

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

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

3.9 Приемка и эксплуатация программного обеспечения

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

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

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

Управление конфигурацией  позволяет организовать, систематически учитывать и контролировать внесение изменений в ПО на всех стадиях его жизненного цикла. Общие принципы и рекомендации по управлению конфигурацией ПО отражены в проекте стандарта ISO/IEC 12207-2: 1995 “Information Technology - Software Life Cycle Processes. Part2. Configuration Management for Software”.

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

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

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

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

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

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

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

· - подготовительную работу; оценку управления проектом; техническую оценку.

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

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

Информация о работе Сертификация програмного обеспечения