| 1 | выдержки из перевода статьи [http://habrahabr.ru/blogs/code_review/64086/ Я ненавижу тебя: твой код – отстой!] |
| 2 | Оригинал [http://mumak.net/stuff/your-code-sucks.html Your Code Sucks and I Hate You: The Social Dynamics of Code Reviews] |
| 3 | |
| 4 | |
| 5 | == Что такое плохо == |
| 6 | |
| 7 | |
| 8 | === Ad hominem (переход на личности – прим. перев.) |
| 9 | === |
| 10 | |
| 11 | Здесь практически нечего добавить: инспектируйте программу, а не программиста. Замечания о его личности лишь усложняют восприятие им критики. |
| 12 | Совет: если вы пишите негативные комментарии, пишите «патч» или «код» вместо «ты». Например, вместо «У тебя глюк в get_message» пишите «После применения этого патча в get_message появился глюк». |
| 13 | |
| 14 | === Туманные результаты ревизии === |
| 15 | |
| 16 | Если всё, что вы можете сказать, это «В этом патче появился глюк в get_message», то вы плохой рецензент. Цель ревизии – улучшить код, а не загадывать автору загадки. |
| 17 | |
| 18 | Автор должен иметь возможность однозначно выделить и понять каждую отдельную мысль в вашем замечании, а также всё замечание целиком. Обзоры с нечёткими результатами превращаются в бесконечные дискуссии о коде, которые скорее служат тому, чтобы доставить удовольствие рецензенту, чем повешению качества кода. |
| 19 | |
| 20 | === Не путайте личные предпочтения с объективными достоинствами === |
| 21 | |
| 22 | Это проблема обозревателей в любой области: кинокритика, литературного редактора, научного рецензента. Не обязательно на самом деле хорошо то, что нравится мне. И уж тем более не обязательно на самом деле плохо то, что не нравится мне. Один из аспектов становления выдающегося программиста это моделирование собственных предпочтений в соответствии с реальными, объективными достоинствами. |
| 23 | |
| 24 | Если вы рецензируете патч, который прекрасно устраняет какую-либо проблему, используя парадигму императивного программирования, то не стоит критиковать его лишь за то, что он не следует функциональной парадигме. Так вы дискредитируете идею ревизий, превращаю её в игру по угадыванию предпочтений рецензента, а она должна способствовать создания действительно хорошего код. |
| 25 | |
| 26 | Формулирование комментариев в виде вопросов поможет проверяющему избежать такой оплошности, например: «Не думали ли вы использовать функциональный стиль?», «Почему вы не используете регулярные выражения для решения этой задачи?» и т.д. |
| 27 | |
| 28 | См. также «Чёткий ответ – хороший ответ». |
| 29 | |
| 30 | === «Пока вы ещё здесь…» === |
| 31 | |
| 32 | При обзоре кода всегда есть соблазн попросить автора исправить заодно и какие-нибудь другие проблемы. Такой подход может быстро перерасти в полномасштабную операцию по наведению глянца на большом участке кода, хотя изначально автор и проверяющий должны были утвердить лишь небольшое улучшение. |
| 33 | |
| 34 | Лучший совет в такой ситуации: дорожить поэтапным улучшением. См. «Лучшее враг хорошего». |
| 35 | |
| 36 | === «Флибустьерство» === |
| 37 | |
| 38 | «Флибустьерство» (filibustering) это американский политический термин, обозначающий затягивание дебатов по законопроекту с целью помешать его принятию. Иногда это делается и в проектах свободного ПО с целью саботировать принятие определённого патча. |
| 39 | |
| 40 | «Флибустьерство» также может возникать непреднамеренно. Человек, проводящий ревизию, не принимает патч по причине отсутствия блочных тестов, автор спрашивает, как ему написать блочные тесты для этого кода, а рецензент так и не удосуживается ответить. А ведь омимо этих неприятностей, у автора есть ещё и свои дела, мешающие ему продолжать присылать новые патчи. |
| 41 | |
| 42 | См. «Туманные итоги обзора» и «Быстрый ответ – хороший ответ». |
| 43 | |
| 44 | == Что такое хорошо == |
| 45 | |
| 46 | === Чёткий ответ – хороший ответ === |
| 47 | |
| 48 | Указывайте конкретные строки кода, которые можно улучшить. Опишите, что с в них не так. Предложите способ сделать лучше. Помогите автору определить пределы совершенствования. |
| 49 | |
| 50 | === Быстрый ответ – хороший ответ === |
| 51 | |
| 52 | Как только автор представил свои патчи на ревизию, он больше не может над ними работать. Он должен дождаться ответа ревизора, прежде чем продолжить. Пишите свои замечания в обзор как можно скорее, чтобы внимание автора не успело рассеяться. |
| 53 | |
| 54 | === Лучшее враг хорошего === |
| 55 | |
| 56 | Нельзя сделать идеальный патч, который бы разом решил все ваши проблемы. Не гонитесь за идеалом, работайте над поэтапным улучшением. |
| 57 | |
| 58 | === Будьте благодарны === |
| 59 | |
| 60 | Кто-то попытался улучшить ваш продукт. Они потратили свои силы и фантазию на то, чтобы помочь вам, а теперь представили свой труд на суд общественности: так поблагодарите их. |
| 61 | |
| 62 | В проекте Divmod практикуют принцип включения в каждый обзор кода хотя бы одной похвалы. Всегда можно найти, за что похвалить автора, пусть даже лишь за то, что он взялся поработать над этой частью кода. |
| 63 | |
| 64 | === Задавайте вопросы === |
| 65 | |
| 66 | Рецензент должен задавать вопросы. Нельзя ошибиться, задавая вопросы. В худшем случае автор даст тривиальный ответ. В лучшем случае оба, и автор, и проверяющий, откроют для себя что-то новое. |
| 67 | |
| 68 | == Заключение == |
| 69 | |
| 70 | Ревизии кода дают человеку уникальную возможность расти как программисту, при этом улучшая продукт, который он создаёт. Каждый проект может выбирать из многих вариантов проведения ревизий и предоставляемых ими возможностей. Тщательное обдумывание технологий и процессов взаимодействия людей при проведении обзоров позволит проектам с открытым кодом избежать сложностей, которые отпугивают новичков и утомляют давнишних участников, и сосредоточиться на разработке наилучшего программного обеспечения. |