Как в сетевом графике отпимизировать работу по числу исполнителей? |
Вопросы и задания по курсу "Введение в программную инженерию"
Методические рекомендации
Рекомендация 1
Задания на основе карт памяти (mind maps) следует использовать постепенно вот в каком смысле. Учащиеся должны овладеть этой техникой – оказывается, для этого нужно затратить некоторое время. Нет необходимости проводить специальный тренинг – достаточно просто объяснить, что это такое и как этим пользоваться, и сразу же приступить к использованию. По ходу дела целесообразно давать нужные рекомендации. После нескольких карт памяти, составленных самостоятельно, студенты осваивают эту технику. Первые карты памяти целесообразно рисовать "вручную". Впоследствии, особенно при "массовом" процессе использования карт памяти, целесообразно пользоваться инструментами. Мы рекомендуем продукт Comapping (http://www.comapping.com). Дальнейшие детали по использованию карт памяти в преподавании программной инженерии можно найти в работах [1-3].
Рекомендация 2
Часть заданий и вопросов на отдельную тему часто целесообразно прорабатывать после освоения всего курса вообще, так как они содержат ссылки на другие темы – как назад так и вперед. Другую часть заданий и вопросов целесообразно прорабатывать сразу же после прослушивания лекционного материала и на них строить процесс освоения данного материала. Мы не делили вопросы и задания в соответствии с вышесказанным, надеясь на опытность преподавателей и интуицию учащихся.
Рекомендация 3
Относительно всех лекций правомочно одно, стандартное задание – нарисовать все содержание лекции в виде одной карты памяти на листе формата А4 (можно А3, но не больше). Такие задания целесообразно давать после каждой лекции или в начале лекции, но про материал предыдущей. Преподавателю полезно учитывать информацию из этих проверочных работ при дальнейшем изложении материала. Полезность такого подхода связан с тем, что такие карты памяти легко рисуются (при наличии навыка) и очень легко проверяются.
Рекомендация 4
Часто задания с помощью карт памяти оказываются не совсем картами памяти. Исчезает центральный объект, вместо него появляется произвольных "плоский" граф. Также полезно оказывается рисовать имена связям. Мы все равно называем такие графы картами памяти, чтобы терминологически не усложнять ситуацию.
Литература
- Д.В Кознов, Я.А Кириленко. Опыт сочетания теории и практики в обучении программной инженерии . Труды III Международная научно-практическая конференция "Современные информационные технологии и ИТ-образование" 2008 год. http://2008.itedu.ru/pages/Conference-works.
- D.V.Koznov, M.Y. Pliskin. Computer-Supported Collaborative Learning with Mind-Maps. T. Margaria and B. Steffen (Eds.): ISoLA 2008, CCIS 17, pp. 478–489, 2008. Springer-Verlag, Berlin Heidelberg, 2008.
- Д.В.Кознов. Методика обучения программной инженерии на основе карт памяти. Системное программирование. / Вып. 3, под ред. А.Н.Терехова и Д.Ю.Булычева. СПб.: Изд. СПбГУ, 2008. С. 121-140. http://www.sysprog.info.
Лекция 1. О предмете изучения
Вопросы
- Что такое программная инженерия?
- Назовите дату зарождения программной инженерии как отдельной науки.
- В чем отличие программной инженерии от информатики?
- В чем отличие программной инженерии от системотехники?
- Приведите примеры дисциплин информатики и программной инженерии (дисциплины не путать с учебными предметами).
- Что такое ПО?
- Перечислите характеристики ПО по Бруксу и кратко характеризуйте каждую.
- C какими иными видами человеческой деятельности соотносится создание ПО в данном разделе?
Задания
- С помощью карт памяти максимально полно ответьте на вопрос – что такое программная инженерия, учитывая все измерения этого термина, мелкие и крупные детали.
- С помощью карт памяти нарисуйте взаимосвязи характеристик ПО по Бруксу, пользуясь надписями на дугах.
Лекция 2. Процесс разработки программного обеспечения
Вопросы
- Что такое процесс создания ПО?
- Расскажите о причинах отсутствия универсального процесса разработки ПО.
- Почему возможно и целесообразно стандартизировать процесс на уровне компании?
- Что такое стандартный и конкретный процессы и как они соотносятся?
- Чем отличаются между собой текущий и конкретный процессы? Какие методологии разработки ПО поддерживают понятие конкретного процесса и какими средcтвами?
- Дайте определение деятельности по совершенствованию процесса.
- В чем главная трудность совершенствования процессов в компаниях?
- Перечислите основные направления улучшения процесса.
- Расскажите о стратегии organization pull к внедрению инноваций. Приведите примеры.
- Расскажите о стратегии technology push к внедрению инноваций. Приведите примеры.
- Расскажите о достоинствах, недостатках, а также возможных рисках этих стратегий.
- Что такое модель процесса?
- Что такое фаза процесса?
- Что такое вид деятельности?
- Почему нельзя отождествлять фазы и виды деятельности? Когда и по каким причинам это все таки происходит на практике?
- В чем достоинства водопадной модели? В чем ее историческая роль? В чем ее недостатки?
- Как в рамках водопадной модели предполагается работать с рисками?
- Почему водопадная модель до сих пор используется? Объясните, почему эту модель удобно использовать в оффшорных проектах с почасовой оплатой?
- Чем виток спиральной модели отличается от фазы в водопадной модели? Приведите пример последовательности витков спиральной модели. Опишите условия, при которых спираль завершается.
- Расскажите про второе и третье измерение спиральной модели. Опишите различные секторы витка спирали.
- В чем достоинства и недостатки спиральной модели? Каковы ограничения этой модели?
- Как в рамках этой модели предполагается работать с рисками?
Задания
Лекция 3. Рабочий продукт, дисциплина обязательств, проект
Вопросы
- Дайте определение рабочего продукта. Приведите примеры.
- Чем отличается рабочий продукт от компоненты ПО?
- Расскажите, что такое нематериальный рабочий продукт.
- Опишите, как "работает" дисциплина обязательств.
- Приведите примеры других видов отношений между людьми.
- Расскажите о границах применения дисциплины обязательств.
- Что такое проект и чем он отличается от других форм организации бизнеса и производства?
Задания
- Нарисуйте с помощью карт памяти взаимосвязь рабочего продукта и дисциплины обязательств.
- Нарисуйте с помощью карт памяти информацию об использовании рабочего продукта и дисциплины обязательств в разных методологиях разработки ПО.
- Нарисуйте с помощью карт памяти информацию об использовании рабочего продукта и дисциплины обязательств в разных а также отдельных практиках.
- Соедините в одну карту памяти результаты выполнения заданий 1-3.
Лекция 4. Архитектура ПО
Вопросы
- Дайте определение архитектуре ПО. Расскажите, какие аспекты разработки задействует это понятие.
- Расскажите о причинах множественности точек зрения при разработке ПО.
- Как по вашему мнению, множественность точек зрения помогает или мешает в разработке?
- Перечислите и кратко прокомментируйте разные виды диаграмм UML.
Лекция 5. Управление требованиями
Вопросы
- В чем трудность управления требованиями? При ответе на этот вопрос имейте в виду другие инженерные области и сферы бизнеса. Старайтесь отвечать на вопрос с наружи программной инженерии, а не изнутри.
- Перечислите способы формализации требований. Под формализацией имеется в виду способ не промежуточной, а финальной фиксации.
- Расскажите о способах и техниках "вытягивания" требований.
- Перечислите разные виды документов, формализующих требования.
- Расскажите об отличии функциональных и нефункциональных требований.
- Расскажите о типовом цикле работы с требованиями.
- Перечислите типовые ошибки при работе с требованиями.
Задания
- Нарисуйте на одной карте памяти ответы на вопросы 2-5.
- Добавьте к это карте памяти ответ на вопрос 6.
- Построить модель случаев использования, нарисовать главные сценарии, сформулировать список вопросов для обсуждения и написать техническое задание для следующей задачи. В качестве структуры технического задания используйте модель случаев использования.
Необходимо реализовать программную систему для call-центра крупного банка, обслуживающего частных лиц. Банк хочет начать предоставлять новый вид услуг – по телефону. Кроме того, система должна уметь учитывать рабочее время операторов центра (дифференцированно, собирая информацию о том, какой вид работ, а также простои сколько занимают времени). Система также должна быть интегрирована с различными электронными справочниками и базами данных, содержать информацию о постоянных клиентах, маршрутизировала бы их к "своим" операторам (которые с ними общались и их помнят). Часть функций система должны быть доступны через Интернет, так как менеджеры call-центра должны иметь доступ к текущей статистики, находясь в любой точке мира, а также в дороге (банк – сильно распределен, его call-менеджеры участвуют в большом количестве международных деловых встреч, конференций и пр.) Система должна также обеспечивать максимальную защищенность данных от несанкционированного доступа – ее данные являются жизненно важными, критичными для банка, так как содержат информацию о финансах его клиентов, среди которых есть самые богатые люди мира.
Лекция 6. Конфигурационное управление
Вопросы
- Приведите примеры проблем в проектах, где нет хорошего конфигурационного управления.
- Неформально объясните, какие задачи выполняет конфигурационное управление в проекте.
- Дайте формальное определение конфигурационному управлению.
- Расскажите об известном противоречии - абсолютной сохранности и удобного доступа.
- Приведите пример артефактов проекта, которые могут "подпадать" под конфигурационное управление.
- Приведите пример артефактов проекта, которые могут не "подпадать" под конфигурационное управление. подпадающих
- Что является главным артефактом конфигурационного управления и почему.
- Перечислите основные функции версионного контроля.
- Что такое управление сборками?
- Что такое непрерывная интеграция. В каких известных вам методологиях она используется и почему (на ваш взгляд).
- Расскажите о понятии baseline.
Задания
- Составьте карту памяти, обозначив на ней все известные вам связи конфигурационного управления с другими видами деятельности по разработке ПО.
- Нарисуйте типовой сценарий работы сборщика.
- Нарисуйте различные макро-сценарий сборки (ночной, по запросу, в режиме постоянной интеграции и т.д.)
Лекция 7. Тестирование
Вопросы
- Перечислите и кратко охарактеризуйте различные способы контроля качества ПО.
- Дайте определение тестирования и кратко прокомментируйте его.
- Что означает в контексте тестирования ожидаемое поведение программы?
- Что входит в искусственные, специально заданные условия воздействия на систему, которые имеются в виду в определении тестирования?
- В чем важность концепции теста?
- В чем преимущества автоматического тестирования перед "ручным"?
- В чем трудности автоматического тестирования?
- Приведите свои собственные примеры проблем с интерфейсами к тестируемым системам.
- Приведите примеры того, как прогон тестов может влиять на поведение системы.
- В чем смыл факторизации входных значений при тестировании?
- Расскажите о разных вариантах организации команды тестеровщиков.
- Перечислите и кратко охарактеризуете виды тестирования.
Задания
- Как на ваш взгляд концепция тестирования системы методом черного ящика связан с типичной организацией команды тестеровщиков и ее взаимодействия с командой разработчиков? В ответе учтите различные стратегии, принятые в разных известных вам методологиях разработки ПО. Ответ нарисуйте в виде карты памяти.
- Нарисуйте в виде карты памяти взаимодействие между различными видами тестирования.
- Нарисуйте пример жизненного цикла ошибки.
Лекция 8. Диаграммные техники в работе со знаниями
Вопросы
- Какова роль актеров при построении диаграмм случаев использования?
- Что такое случай использования и чем он отличается от произвольной функции системы.
- Какие бывают виды актеров?
- Расскажите о бизнес-диаграммах случаев использования.
- Расскажите об основном предназначении диаграмм случаев использования. Попробуйте самостоятельно оценить их полезность.
- Расскажите о разных вариантах применения диаграмм случаев использования.
- Расскажите о применении случаев использования в управлении разработкой.
- Расскажите об основной идее цикла автор/рецензент.
- Как этот цикл можно использовать при извлечении знаний из эксперта? Расскажите о дополнительных особенностях этого процесса. Примерьте эту технику для собственного использования и поделитесь возникшими соображениями.
- Расскажите об истории карт памяти, а также о том, что это такое.
- Перечислите и кратко охарактеризуйте основные направления по практическому использованию карт памяти. Как именно вы используйте карты памяти? Собираетесь ли вы их использовать?
- Расскажите о продукте Comapping и его основных возможностях по работе с картами памяти.
Лекция 9. MSF
Вопросы
- Расскажите об истории разработки MSF.
- Расскажите об основных принципах MSF.
- В чем главные новшества MSF?
- Чем отличаются версии MSF 3.х от 4.х?
- Что такое IT-решение?
- Что такое управление компромиссами? Приведите примеры.
- Расскажите о модели команды MSF. В чем ее свобода и где она заканчивается?
Задания
- Нарисуйте модель команды MSF, изобразив также аспекты масштабирования команды, в том числе возможность сочетания/не сочетания различных ролей в одном человеке.
Лекция 10. CMMI
Вопросы
- Что такое CMMI? Постарайтесь не описывать CMMI, а в нескольких предложениях его определить, дать компактное и точное определение.
- Кратко расскажите историю развития стандарта CMMI. Чем CMMI отличается от CMM?
- Перечислите и кратко охарактеризуйте уровни CMMI.
Лекция 11. "Гибкие" (agile) методы разработки
Вопросы
- Расскажите о принципах "гибких" методов разработки.
- Какие, по вашему, существуют ограничения в применении гибких методов?
- Перечислите известные вам "гибкие" методологии разработки ПО.
- Расскажите о принципах XP. С чем, на ваш взгляд, могут возникнуть трудности при практическом внедрении XP?
- Расскажите о главных идеях Scrum. При этом не начинайте длинный рассказ про всю методологию в целом, а также не перечисляйте ее сонные артефакты. Дайте качественное описание из вне.
- Расскажите, как устроена самоорганизуемсоть команды в Scrum? Как методология ограждает свободу команды и какие выгоды из этого извлекаются для проекта?
- Расскажите об обязанностях Scum-матера.
- Расскажите об обязанностях Product Owner.
- Расскажите о задачах ежедневных встреч.
Лекция 12. Обзор технологии Microsoft Visual Studio Team System (VSTS)
Вопросы
- Расскажите об основных составляющих продукта MS VSTS.
- Расскажите о функциональности TFS.
- Расскажите о различных клиентских приложениях MS VSTS.
- Расскажите о средствах поддержания сборки в MS VSTS.
- Расскажите о различных изданиях Visual Studio и их возможностях относительно MS VSTS.
- Расскажите о самом простом клиенте TFS и тех функциональных возможностях, которые он обеспечивает.
- Расскажите о возможностях пакета Team Foundation Power Tools. Это клиентская или северная компонента?
- Расскажите об инсталляции MS VSTS.
Задания
- Нарисуйте с помощью карт памяти схему продукта MS VSTS, подробно, со всеми деталями и дополнительными используемыми технологиями. При этом старайтесь не смотреть на картинки в курсе лекций, а пользуйтесь имеющейся у вас информацией и здравым смыслом, излагая все, что вы знаете и постепенно уточняя возникшие вопросы.
Лекция 13. VSTS: управление элементами работ (Work Items)
Вопросы
- Что такое элемент работы? Приведите примеры различных видов элементов работы.
- Какие есть еще артефакты в процессе, развернутом в MS VSTS? Как они взаимосвязаны с элементами работы?
- Что такое тип элемента работы, что в нем определяется?
- Расскажите о реквизитах элемента работы.
- Как и где задается жизненный цикл элемента работы? Какие программные продукты при этом используются?
- Расскажите об импорте/экспорте элементов в MS Excel и Project: зачем это нужно, какие практические выгоды это дает.
- Расскажите о связи элементов работы и отчетов.
Лекция 14. VSTS: конфигурационное управление
Вопросы
- Перечислите особенности системы контроля версий TFS, отсутствующие в других подобных средствах.
- Расскажите об Отслеживание изменений отдельных файлов.
- Расскажите о правилах внесения изменений.
- Расскажите об управлении ветками.
- Расскажите о сохранении без внесения.
- Расскажите о связи средств управления сборкой TFS и MS Build.
- Расскажите об описаниях сборок (build definition).
- Расскажите о результатах сборок (build results).
- Расскажите о том, как создается проект в MS Build.
- Расскажите о запуске процесса сборки.
- Расскажите об анализе результатов сборки.
- Расскажите об управлении процессом сборки.
- Расскажите об управлении политикой очистки сборок.
Лекция 15. VSTS: тестирование
Вопросы
- Подробно разберите и прокомментируйте жизненный цикл ошибки в шаблоне процесса MSF for Agile.
- Расскажите о том, как создается описание ошибки.
- Опишите связь изменений исходных текстов ПО и ошибок.
- Расскажите о системе автоматических оповещений в TFS.
- Расскажите о целях и задачах модульного тестирования. Как модульные тесты, созданные разработчиками, могут использоваться в дальнейшем?
- Какие альтернативы MS VSTS существуют для автоматической поддержки модульного тестирования для Visual Studio?
- Расскажите о поддержке модульного тестирования в MS VSTS. Какая часть среды реализует эту функциональность?
- Расскажите о поддержке работы с пакетами тестов в MS VSTS.
- Расскажите о подходе тестирования пользовательского интерфейса Capture & Playback. В чем его трудности?
- Расскажите о том, как эти трудности решаются в случае тестирования интерфейсов Web-приложений.
- Расскажите о поддержке Capture & Playback тестирования интерфейсов Web-приложений в MS VSTS.
Лекция 16. VSTS: поддержка различных моделей процесса
Вопросы
- Зачем нужны разные шаблоны процессов в MS VSTS?
- Что они определяют, что задают, и как ограничивают разработчиков. И как им помогают?
- Какова на ваш взгляд, трудоемкость создания собственного шаблона процесса "с нуля"?
- С какой темой курса связана шаблоны процессов в MS VSTS? Найдите термин из курса, который в точности может заменить термин "шаблон процесса".
- Перечислите и охарактеризуйте разделы описания шаблона процесса.
- Сделайте краткий обзор известных вам шаблонов процесса MS VSTS.
- Опишите шаблон MSF for Agile Software Development.
- Опишите шаблон Scrum.
- Чем они отличаются?