Что такое findslide.org?

FindSlide.org - это сайт презентаций, докладов, шаблонов в формате PowerPoint.


Для правообладателей

Обратная связь

Email: Нажмите что бы посмотреть 

Яндекс.Метрика

Презентация на тему Software Development Life Cycle and Methodologies (Topic 2)

Содержание

Cодержание:Разработка ПО.Верификация и валидация.V- model.Spiral model.Waterfall model.SCRUM.CANBAN.MSF.RUP. Жизненный цикл продукта.
Topic 2.  Software Development Life Cycle and Methodologies Cодержание:Разработка ПО.Верификация и валидация.V- model.Spiral model.Waterfall model.SCRUM.CANBAN.MSF.RUP. Жизненный цикл продукта. Разработка ПО — это род деятельности и процесс, направленный на создание и Методология — это система принципов, а также совокупность идей, понятий, методов, способов и Верификация — это обычно внутренний процесс управления качеством, обеспечивающий согласие с правилами, стандартами V-ModelОсновной принцип V-образной модели заключается в том, что детализация проекта возрастает при V-Model V-Model V-ModelV-модель обеспечивает поддержку в планировании и реализации проекта. В ходе проекта ставятся V-ModelДостоинства:• Пользователи V-Model участвуют в разработке и поддержке V-модели. • На старте Spiral Model Spiral Model Представляет собой процесс разработки программного обеспечения, сочетающий в себе как проектирование, Spiral ModelКаждый виток спирали соответствует созданию фрагмента или версии программного обеспечения, на Waterfall Model Waterfall Model Каскадная модель (waterfall model) —модель процесса разработки программного обеспечения, в которой процесс разработки выглядит Waterfall ModelМетодику «Каскадная модель» довольно часто критикуют за недостаточную гибкость и объявление SCRUMSCRUM — методология, предназначенная для небольших команд (3-9 человек). Весь проект делится SCRUM Team SCRUM Events KANBANKANBAN – гибкая методология разработки программного обеспечения, ориентированная на задачи. Основные правила:визуализация Во-первых, нужно сразу понять, что Канбан — это не конкретный процесс, а Канбан разработка отличается от SCRUM в первую очередь ориентацией на задачи. Если Проработка дизайна: этот и остальные столбцы до «Закончено» могут меняться, т.к. именно Весь Канбан можно описать всего тремя основными правилами: 1. Визуализируйте производство — MICROSOFT SOLUTIONS FRAMEWORK — методология разработки программного обеспечения, предложенная корпорацией Microsoft. MSF RATIONAL UNIFIED PROCESS RUP — методология разработки программного обеспечения, созданная компанией Rational RATIONAL UNIFIED PROCESS Использование методологии RUP направлено на итеративную модель разработки. Особенность Таким образом, существует множество различных методологий разработки программного обеспечения, они не универсальны В любой модели ЖЦ ПО имеется несколько характеристик качественного тестирования:  Каждому Цикл разработки ПО Идея – точка отсчета или то, с чего начинается любой проект.Дизайн (product Статусы спецификации:Черновик (Draft)Ожидание утверждения (Approval Pending)Утверждено (Approved)CVS – система контроля версий.Макеты (mock-up), Как правило, существуют минимум две версии ПО: тестовая и продакшин.Причины возникновения багов Тестирование и ремонт багов Тест приемки (smoke test).Тестирование новых компонентов (new feature РелизRelease (англ.) — выпуск.Виды релизов:major release – 1.0minor release – 1.1patch release Освежим:Перечислите стадии цикла разработки ПО. Перечислите болезни спецификаций.Для чего нужно утверждение спецификаций? Литература:http://www.protesting.ru/ http://ru.qahelp.net/ http://habrahabr.ru/ 4. The Scrum Master Training Manual, v. 1.2., By
Слайды презентации

Слайд 2 Cодержание:

Разработка ПО.
Верификация и валидация.
V- model.
Spiral model.
Waterfall model.
SCRUM.
CANBAN.
MSF.
RUP.
Жизненный

Cодержание:Разработка ПО.Верификация и валидация.V- model.Spiral model.Waterfall model.SCRUM.CANBAN.MSF.RUP. Жизненный цикл продукта.

цикл продукта.


Слайд 3 Разработка ПО — это род деятельности и процесс,

Разработка ПО — это род деятельности и процесс, направленный на создание

направленный на создание и поддержание работоспособности, качества и надежности программного

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

Слайд 4 Методология — это система принципов, а также совокупность идей,

Методология — это система принципов, а также совокупность идей, понятий, методов, способов

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

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

Слайд 5 Верификация — это обычно внутренний процесс управления качеством, обеспечивающий

Верификация — это обычно внутренний процесс управления качеством, обеспечивающий согласие с правилами,

согласие с правилами, стандартами или спецификацией. Валидация — подтверждение на основе

представления объективных свидетельств того, что требования, предназначенные для конкретного использования или применения, выполнены.

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

Слайд 6 V-Model

Основной принцип V-образной модели заключается в том, что

V-ModelОсновной принцип V-образной модели заключается в том, что детализация проекта возрастает

детализация проекта возрастает при движении слева направо, одновременно с

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


Слайд 7 V-Model

V-Model

Слайд 8 V-Model

V-Model

Слайд 9 V-Model
V-модель обеспечивает поддержку в планировании и реализации проекта.

V-ModelV-модель обеспечивает поддержку в планировании и реализации проекта. В ходе проекта

В ходе проекта ставятся следующие задачи:
Минимизация рисков: V-образная модель делает

проект более прозрачным и повышает качество контроля проекта путём стандартизации промежуточных целей и описания соответствующих им результатов и ответственных лиц.
Повышение и гарантии качества: V-Model — стандартизованная модель разработки, что позволяет добиться от проекта результатов желаемого качества. Промежуточные результаты могут быть проверены на ранних стадиях.
Уменьшение общей стоимости проекта: Ресурсы на разработку, производство, управление и поддержку могут быть заранее просчитаны и проконтролированы. Получаемые результаты также универсальны и легко прогнозируются.
Повышение качества коммуникации между участниками проекта: Универсальное описание всех элементов и условий облегчает взаимопонимание всех участников проекта.


Слайд 10 V-Model
Достоинства:
• Пользователи V-Model участвуют в разработке и поддержке

V-ModelДостоинства:• Пользователи V-Model участвуют в разработке и поддержке V-модели. • На

V-модели.
• На старте любого проекта V-образная модель может

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

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



Слайд 11 Spiral Model

Spiral Model

Слайд 12 Spiral Model
Представляет собой процесс разработки программного обеспечения, сочетающий в

Spiral Model Представляет собой процесс разработки программного обеспечения, сочетающий в себе как

себе как проектирование, так и постадийное   прототипирование с целью сочетания

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


Слайд 13 Spiral Model
Каждый виток спирали соответствует созданию фрагмента или

Spiral ModelКаждый виток спирали соответствует созданию фрагмента или версии программного обеспечения,

версии программного обеспечения, на нем уточняются цели и характеристики

проекта, определяется его качество и планируются работы следующего витка спирали. Таким образом углубляются и последовательно конкретизируются детали проекта и в результате выбирается обоснованный вариант, который доводится до реализации. Каждый виток разбит на 4 сектора:
оценка и разрешение рисков,
определение целей,
разработка и тестирование,
планирование.



Слайд 14 Waterfall Model

Waterfall Model

Слайд 15 Waterfall Model
Каскадная модель (waterfall model) —модель процесса разработки программного обеспечения, в которой

Waterfall Model Каскадная модель (waterfall model) —модель процесса разработки программного обеспечения, в которой процесс разработки

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

требований, проектирования, реализации, тестирования, интеграции и поддержки.

Слайд 16 Waterfall Model
Методику «Каскадная модель» довольно часто критикуют за

Waterfall ModelМетодику «Каскадная модель» довольно часто критикуют за недостаточную гибкость и

недостаточную гибкость и объявление самоцелью формальное управление проектом в

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

Слайд 17 SCRUM
SCRUM — методология, предназначенная для небольших команд (3-9

SCRUMSCRUM — методология, предназначенная для небольших команд (3-9 человек). Весь проект

человек). Весь проект делится на итерации (спринты) продолжительностью 30

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

Слайд 18 SCRUM Team

SCRUM Team

Слайд 19 SCRUM Events

SCRUM Events

Слайд 20 KANBAN
KANBAN – гибкая методология разработки программного обеспечения, ориентированная

KANBANKANBAN – гибкая методология разработки программного обеспечения, ориентированная на задачи. Основные

на задачи.
Основные правила:
визуализация разработки:
разделение работы на задачи;
использование отметок

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

Преимущества KANBAN:
уменьшение числа параллельно выполняемых задач значительно уменьшает время выполнения каждой отдельной задачи;
быстрое выявление проблемных задач;
вычисление времени на выполнение усредненной задачи.

Слайд 22 Во-первых, нужно сразу понять, что Канбан — это

Во-первых, нужно сразу понять, что Канбан — это не конкретный процесс,

не конкретный процесс, а система ценностей. Как, впрочем, и

SCRUM с XP. Это значит, что никто вам не скажет что и как делать по шагам. Во-вторых, весь Канбан можно описать одной простой фразой — «Уменьшение выполняющейся в данный момент работы (work in progress)». В-третьих, Канбан — это даже еще более «гибкая» методология, чем SCRUM и XP. Это значит, что она не подойдет всем командам и для всех проектов. И это также значит, что команда должна быть еще более готовой к гибкой работе, чем даже команды, использующие SCRUM и XP. Разница между Канбан и SCRUM: — В Канбан нет таймбоксов ни на что (ни на задачи, ни на спринты) — В Канбан задачи больше и их меньше — В Канбан оценки сроков на задачу опциональные или вообще их нет — В Канбан «скорость работы команды» отсутствует и считается только среднее время на полную реализацию задачи

Слайд 23 Канбан разработка отличается от SCRUM в первую очередь

Канбан разработка отличается от SCRUM в первую очередь ориентацией на задачи.

ориентацией на задачи. Если в SCRUM основная ориентация команды

— это успешное выполнение спринтов (надо признать, что это так), то в Канбан на первом месте задачи. Спринтов никаких нет, команда работает над задачей с самого начала и до завершения. Деплоймент задачи делается тогда, когда она готова. Презентация выполненной работы — тоже. Команда не должна оценивать время на выполнение задачи, ибо это имеет мало смысла и почти всегда ошибочно вначале.
Цели проекта: Необязательный, но полезный столбец. Сюда можно поместить высокоуровневые цели проекта, чтобы команда их видела и все про них знали. Например, «Увеличить скорость работы на 20%» или «Добавить поддержку Windows 7». Очередь задач: Тут хранятся задачи, которые готовы к тому, чтобы начать их выполнять. Всегда для выполнения берется верхняя, самая приоритетная задача и ее карточка перемещается в следующий столбец.

Слайд 24 Проработка дизайна: этот и остальные столбцы до «Закончено» могут

Проработка дизайна: этот и остальные столбцы до «Закончено» могут меняться, т.к.

меняться, т.к. именно команда решает, какие шаги проходит задача

до состояния «Закончено». Например, в этом столбце могут находиться задачи, для которых дизайн кода или интерфейса еще не ясен и обсуждается. Когда обсуждения закончены, задача передвигается в следующий столбец. Разработка: Тут задача висит до тех пор, пока разработка фичи не завершена. После завершения она передвигается в следующий столбец. Или, если архитектура не верна или не точна — задачу можно вернуть в предыдущий столбец. Тестирование: В этом столбце задача находится, пока она тестируется. Если найдены ошибки — возвращается в Разработку. Если нет — передвигается дальше. Деплоймент: У всех проектов свой деплоймент. У кого-то это значит выложить новую версию продукта на сервер, а у кого-то — просто закомитить код в репозиторий. Закончено: Сюда стикер попадает только тогда, когда все работы по задаче закончены полностью.

Слайд 25 Весь Канбан можно описать всего тремя основными правилами: 1.

Весь Канбан можно описать всего тремя основными правилами: 1. Визуализируйте производство

Визуализируйте производство — Разделите работу на задачи, каждую задачу напишите

на карточке и поместите на стену или доску. — Используйте названные столбцы, чтобы показать положение задачи в производстве. 2. Ограничивайте WIP (work in progress или работу, выполняемую одновременно) на каждом этапе производства. 3. Измеряйте время цикла (среднее время на выполнение одной задачи) и оптимизируйте постоянно процесс, чтобы уменьшить это время.

Слайд 26 MICROSOFT SOLUTIONS FRAMEWORK — методология разработки программного обеспечения,

MICROSOFT SOLUTIONS FRAMEWORK — методология разработки программного обеспечения, предложенная корпорацией Microsoft.

предложенная корпорацией Microsoft.
MSF опирается на практический опыт Microsoft

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

Слайд 28 RATIONAL UNIFIED PROCESS
RUP — методология разработки программного

RATIONAL UNIFIED PROCESS RUP — методология разработки программного обеспечения, созданная компанией

обеспечения, созданная компанией Rational Software.
В основе методологии лежат

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


Слайд 29
RATIONAL UNIFIED PROCESS
Использование методологии RUP направлено на

RATIONAL UNIFIED PROCESS Использование методологии RUP направлено на итеративную модель разработки.

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

степень формализации может меняться в зависимости от потребностей проекта.
Данная методология применима как в небольших и быстрых проектах, где за счет отсутствия формализации требуется сократить время выполнения проекта и расходы, так и в больших и сложных проектах, где требуется высокий уровень формализма, например, с целью дальнейшей сертификации продукта. Это преимущество дает возможность использовать одну и ту же команду разработчиков для реализации различных по объему и требованиям.
Фазы в RUP:
Начальная стадия (Inception)
Уточнение (Elaboration)
Построение (Construction)
Внедрение (Transition)



Слайд 31 Таким образом, существует множество различных методологий разработки программного

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

обеспечения, они не универсальны и описываются различными принципами. Выбор

методологии разработки для конкретного проекта зависит от предъявляемых требований.

Слайд 32 В любой модели ЖЦ ПО имеется несколько характеристик

В любой модели ЖЦ ПО имеется несколько характеристик качественного тестирования: Каждому

качественного тестирования:
Каждому процессу разработки соответствует свой процесс

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

Слайд 33 Цикл разработки ПО


Цикл разработки ПО

Слайд 34 Идея – точка отсчета или то, с чего

Идея – точка отсчета или то, с чего начинается любой проект.Дизайн

начинается любой проект.
Дизайн (product design) – разработка и документация

того, как необходимо воплотить идею в жизнь, др. словами как готовый продукт должен выглядеть/работать.
Спецификация (specification) – документ описывающий требования к продукту.
1. Акцент на деталях и их четкое определение.
2. Забота о недопущении неверного толкования.
3. Непротиворечивость с другими документами.
4. Логическая взаимосвязь компонентов.
5. Полнота охвата предмета.
6. Соответствие нормативным актам.
7. Соответствие деловой практике.



Слайд 35 Статусы спецификации:
Черновик (Draft)
Ожидание утверждения (Approval Pending)
Утверждено (Approved)
CVS –

Статусы спецификации:Черновик (Draft)Ожидание утверждения (Approval Pending)Утверждено (Approved)CVS – система контроля версий.Макеты

система контроля версий.
Макеты (mock-up), блоксхемы (flow chart) и примеры

(example).
Кодирование.
Работа программиста заключается в том, чтобы перевести вещи,
отраженные в спецификации, на язык программирования.
Основные занятия программиста:
Написание кода
Интеграция кода
Ремонт багов

Слайд 36 Как правило, существуют минимум две версии ПО: тестовая

Как правило, существуют минимум две версии ПО: тестовая и продакшин.Причины возникновения

и продакшин.
Причины возникновения багов в коде:
Некачественные и/или изменяющиеся спецификации


Личностные качества программиста
Отсутствие опыта
Пренебрежение стандартами кодирования
Сложность системы
Баги в ПО третьих лиц
Отсутствие юнит-тестирования
Нереально короткие сроки для разработки

Слайд 37 Тестирование и ремонт багов
Тест приемки (smoke test).
Тестирование

Тестирование и ремонт багов Тест приемки (smoke test).Тестирование новых компонентов (new

новых компонентов (new feature testing).
Регрессивное тестирование (regression testing).
Система трэкинга

багов (Bug Tracking System).
Build — это версия версии ПО.
Перед тестированием обязательно нужно проверить версию ПО.

Слайд 38 Релиз
Release (англ.) — выпуск.
Виды релизов:
major release – 1.0
minor

РелизRelease (англ.) — выпуск.Виды релизов:major release – 1.0minor release – 1.1patch

release – 1.1
patch release – 1.11
Релиз, как правило, происходит

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


Слайд 41 Освежим:
Перечислите стадии цикла разработки ПО.
Перечислите болезни спецификаций.
Для

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

чего нужно утверждение спецификаций?
Для чего нужно замораживание спецификаций?


Перечислите причины появления багов кода.
Для чего нужно замораживание кода?
Что такое тест приемки?
Что случается, если тест приемки не пройден?
Виды релизов.
Какие методологии разработки ПО вам известны?
Когда целесообразно начинать тестирование?










  • Имя файла: software-development-life-cycle-and-methodologies-topic-2.pptx
  • Количество просмотров: 132
  • Количество скачиваний: 0