Различные ошибки при разработке в предприятии

17.03.25

Разработка - Рефакторинг и качество кода

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

Может, я и детский лепет решила писать. Если что, извиняюсь, но просто уже "Крик души".

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

 

Типичные ошибки:

1. Поле объекта не обнаружено

2. Метод объекта не обнаружен

3. Неверный параметр "ИзмеренияОсновногоРегистра" (измерение 1 не соответствует ни одному из измерений основного регистра)

4. Запись не верна! Вид субконто "ВидНоменклатуры" не доступен для данной записи (Регистр бухгалтерии: Хозрасчетный; Номер строки: 1)


Регистр расчета.

Начнем про неверные параметры регистра расчета. Проводим начисление зарплаты, и вылетает такой Привет.

 

 

Если нажать  Подробно и Конфигуратор, то выкинет на соответствующий вид расчета, где и была ошибка. А теперь вчитываемся по буквам в Массив Измерений и в данные регистра, думаю, все теперь ясно.

 

 

Здесь, конечно, нарушены и стандарты разработки. Режет глаз. Но поскольку это чисто набросок, то думаю, этот стандарт мы все же опустим.  На итоговой кураторы, думаю, точно такого не допустят, если студент до неё дойдет, конечно)))

 

Регистр бухгалтерии

Запись не верна! Вид субконто "ВидНоменклатуры" недоступен для данной записи (Регистр бухгалтерии: Хозрасчетный; Номер строки: 1)

 

 

Здесь типичная ошибка  платформы. И это не новинка. Слетают настройки субконто. У регистра расчета, к слову, тоже могут слетать настройки планов видов расчета. Не встала база для данного вида расчета и дело с концом. Ошибки  не вылезет, просто  результат будет  0 или null. Найти это можно только в процессе отладки.

PS: Живой пример, когда мы создаем ВидРасчета, например, Премия, который зависит от базы (оклада). Так вот, когда мы ставим базовые виды Расчета для той же Премии, они могут не встать, в итоге база Null и результата нет, либо  результат 0, если мы вооружились на нужное нам числовое поле функцией ЕстьNull(). В процессе отладки мы найдем, что база нулевая, но ведь мы в конфигураторе все настройки сделали! Но увы, и в предприятии нужно проверять.

Переходим к субконто, мы настроили в конфигураторе:

 

 

Но, о чем сказано выше, полезли в предприятии

 

 

А там пусто, в связи с чем и вылазит данная ошибка. Причем, может, предприятие скорее всего не даст создать данное субконто, так как ключ уже есть (в конфигураторе) и создать его вновь в предприятии будет дублем неуникальности. Такие ошибки нужно переделывать в конфигураторе и следить, чтоб все встало в предприятии. Или даже если  пробовать через предприятие, то в конфигураторе все равно нужно  убрать.

 

Регистры накопления.

Поле объекта не обнаружено

 

 

Если выдает кнопки Подробно и Конфигуратор, то лучше по ним пройтись, там сразу выкинет в нужное место кода.

 

 

Если всмотреться, то у объекта не поля Записать, есть Свойство Записывать(), который ставим в истину для того, чтобы осуществлялась запись в регистр методом Записать().

 

 

Опять ошибка. По ходу человек решил скопировать движения с одного регистра для другого регистра, не всмотревшись в их структуру. Первый регистр был с типом остатки. Мы же сейчас пишем данные в регистр с типом обороты. У оборотного регистра нет Вида Движения, как и остатков соответственно, поэтому и ошибка. Данную строку можно просто удалить, так как оно не нужно в данном случае.

 

 

Итого нас выкинет через подобно на строку:

Движение.Склад = Склад;

Смотрим скриншот выше и смотрим структуру регистра, куда пишем.

То, что слева Движение... это данные регистра, то, что после знака = это данные вашего документа. В документе видим склад есть - оптовый, но в регистре где склад? Потому и ошибка.

 

 

Также хочется поговорить о привязках процедур в модулях.

 

 

Спрашивается, откуда это? Мы всего лишь нажали кнопку Добавить на форме.

Преобразование значения к типу Число не может быть выполнено
{ОбщийМодуль.Расчеты.Модуль(12)}:СтоимостьСоСкидкой = Сумма - Скидка;
{Документ.РеализацияТоваровИУслуг.Форма.ФормаДокумента.Форма(17)}:Массив = Расчеты.РассчитатьСтоимость(Элементы.Товары.ТекущиеДанные.ЦенаРеализации,Элементы.Товары.ТекущиеДанные.Количество);

[ОшибкаВоВремяВыполненияВстроенногоЯзыка, ОшибкаИспользованияВстроенногоЯзыка]

Процедуры на форме состоят из нескольких имен. К имени поля клеится еще событие, а если есть ТЧ, то вставляется имя табличной части. Например СкладПриИзменении, ТоварыКоличествоПриИзменении, ТоварыСуммаПриИзменении. Привязывается процедура в свойствах на закладке События. Выделяем соответствующее поле и жмем лупу.

