Отладка/доработка модуля менеджера "на лету"

23.10.16

Разработка - Инструментарий разработчика

Данный прием позволяет отлаживать и дорабатывать модуль менеджера во внешней обработке без необходимости пересохранять конфигурацию и перезапускать базу

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Отладчик (ОФ+УФ)
.epf 18,70Kb
17
17 Скачать (2 SM) Купить за 2 150 руб.
Отладчик (только ОФ)
.epf 14,17Kb
1
1 Скачать (1 SM) Купить за 1 850 руб.
Отладчик (только УФ)
.epf 14,00Kb
7
7 Скачать (1 SM) Купить за 1 850 руб.

Постановка задачи

Предположим, что мы дорабатываем базу с очень тяжелой конфигурацией. Сохранение и/или перезапуск после сохранения выполняются продолжительное время.
Пусть есть модуль менеджера некоторого объекта в нашей конфигурации. В этом модуле менеджера есть экспортный метод, из которого вызываются остальные процедуры.
Необходимо доработать этот модуль менеджера. При этом требуется минимизировать количество перезапусков базы после каждого внесения изменения в код в процессе отладки.

Суть решения

- Скопируем весь код модуля менеджера во внешнюю обработку
- Добавим возможность переадресовывать вызовы экспортных методов модуля менеджера во внешнюю обработку (максимально простым способом)
- Переадресацию будем включать/отключать из отладчика с помощью механизма остановки по условию

Шаг 1
Предлагаю добавить в начало метода, который является точкой входа, следующий код:

// Модуль менеджера некоторого объекта конфигурации

Процедура Печать(Параметры) Экспорт

	// ++ отладка
	Перем Отладчик;

	Если Отладчик <> Неопределено Тогда
		Отладчик.Печать(Параметры);
		Возврат;
	КонецЕсли;
	// -- отладка
	
	Сообщить("Это вызов из модуля менеджера");

КонецПроцедуры

Шаг 2. 
Далее создаем служебную универсальную внешнюю обработку, например, в какой-нибудь папке на сервере. Назовем ее Отладчик.epf
В этой обработке опишем короткую универсальную экспортную функцию примерно следующего содержания:

// Модуль обработки Отладчик.epf

Функция УстановитьМодульОтладки(Отладчик, ИмяМодуля) Экспорт
	
	Отладчик = ВнешниеОбработки.Создать(ПутьКВнешнейОбработке(ИмяМодуля), Ложь);
	
	Возврат Ложь;
	
КонецФункции

Функция ПутьКВнешнейОбработке(ИмяМодуля)

	Возврат ТекущийКаталог() + ИмяМодуля+ ".epf";

КонецФункции

Функция ТекущийКаталог() Экспорт
	
	Файл = Новый Файл(ЭтотОбъект.ИспользуемоеИмяФайла);
	Возврат Файл.Путь;
	
КонецФункции


Шаг 3.
Создадим внешнюю обработку, в которой будем писать наш код. Копируем в модуль объекта этой обработки код из модуля менеджера полностью.
Сохраним ее в той же папке, что и Отладчик.epf. Зададим для этой обработки имя, например, такое Обработки.ПечатьСчета.МодульМенеджера.epf.

// модуль объекта внешней обработки Обработки.ПечатьСчета.МодульМенеджера.epf

Процедура Печать(Параметры) Экспорт

	// ++ отладка
	Перем Отладчик;

	Если Отладчик <> Неопределено Тогда
		Отладчик.Печать(Параметры);
		Возврат;
	КонецЕсли;
	// -- отладка
	

	// ++ исправили
	//Сообщить("Это вызов из модуля менеджера");
	Сообщить("Это вызов из внешней обработки");
	// -- исправили

КонецПроцедуры

Шаг 4.
В модуле менеджера ставим точку останова по условию. В условие прописываем следующий код:

ВнешниеОбработки.Создать("C:\Отладка\Отладчик.epf", Ложь).УстановитьМодульОтладки(Отладчик, "Обработки.ПечатьСчета.МодульМенеджера")


