|
20.03.2017, 09:42 | #1 |
Участник
|
Цитата:
Сообщение от belugin
А еще есть книжка Эффекстивная работа с унаследованным кодом там как раз про то, как писать тесты для говнокода.
Как и все подобные книги, авторы исходят из предположения, что код можно и нужно менять. Дается обоснование, почему "боязнь изменений" - это плохо Далее даются советы, как лучше делать эти изменения. Как я уже говорил в самом начале этой ветки, для dynamics продуктов это предположение неверное. Большинство приемов связанных с расщеплением, охватом не работают. (см. приложенные скриншоты) Так в аксапте нельзя менять сигнатуры методов, которые находятся в sys-слоях. Можно только расширять сигнатуры. Что и делается параметрами по умолчанию. Откуда собственно и появилась ветка. Причем нельзя менять не только клиентам и партнерам. Нельзя менять и самому майкрософту, чтобы не потерять совместимость кода. Поэтому для Аксапты нужны адаптированные методы. Но пока я вижу только советы: тестировать только свои изменения. Критерий - здравый смысл. Что ж, и такие советы тоже не так уж и плохи. Спасибо. Ближайший аналог: разработка с закрытыми dll или com-компонентами. В свой проект вы можете добавить закрытый код. Но не можете его изменить. Вы можете создать свой охватывающий объект. Но не можете изменить поведение другого стандартного кода, который использует закрытый код (вернее можете. но выполнив закат солнца вручную) и скорее нужно искать приемы разработки с подобными закрытыми компонентами. Создал новую ветку Как правильно вести разработку в условиях, когда часть кода закрыта от изменения - Sys-слой в аксапте, закрытые codeunit в навике, extensions в MS CRM Если у кого есть соображения именно по unit-тестированию, велкам в эту ветку, котороая называется: Как правильно выполнять unit-тестирования методов с параметрами по умолчанию на ваш взгляд? |
|
20.03.2017, 11:03 | #2 |
Участник
|
Цитата:
Сообщение от mazzy
Как и все подобные книги, авторы исходят из предположения, что код можно и нужно менять. Как я уже говорил в самом начале этой ветки, для dynamics продуктов это предположение неверное.
Так в аксапте нельзя менять сигнатуры методов, которые находятся в sys-слоях. Причем нельзя менять не только клиентам и партнерам. Нельзя менять и самому майкрософту, чтобы не потерять совместимость кода. \Classes\RunBase\dialog в AX2009: X++: protected Object dialog(DialogRunbase _dialog = null, boolean _forceOnClient = false) X++: protected Object dialog() Цитата:
По мне - умерла, так умерла: если надо существенно поменять сигнатуру стандартного метода, то надо это сделать - и по возможности использовать нормально типизированные параметры, а не безликие boolean-флажки, чтобы компилятор заметил несоответствия в вызывающем коде, а еще лучше, по-моему, вместо хрендцати параметров использовать data transfer objects (DTO), в которые можно добавлять новые свойства, не переделывая каждый раз сигнатуру вызываемого метода. Извините, что не в тему, наболело. Последний раз редактировалось gl00mie; 20.03.2017 в 11:34. Причина: typo |
|
20.03.2017, 11:43 | #3 |
Участник
|
Цитата:
Цитата:
вуаля, ответ готов. самое интересное, как всегда, не что сказано, а что пропущено. )))) Цитата:
Цитата:
про майкрософт - согласен. про "добавление параметров по умолчанию" - по прежнему считаю, что это очень распространенный подход в аксапте Цитата:
Сообщение от gl00mie
По мне - умерла, так умерла: если надо существенно поменять сигнатуру стандартного метода, то надо это сделать - и по возможности использовать нормально типизированные параметры, а не безликие boolean-флажки, чтобы компилятор заметил несоответствия в вызывающем коде, а еще лучше, по-моему, вместо хрендцати параметров использовать data transfer objects (DTO), в которые можно добавлять новые свойства, не переделывая каждый раз сигнатуру вызываемого метода.
А как это эффективно и правильно сделать в существующем инструментарии? И с существующим унаследованным кодом? Собственно тема как раз про это ) |
|
20.03.2017, 11:51 | #4 |
Участник
|
|
|