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

23.10.16

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

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

Скачать файлы

Наименование Файл Версия Размер
Отладчик (ОФ+УФ)
.epf 18,70Kb
16
.epf 18,70Kb 16 Скачать
Отладчик (только ОФ)
.epf 14,17Kb
1
.epf 14,17Kb 1 Скачать
Отладчик (только УФ)
.epf 14,00Kb
6
.epf 14,00Kb 6 Скачать

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

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

Суть решения

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

Шаг 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

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

См. также

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

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

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

13000 руб.

02.09.2020    119918    656    389    

701

Infostart PrintWizard

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

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

18000 руб.

06.10.2023    7008    20    6    

37

Infostart УДиФ: Управление данными и формами

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

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

10000 руб.

10.11.2023    3246    10    1    

31

SALE! 30%

PowerTools

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

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

3600 2520 руб.

14.01.2013    177341    1070    0    

846

Многопоточность. Универсальный «Менеджер потоков» 2.1

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

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    99204    239    97    

296

[ЕХТ] Фреймворк для Расширений 1С

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

"Фреймворк для Расширений 1С" это универсальное и многофункциональное решение, упрощающее разработку и поддержку создаваемых Расширений. Поставляется в виде комплекта из нескольких Расширений с открытым исходным кодом. Работает в любых Конфигурациях в режиме Управляемого приложения с режимом совместимости 8.3.12 и выше без необходимости внесения изменений в Конфигурацию.

3000 руб.

27.08.2019    17914    6    8    

38

1С HTML Шаблоны / HTML Templates

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

Быстрая и удобная обработка для работы с шаблонами HTML. Позволяет легко и быстро формировать код HTML.

2040 руб.

27.12.2017    27945    3    10    

14

Выполнение произвольного кода или запроса с параметрами через Web-сервис (замена COM-подключений)

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

В процессе работы в 1С часто возникает потребность получить данные из другой базы.  Обычно это делается через COM-соединение, и время выполнения запроса при этом оставляет желать лучшего. В данной публикации представлено универсальное решение, позволяющее практически моментально выполнить произвольный код или запрос с параметрами в другой информационной базе через Web-сервис.

2400 руб.

24.09.2019    23490    15    15    

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

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

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

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

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

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

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

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

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

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

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


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

Прошу пояснить для чего нужно на 3 шаге прописывать в отладочной обработке блок переадресации
Прикрепленные файлы:
Оставьте свое сообщение