В данном случае мы при изменении табличной части уже обратились к подсчету себестоимости для... расчета данных о товаре, который еще не внесен. В данном случае у нас  значение отсутствует,  без типа данных это Null.  Поэтому выскакивает  данная ошибка.  Null это отсутствие значения, которое непонятно даже платформе.  То есть расчет  стоимости и скидки мы делаем ПриИзменении() соответствующих полей, но тут оно излишне, это вариант как в каждую бочку затычка, но лучше взвешивать подобное. 

 

 

Итого, такие вещи сразу убираешь. Этот код должен быть для подсчета, но в процессе вылезает еще одна ошибка

 

 

Проверяем.. На форме имя правильное, в объекте тоже:

 

 

Интересно, в документе у нас ЦенаРеализации, в общем модуле просто Цена. Но процедура в привязке стоит ТоварыЦенаПриИзменении(), то есть мы сначала создали реквизит, привязали процедуру, а потом переименовали реквизит. Так лучше не делать. Кроме того, что вызов на форме не на месте, так как она должна вызываться при изменении другого поля. Другой раз неправильная привязка к событию  может  давать  хорошие баги. Как здесь например вызов расчета себестоимости  при изменении каждого поля. Добавлю следующее:

Когда  вызываем процедуру из общего модуля, то переменные должны сопоставляться по типу в строгой последовательности.

Плюс учитывая  в общем модуле Директиву &НаКлиенте, я бы все таки делила бы эти вещи отдельно на клиентские и серверные. Хоть и в типовых бывает что объединяют, но без знания дела эти вещи могут закончиться багами, поэтому лучше делить.

Про Вариант Null так же добавлю, что  все что платформе неизвестно, любое отсутствие значения это Null, Поэтому всегда прописываем тип данных. А если есть риск отсутствующего значения, то  есть функция ЕстьNull(), с помощью которой можно так же вывести число 0 или даже текст, если вдруг нужно. Оговаривается данных функционал по теме запросов.

 

Настройки Сервер, Клиент, ВызовСервера, Экспортные функции

Также другой раз не всегда соображаем, куда копнуть при вызове процедур из общих модулей.

 

 

Как это не вызвать? Полезли в общий модуль.

 

 

Галки Сервер и вызов сервера есть. Если стоит Сервер и клиент, то писала выше, что на начальном этапе изучения лучше делить. В Типовых совмещают, но как.. рано или поздно может поймем, но  пока лучше по отдельности изучать для понимания.

Итого галки все  нужные стоят, переменные по порядку  сделаны как надо.. А... Мы для вызова процедуры из общего модуля забыли её сделать экспортной. То есть по сути в общих модулях мы ставим процедуры экспортными, чтоб к ним обращаться с любого места и не кодить в каждой справке/документе один и тот же код. Прописываем ЭКСПОРТ

Это как минимум тех ошибок, которые просматриваешь каждый день, помимо  своей Итоговой работы. Но куда ж без помощи студентам)))

См. также

HighLoad оптимизация Рефакторинг и качество кода Технологический журнал Программист Платформа 1С v8.3 Россия Бесплатно (free)

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

19.03.2025    1069    EFSOL_oblako    2    

4

DevOps и автоматизация разработки Рефакторинг и качество кода Тестирование QA Программист Платформа 1С v8.3 Бесплатно (free)

Расскажу, почему осознанно не буду внедрять SonarQube в свой рабочий процесс несмотря на то, что инструмент очень понравился. Статей, как его внедрили и используют, много. А почему внедрили, попробовали и отказались, по-моему, еще не было.

12.03.2025    992    ovetgana    23    

-4

Нейросети Рефакторинг и качество кода Тестирование QA Программист Платформа 1С v8.3 Бесплатно (free)

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

11.03.2025    3720    mrXoxot    50    

41

Рефакторинг и качество кода Тестирование QA Программист Платформа 1С v8.3 Бесплатно (free)

В последней статье по докладу Александра Кириллова, с которым он выступил на конференции INFOSTART TECH EVENT 2024, обсудим особенности тестирования после завершения рефакторинга платформеннозависимого кода

11.03.2025    435    it-expertise    0    

3

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

Расширяемый форматтер структуры модулей 1С. Умеет автоматически расставлять стандартные области и раскидывать по ним процедуры и функции модуля, оформлять стандартные комментарии к методам с помощью ИИ. Также умеет анализировать модуль - извлекать структуру вызовов, используемые поля и т.д. Реализован в виде расширения (.cfe). Можно использовать как платформу для обработки кода в своих задачах автоматизации разработки.

12.02.2025    6685    433    wonderboy    44    

118

Linux Рефакторинг и качество кода Программист Платформа 1С v8.3 Бесплатно (free)

В третьей статье по докладу Александра Кириллова, с которым он выступил на конференции INFOSTART TECH EVENT 2024, обсудим подходы к рефакторингу платформеннозависимого кода

11.02.2025    1010    it-expertise    0    

3

Рефакторинг и качество кода Linux Программист Платформа 1С v8.3 Бесплатно (free)

