Есть ли момент, когда стоимость рефакторинга перевешивает стоимость переписывания?
У меня есть действительно шокирующий код, рекламируемый как фреймворк следующего поколения на моем нынешнем месте работы.
Дело в том, что есть только один человек с таким мнением, и это тот парень, который написал большую часть этого. У остального отдела сложилось впечатление, что оно плохо закодировано, лаваш для отладки и просто немного ворсистый в целом.
Парень, который написал это, имеет довольно влиятельную позицию в управлении, поэтому они находятся на той стороне лагеря.
Мы выдвинули на первый план (подлинную) озабоченность руководства, но, очевидно, они не готовы уделять больше времени проекту, который непосредственно не способствует получению прибыли.
В этой среде развернуто несколько приложений, поэтому любой рефакторинг должен охватывать эти приложения.
Все это настолько переплетено, что мы не можем просто извлечь реализацию определенного класса и переписать ее таким образом, чтобы даже простые изменения в ядре API означали большой проект.
Тем не менее, он имеет 3 года в реальном развертывании, и многие исправления ошибок, угловые случаи и граничные условия учитываются.
Переписываем ли мы по частям и пытаемся ли реорганизовать, учитывая, что это будет несколько крупных проектов, реорганизация со временем, что может занять еще 3 года, чтобы привести его в порядок, или мы просто переписываем наши конкретные требования поверх существующих фреймворк?
6 ответов
Переписывать что-либо - это почти всегда плохая идея - вы тратите месяцы на работу, и вам нечего показать, пока вы не закончите. И это предполагает, что вы не становитесь жертвой эффекта второй системы и что вы действительно заканчиваете.
Рефакторинг почти наверняка правильный ответ. У меня нет опыта рефакторинга PHP (я делаю C++ и C#), поэтому я не могу дать какой-либо конкретный совет. Вы должны приступить к шагам ребенка.
- Во-первых, определите те части кода, которые вас больше всего обижают. Для меня в C++ это глобальные переменные.
- Во-вторых, сделайте небольшие рефакторинги, чтобы устранить одну проблему за раз. Чтобы не сломать старых клиентов этого кода, вам может потребоваться установить фасад. Либо вы можете поместить новый фасад в старый код, либо вы можете поместить старый фасад в новый код.
- В-третьих, и это самое главное, если вы не уверены, убедитесь, что у вас есть солидный набор модульных тестов для кода, который вы собираетесь реорганизовать.
Но: не бросайте все, чтобы переписать код. Рефакторинг постепенно. Это немного замедлит вас, но вы все равно будете приносить пользу, пока продвигаетесь вперед.
См. Эту статью, которая поможет вам объяснить техническую задолженность вашему руководству. Это также объяснит, почему их это не волнует.
Преимущество переписывания заключается в том, что вы можете учесть все новое на этапе анализа, создать модель, более адаптированную к текущим потребностям. С другой стороны, если это только плохо закодировано, не плохо спроектировано, нет смысла делать полное переписывание. Просто дезинфицируйте / реорганизуйте код.
Чтобы добавить к тому, что уже было сказано: попробуйте получить бай-ин от руководства. При проведении рефакторинга есть свои преимущества: трудозатраты на программирование новых функций со временем будут снижаться, а не увеличиваться, что приведет к снижению затрат на заработную плату и, возможно, к затратам на сервер. Если никто из вашего руководства не понимает, почему рефакторинг имеет смысл и сделает вас счастливее, выполняя свою работу, вы работаете в нужном месте?
Переписывать это очень рискованно. Вы замените старый хорошо отлаженный код новым кодом, который еще предстоит отладить. Это внесет множество ошибок, и вам придется их исправлять. Лучше постепенно проводить рефакторинг - сначала очень подробно понять, для чего нужна какая-то часть, а затем рефакторинг. Таким образом вы заменяете меньше кода и снижаете риск появления слишком большого количества новых ошибок.
На небольшом уровне: да: предоставьте новую версию функции, убедитесь, что она работает как с новой, так и со старой, удалите старую. Это часто достаточно быстро, чем рефакторинг самой функции. Но на этом уровне это рефакторинг:)
Стратегическая стоимость переписывания практически всегда превышает рефакторинг.
Вы не можете доставить. Вы должны поддерживать старую версию, пока вы разрабатываете новую. Если финансы говорят, что вы должны убить проект переписывания, вы ничего не добились - ваша рабочая база кода находится в плохом состоянии, как будто ничего не было сделано. Вероятно, еще хуже, поскольку все изменения были включены, потому что "мы все выбросим, когда переписывание все равно закончится".
Да, сценарии, где переписывание дешевле, МОЖЕТ быть построено:
- исходная кодовая база настолько спагеттирована, что любая локальная модификация нарушает, казалось бы, не связанные функции.
- У вас действительно отличная новая команда, намного лучше, чем старые парни, но у них нет опыта работы с существующей кодовой базой, а существующая кодовая база - беспорядок, или на языке, который они не знают, или что-то в этом роде.
Тем не менее, опыт показывает, что код плох по какой-то причине, и это не всегда кодеры, и если вы не выявите и не измените причины, переписывание будет упражнением в повторении истории.
Это очень сложное решение...
Проблема, которую я вижу здесь, состоит в том, что фреймворк используется и исправляется в течение длительного времени, поэтому в него вложено много знаний, и качество выполняемых проектов, очевидно, приемлемо. так что если вы переписываете его с нуля со всеми известными вам требованиями - вы можете быть уверены, что забудете что-то, что уже сработало (трудно объяснить это клиенту - или вашему начальнику;))
Реорганизовать его - он думает - это также трудная задача, поскольку есть только один парень, который действительно знает связи в коде - кто не хочет его менять...
Есть три варианта:
- живи с этим
- убедить парня в необходимости рефакторинга, чтобы каждый мог использовать / поддерживать его не только он
- убедить руководство в необходимости переписывания, но это очень расстроит того, кто против переписывания / рефакторинга
В любом случае, это плохая ситуация для всех... так как со временем ответственному за фреймворк придется самому разобраться с этим, и тогда, вероятно, будет слишком поздно.