Командная разработка программных средств

Содержание

Слайд 2

Лабораторная 1.3. Кодирование, ревью кода

Разбор предыдущей лабораторной.
Задание 1. Кодирование, написание тестов.
Задание

Лабораторная 1.3. Кодирование, ревью кода Разбор предыдущей лабораторной. Задание 1. Кодирование, написание
2. Ревью кода.
В ревью должны быть задействованы все участники группы (как авторы или как рецензенты).
Контрольные списки должны быть разработаны самостоятельно (минимум 5 пунктов списка).
В ревью могут участвовать: код, архитектура, юнит-тесты.
Отчет по лабораторной: результат лабораторной, описание собственного вклада в решение задачи.

Командная разработка, ИрГУПС-2017

Слайд 3

Разбор предыдущей лабораторной

« … люди постоянно должны изучать что-то новое, что бы

Разбор предыдущей лабораторной « … люди постоянно должны изучать что-то новое, что
не происходило стагнации личности, а позже и деградации. Это может вызвать потерю ценностей и бесцельное проведение жизни.»
Коллектив авторов
Основные замечания:
Отсутствие или низкое качество псевдокода
Своеобразное представление результатов проектирования (одна диаграмма классов, миллион непонятых блок-схем)
Отсутствие соглашений по защитному программированию
Отсутствие соглашений по структуре ini-файлов (не у всех).
Отсутствие соглашение о получении обрабатываемого файла (не у всех)
Отсутствие документирования, тестирования и отладки как задачи
Необоснованные оценки трудозатрат (29 часов на весь проект).
Загадочные имена функций и переменных (OrigINItoOutINI, type Data struct)
Наличие немотивированных отступлений.

Слайд 4

Контрольные списки для ревью кода

Контрольные списки для ревью кода

Слайд 5

Ревью кода: пример контрольного списка

Общие вопросы:
Работает ли код? Выполняет ли он свои

Ревью кода: пример контрольного списка Общие вопросы: Работает ли код? Выполняет ли
прямые обязанности, корректна ли логика, и т. д.
Легок ли код для понимания?
Соответствует ли код вашему стилю написания кода? Обычно это относится к расположению скобок, названиям переменных и функций, длинам строк, отступам, форматированию и комментариям.
Есть ли в ревью избыточный или повторяющийся код?
Является ли код связным насколько это возможно?
Можно ли избавиться от глобальных переменных или переместить их?
Есть ли закомментированный код?
У циклов есть установленная длина и корректные условия завершения?
Может ли что-то в коде быть заменено библиотечными функциями?
Может ли быть удалена часть кода, предназначенного для логирования или отладки?

Командная разработка, ИрГУПС-2017

Слайд 6

Ревью кода: пример контрольного списка

Безопасность и защитное программирование
Все ли входные данные проверяются

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

Командная разработка, ИрГУПС-2017

Слайд 7

Ревью кода: пример контрольного списка

Документация
Есть ли комментарии? Раскрывают ли они смысл кода?
Все

Ревью кода: пример контрольного списка Документация Есть ли комментарии? Раскрывают ли они
ли функции прокомментированы?
Есть ли какое-то необычное поведение или описание пограничных случаев?
Использование и функционирование сторонних библиотек документировано?
Все ли структуры данных и единицы измерения описаны?
Есть ли незавершенный код? Если есть, должен ли он быть удален или помечен маркером типа «TODO»

Командная разработка, ИрГУПС-2017

Слайд 8

Ревью кода: пример контрольного списка

Тестирование
Является ли код тестируемым? Например, он не должен

Ревью кода: пример контрольного списка Тестирование Является ли код тестируемым? Например, он
содержать слишком много зависимостей или скрывать их, тестовые фреймворки должны иметь возможность использовать методы кода, и т. д.
Есть ли тесты и если есть, то достаточны ли они? Например, они покрывают код в нужной мере.
Юнит-тесты на самом деле проверяют, что код предоставляет требуемую функциональность?
Все ли массивы проверяются на «выход за границы»?
Может ли любой тестирующий код быть заменен с использованием существующего API?

Командная разработка, ИрГУПС-2017

Слайд 9

Тестирование в Go

Тестирование в Go

Слайд 10

Юнит-тесты

Пакет testing
Файл ИмяТестируемойСущности_test.go
В этом файле:
func TestИмяТестируемойФункции(t *testing.T)
Команда go test

Юнит-тесты Пакет testing Файл ИмяТестируемойСущности_test.go В этом файле: func TestИмяТестируемойФункции(t *testing.T) Команда go test

Слайд 11

Пример

Пример

Слайд 12

Пример

Пример

Слайд 13

Пример

Пример

Слайд 14

Отчет по лабораторной

Отчет по лабораторной