Шаг 5.
Запускаем тестовый пример. В точке останова будет вызвана проверка условия. При этом в переменную Отладчик присвоится объект созданной внешней обработки Обработки.ПечатьСчета.МодульМенеджера.epf. Это приведет к тому, что условие Если Отладчик <> Неопределено Тогда выполнится, и вызов будет переадресован во внешнюю обработку.

Шаг 6.

Дорабатываем и отлаживаем код во внешней обработке, при этом не тратим время на перезапуск после каждого сохранения. 

После окончания доработок - заменяем код в модуле менеджера на код из внешней обработки (полностью).

Не забываем отключить точки останова по условию.

Перед помещением в хранилище можно удалить отладочную часть в модуле менеджера. 

  

Область применения

Таким способом можно отлаживать и дорабатывать модули менеджеров любых объектов и общие модули (серверные).
Для отладки модулей объектов используется похожая технология, но при этом имеется ряд нюансов и ограничений.

Файлы

Прикладываю внешнюю обработку Отладчик.epf, которая кроме описанной выше функции имеет еще несколько полезных возможностей. В том числе умеет создавать пустую обработку-шаблон с именем, соответствующим дорабатываемому объекту

Обработка открывается в режиме управляемого и обычного приложения в любой конфигурации. 
Тестировалась на платформе 8.3 в режиме совместимости с 8.2.13. То есть должна работать под 8.2 и 8.3

Универсальные процедуры универсальные функции отладка инструменты инструментарий

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

15500 руб.

02.09.2020    178737    988    403    

948

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    20270    133    74    

134

Пакетная печать Печатные формы Инструментарий разработчика Программист Платформа 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Инструмент, позволяющий абсолютно по-новому взглянуть на процесс разработки печатных форм. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и "прозрачность" разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    19024    51    19    

83

Инструменты администратора БД Инструментарий разработчика Роли и права Программист Платформа 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

15000 руб.

10.11.2023    12982    53    33    

72

Инструментарий разработчика Программист Платформа 1С v8.3 Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    29203    100    48    

146

Инструментарий разработчика Программист 8.3.14 Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

20000 руб.

07.10.2021    18711    7    32    

43

Инструментарий разработчика Платформа 1С v8.3 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    1833    2    0    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. dj_serega 394 23.10.16 19:56 Сейчас в теме
2. Swetlana 27 23.10.16 20:36 Сейчас в теме
не вижу идею((
maksa2005; dnkon; Serj1C; iov; Alien_job; корум; +6 Ответить
4. json 3365 23.10.16 21:28 Сейчас в теме
3. Alister 10 23.10.16 21:06 Сейчас в теме
Как бы и всем остальным идею оценить.)))
Neuroproton; +1 Ответить
5. json 3365 23.10.16 21:43 Сейчас в теме
(3) Alister, нет ничего проще.

1. Просто попробуйте доработать проведение документа в ерпи на среднестатистическом тестовом сервере.
Посчитайте количество перезапусков, которое вы делаете на этапе отладки и умножьте это количество на время перезапуска.

2. А после этого попробуйте проделать все то же самое по описанной выше технологии.
3. Почувствуйте разницу.

