0. json 22.10.16 13:39 Сейчас в теме

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

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

Перейти к публикации

Комментарии
Избранное Подписка Сортировка: Древо
1. dj_serega 368 23.10.16 19:56 Сейчас в теме
2. Swetlana 10 23.10.16 20:36 Сейчас в теме
не вижу идею((
maksa2005; dnkon; Serj1C; iov; Alien_job; корум; +6 Ответить
4. json 23.10.16 21:28 Сейчас в теме
3. Alister 9 23.10.16 21:06 Сейчас в теме
Как бы и всем остальным идею оценить.)))
5. json 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 24.10.16 12:38 Сейчас в теме
(8) Alister, теперь ясно)
А я то с форума не перехожу, поэтому и не понял в чем фишка
6. citicat 119 24.10.16 08:57 Сейчас в теме
Спасибо большое! При работе с УПП и шести одновременно работающих пользователях (или КА и двенадцати одновременно работающих пользователях) полезный инструмент.
7. jaroslav.h 24.10.16 09:41 Сейчас в теме
ай бомбец, какой бомбец, не знал, попробовал, шик, дякую!
9. Alister 9 24.10.16 12:30 Сейчас в теме
(0) вот, когда появился нулевой комент, то и кнопка перехода к публикации появилась.)))
11. herfis 339 24.10.16 12:50 Сейчас в теме
Использование условной точки останова в т.ч. в качестве переключателя developer/production - остроумный ход, упрощающий использование идеи.
Но с другой стороны - выполнение подмены на сервере требует сервера в режиме отладки.
Возможно, имеет смысл усложнить идею, чтобы обойти это ограничение.
headMade; +1 Ответить
12. json 24.10.16 13:30 Сейчас в теме
(11) herfis, думал использовать для этого хранилище настроек.
Но схема при этом сильно усложняется. Нужно больше кода писать для переадресации и инструмент запуска делать более навороченный.
Пока этот вариант устраивал, не стал заморачиваться.

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

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

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

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

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

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

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


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

Вакансии

Программист 1С
Екатеринбург
зарплата от 90 000 руб. до 150 000 руб.
Полный день

Архитектор 1С
Нижний Новгород
зарплата от 180 000 руб.
Полный день

Разработчик 1С
Нижний Новгород
зарплата до 90 000 руб.
Полный день

Консультант-аналитик 1С
Москва
зарплата от 100 000 руб. до 150 000 руб.
Полный день

Автор новостных обзоров на тему 1С и бухучета
Санкт-Петербург
По совместительству