Во второй статье по докладу Александра Кириллова, с которым он выступил на конференции INFOSTART TECH EVENT 2024, поговорим об особенностях анализа конфигурации 1С на наличие платформеннозависимого кода.

31.01.2025    1686    it-expertise    1    

8

Рефакторинг и качество кода Обновление 1С Программист Платформа 1С v8.3 Бесплатно (free)

В практике нашей специальной команды по проектам сложных обновлений 1С прошел один из самых объёмных проектов: необходимо было обновить «1С: Бухгалтерия предприятия КОРП 3.0 + БИТ.ФИНАНС». Конфигурация содержала доработки практически по всем типам объектов метаданных. Длительность проекта составила 1 год и 2 месяца и обеспечила полной загрузкой 4 разработчиков на 6 месяцев.

31.01.2025    1213    1c-izh    3    

5
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Восьмой 92 18.03.25 14:01 Сейчас в теме
Молодец Лен, так держать!
2. nuctoh 31 18.03.25 22:43 Сейчас в теме
Извините, но это разраб со стажем в месяц орет с разраба со стажем в неделю.
PS: NULL это не пустое значение, а отсутствие значения в БД.
Bukaska; chrnv; +2 Ответить
3. Bukaska 147 19.03.25 18:32 Сейчас в теме
(2) Спасибо за замечание. Исправила. Каждый понимает по разному. Главное понимать, как с этим работать. Отрицательный результат тоже результат, даже если толком ничего не понятно и неизвестно.
4. nuctoh 31 19.03.25 22:39 Сейчас в теме
(3) Спасибо, конечно, за исправление, только оно некорректно )) Null вполне понятен и платформе и должен быть понятен разработчику. Null это отсутствие записи в БД. Так что если какая-то функция возвращает null, к примеру ПолучитьЦенуНоменклатуры, то этот null можно трактовать как отсутствие цены в регистре ЦеныНоменклатуры и сообщить пользователю.
Но предыдущий мой коммент посвящен вовсе не null, а довольно наивному и с ошибками решению простой задачи расчета суммы в строке товаров. И там целый ворох косяков:
1. Ошибка. Нет проверки на Неопределено у Элементы.Товары.ТекущиеДанные. При удалении строки или очистке таблицы событие Товары.ПриИзменении тоже выстреливает. В пустой таблице выделенной строки нет, так что вылетит ошибка.
2. Нет нужды каждый раз пересчитывать сумму при изменении любого поля у ТЧ. Гораздо правильней потрудиться и повесить расчет на события ТоварыЦенаПриИзменении и прочие, от которых может зависеть сумма. Во-первых, при расчете сумм (особенно со скидками, как в примере) может быть сложный расчет, дергающий БД, а зачем нам лишний серверный вызов, если мы просто хотим коммент в строке приписать? Во-вторых, это в нашем ванильном примере пять строк исполняются мгновенно, а когда вы дорастёте до ERP с процедурами по несколько сот строк, размазанных по модулям, то отзывчивости некомпилируемому языку 1С это не добавит.
3. Если уж мы возвращаем некий сложный набор данных как в случае функции РассчитатьСтоимость, то зачем массив с фикс данными? Чтобы разработчик не догадался что в нем за данные, когда отладчиком будет бежать? Или чтобы получить непонятную ошибку Элемент по индексу не определен, если кто-то криво изменит нашу функцию? Почему не вернуть структуру с полями Сумма, Скидка и СтоимостьСоСкидкой?
4. Зачем вообще &клиентская РассчитатьСтоимость нам чтото возвращает? Мы можем объявить ее процедурой без параметров и в ней получая текущие данные строки рассчитать стоимость и сразу же поместить в соотв поля. Так вы замените 4 строки в каждом событии ТоварыПолеПриИзменении (а их наверно будет минимум три - для полей Количество, Цена и Скидка) на одну, сэкономите себе 9 строк кода и, главное, поместите всю логику в одно место.
5. Зачем объявлять эту функцию экспортируемой? Экспортируемой нужно делать только процеруры, вызываемые обработчиками ожиданий. Нет, конечно, если вы получили где-то во внешнем модуле форму документа и программно добавляете в нее строки и считаете суммы, то экспортировать надо. Но этот стиль называется "макаронная фабрика". Если уж надо отправить в форму какие-то данные и их обработать, то лучше воспользоваться событием ОбработкаОповещения формы и соответственно методом Оповестить во внешнем модуле.

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

В общем, успехов вам в изучении 1С и движения по карьере. Но торопитесь! Код такого качества уже выдает любая передовая нейросетка типа deepseek, qwen или простихоспади chatgpt!
5. Bukaska 147 20.03.25 09:48 Сейчас в теме
(4) Я пишу про те студенческие реалии, что сама каждый день вижу. Они могут быть неоптимальны, но сделаны для того, чтоб студент познавал механизмы для понятия. Здесь указаны вещи, что допускают студенты сплошь и рядом. Важно чтоб студент понимал, где ошибка и почему, а не кричал в учебном чате умывая руки. Базы временами, что черт ногу сломит, это еще цветочки. В общем я вроде пояснила ситуацию.
Оставьте свое сообщение