ps. ВСЕМ не оценить, т.к. с тяжелыми конфигурациями [к счастью] работают не ВСЕ.
Brawler; Восьмой; cleaner_it; Сурикат; Quasar; +5 Ответить
8. Alister 10 24.10.16 12:27 Сейчас в теме
(5) первые посты были не от того, что идея какая-то не такая, а потому что из-за нового интерфейса пропала кнопка перехода к самой публикации из коментов, вот и не понятно было в чем состоит идея - просто не знали, как в публикацию перейти, а в лучших из новых она еще не появилась.
корум; json; +2 Ответить
10. json 3365 24.10.16 12:38 Сейчас в теме
(8) Alister, теперь ясно)
А я то с форума не перехожу, поэтому и не понял в чем фишка
6. citicat 119 24.10.16 08:57 Сейчас в теме
Спасибо большое! При работе с УПП и шести одновременно работающих пользователях (или КА и двенадцати одновременно работающих пользователях) полезный инструмент.
7. jaroslav.h 181 24.10.16 09:41 Сейчас в теме
ай бомбец, какой бомбец, не знал, попробовал, шик, дякую!
9. Alister 10 24.10.16 12:30 Сейчас в теме
(0) вот, когда появился нулевой комент, то и кнопка перехода к публикации появилась.)))
11. herfis 515 24.10.16 12:50 Сейчас в теме
Использование условной точки останова в т.ч. в качестве переключателя developer/production - остроумный ход, упрощающий использование идеи.
Но с другой стороны - выполнение подмены на сервере требует сервера в режиме отладки.
Возможно, имеет смысл усложнить идею, чтобы обойти это ограничение.
headMade; +1 Ответить
12. json 3365 24.10.16 13:30 Сейчас в теме
(11) herfis, думал использовать для этого хранилище настроек.
Но схема при этом сильно усложняется. Нужно больше кода писать для переадресации и инструмент запуска делать более навороченный.
Пока этот вариант устраивал, не стал заморачиваться.

У вас уже есть наработки или идеи по этому поводу?
13. herfis 515 24.10.16 15:12 Сейчас в теме
(12) Наработок и идей нет. Идея использования хранилища настроек вполне нравится.
Да, удобный инструмент (обработку) для администрирования отладки придется делать навороченным. Чем удобнее его делать, тем более навороченным он будет.
Основной код переадресации для минимизации самой заглушки можно запихнуть в хранилище настроек тоже и вызывать через Выполнить().
Главный минус, который вижу - после отладки отладочный код будет очень желательно удалить (в отличие от сабжевого решения, где можно его "бесплатно" оставить).
14. vec435 17 26.10.16 08:43 Сейчас в теме
использование 1 внешней обработки с кучей доп модулей существенно упрощает отладку и разработку. Например поменять значение переменной "на лету".
Но почему нельзя напрямую из конфигуратора в нужной точке останова вызвать ВнешниеОбработки.Создать("C:\Отладка\Отладчик.epf", Ложь).печать(параметры, допПараметры)? Плюс в том что исходный код не переписывается.
15. json 3365 26.10.16 09:15 Сейчас в теме
(14) vec435, я вижу несколько причин, почему неудобно делать, как вы предлагаете:
- так можно вызвать только функцию. Если Печать была бы процедурой, то через вычислить выражение её было бы не вызвать
- часто бывает, что дорабатываемый модуль является промежуточным звеном и после него вызываются другие, например при проведении в типовых
- бывает, что за экспортной процедурой тянется куча других. У меня так было, когда я дорабатывал модуль ПартионныйУчет в ерпи 2.1
- также считаю неудобным вписывать в точке останова вызываемый метод, т.к. при опечатке трудно увидеть ошибку, а также в случае, если у функции большое число параметров
- функция печать может возвращать параметр отличный от булевского

Но если требуется только изменить значение переменной, то можно использовать ваш метод и не вносить изменения в код вообще

Т.о.считаю описнный в статье подход более универсальным
16. vec435 17 26.10.16 16:33 Сейчас в теме
из функции "ФункПечать" можно вызвать процедуру "печать" во внешней обработки
вызываемый метод в любом случае вписывается в вызов "руками" или копируется из какого-то места
можно передать как допПараметр объект и вызывать другие функции

и мы выполняем отладку дорабатываемого модуля - т.е. отладили, получили необходимый результат - перекинули в исходный модуль и дальше смотришь

и опять -таки "исходный код не переписывается" !!!!
17. json 3365 26.10.16 17:06 Сейчас в теме
(16) vec435, признаю, что был не прав, что можно отлаживать только функции.
А как предложите поступить, чтобы прервать процедуру? Например, в примере с печатью мы получим сначала доработанную версию табличного документа, а затем исходную.
Или предположим еще одна ситуация: мы вызываем экспортную функцию, которая возвращает значение. Возникает ряд случаев, когда нельзя просто так взять и подменить результат.
Или еще одна ситуация, пусть в нашу процедуру передается таблица, которую мы должны заполнить в этой процедуре. В этом случае нельзя, чтобы одновременно выполнилась и встроенная и внешняя версии модуля.

Но в общем согласен. Подход, предложенный вами мне нравится. В большинстве случаев можно обойтись вообще без изменения исходного модуля, но только придется проявлять долю изобретательности от раза к разу.
18. vec435 17 27.10.16 12:11 Сейчас в теме
согласен, сложностей хватит и в том и другом случае. Если есть возможность изменить конфигурацию - то возможно ваш и лучше. Но в таком случае можно выставить прерывание выполнения исходного модуля и выполнить только внешнюю процедуру - изменение исходного модуля минимум
19. wojwoo 70 31.10.16 17:32 Сейчас в теме
(0) Спасибо!
Благодаря Вам, написал свою первую статью о своих вариантах борьбы со стоимостью перезапуска 1С при разработке в УПП (http://infostart.ru/public/558702/)
20. json 3365 31.10.16 18:38 Сейчас в теме
(19) wojwoo, я пока еще не успел описать отладку форм. Это пока в планах.
При отладке необходимо минимизировать количество отладочного кода, который вам потом придется удалять. Так вот, предлагаю вам подумать, как можно реализовать отладку форм вообще без модификации самой формы. Т.е. чтобы доработать-отладить форму в нее можно не добавлять отладочный код вообще.
21. wojwoo 70 01.11.16 15:25 Сейчас в теме
(20)
В моем примере «Быстрое редактирование и отладка формы документа» в дорабатываемой форме (документа или справочника) отладочного кода нет.
Форма копируется во внешнюю обработку и после внесения доработок возвращается в конфигурацию без дополнительных модификаций.
Для удобной отладки в обработку дополнительно копируется форма списка, в которую вносится дополнительный код, чтобы запускать дорабатываемую форму, а не форму в конфигурации. Этот код фактически без модификаций может быть применен для любой формы списка, т.е. может использоваться как шаблон.
Считаю, что задачу минимизации количества перезапусков базы после каждого внесения изменения в код в процессе отладки мой вариант решает.

Если вариант с дополнительным копированием формы списка представляется громоздким и предполагается отладка на одном объекте в событии «ПередОткрытием» формы прописать всего 1 строчку, которую, естественно, нужно удалить перед возвратом формы в конфигурацию:
ДокументОбъект = Документы.ИмяДокумента.НайтиПоНомеру("НомерДокумента", ТекущаяДата()).ПолучитьОбъект();
Или
СправочникОбъект = Справочники.ИмяСправочника.НайтиПоКоду("Код").ПолучитьОбъект();


PS
Поясните, пожалуйста, причину просьбы удалить Вашу фамилию и имя из текста моей статьи.
22. MarSeN 987 08.10.19 10:31 Сейчас в теме
+1
Увидел принцип перенаправления выполнения кода, который месяц назад заюзал для своей консольки кода на УФ.
Значит не только у изветсных персонажей мысли сходятся.
Возможно скоро выложу свой вариант, только хочу его как опенсоурс проектик сделать чтоб каждый жедающий мог приложить к нему руку )
А рук там нужно много )
23. amiralnar 9 31.01.24 10:07 Сейчас в теме
Потрясающе! Очень полезная возможность.

Прошу пояснить для чего нужно на 3 шаге прописывать в отладочной обработке блок переадресации
Прикрепленные файлы:
24. ShootNICK 14 26.03.24 17:42 Сейчас в теме
Скучаю по #ЗагрузитьИзФайла в начале модуля =)

Сейчас бы все сразу в git
Оставьте свое сообщение