Олег Тымко: «Open Source помог мне прокачать навыки коллаборации и общения в сообществе»

22.06.2021      58643

На конференции Infostart Event 2021 Post-Apocalypse мы поговорили с ведущим разработчиком компании «Серебряная пуля» Олегом Тымко. Обсудили вопросы качества кода, развития Open Source проектов и основные принципы обмена знаниями в сообществе.

 

 

Представьтесь, пожалуйста, кто вы и в какой роли приехали к нам на конференцию.

Меня зовут Олег Тымко. Я приехал на конференцию в роли докладчика. Выступал с докладом по вскрытию статического анализа 1С и собираюсь проводить хакатон с OneScript.Web по разработке на языке 1С.

Который раз вы приезжаете на конференцию?

Я приезжаю третий раз. Два раза в роли докладчика, а один раз – просто в роли участника – слушал, ходил, смотрел, наблюдал.

Что вас привлекает на наших мероприятиях?

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

Находят ли применение услышанные здесь идеи в вашей работе?

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

Вы уже вторую конференцию для доклада выбираете тему анализа качества кода. Почему вы считаете, что это важно?

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

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

Если говорить об инструментах анализа кода, я один из участников сообщества 1c-syntax, где разрабатывается инструмент BSL Language Server, одно из направлений использования которого – это проверки. Соответственно, мы можем написать какие-то шаблоны, чтобы найти закономерность, чтобы выявить какой-то дефектный код – это может быть какая-то критическая ошибка или менее важная. Мне эта идея понравилась.

До этого я видел только «1С:Автоматизированную проверку конфигураций» и мне, к сожалению, не казалось удачной идеей там что-то в большом объеме разрабатывать. А для проекта BSL LS – правда, не на языке 1С, а на Java – удалось написать много проверок, которые существенно упростили разработку и поддержку в той компании, где я на тот момент работал. Все ошибки удавалось диагностировать сразу, до того, как они стрельнут в продуктиве. И, соответственно, я сэкономил время и тратил его на что-то другое, на что-то более интересное – либо было просто легче работать.

 

 

Насколько я знаю, проект BSL Language Server – это открытый проект, который развивается на GitHub, и кроме него вы участвуете и в других Open Source проектах. Как вы считаете, какую роль Open Source разработка играет в развитии сообщества?

Я в эту Open Source тусовку влился только в 2016 году. Это было не очень давно. К тому времени я уже прошел половину своего пути в 1С-разработке. Соответственно, меня заинтересовала тема OneScript, всех инструментов, написанных на нем. Мне Open Source помог прокачать навыки коллаборации, общения в сообществе, выяснения каких-то тем, прокачать навыки программирования вне экосистемы 1С. Получается, что 1С можно автоматизировать еще и другими способами, потому что одно дело – разработка, а другое дело – автоматизация разработки, чтобы экономить время. Как раз все эти библиотеки, скрипты на OneScript, попали в яблочко на 100%. Есть Vanessa-runner, который облегчает пакетный запуск, чтобы сократить рутинные действия. Например, с его помощью можно запустить расширенную проверку конфигурации – она хорошо выявляет критические ошибки. Нас вендор не обделил статическим анализом изначально, но не многие про это знают. Соответственно, через Vanessa-runner можно запускать пакетный режим одной читабельной строчкой, которая тебе выдает отчет, что у тебя внутри не так. Соответственно, если это писать на bash, на shell – получается простыня кода. А на OneScript все просто, понятно. Заходишь в код, и там можно разобраться, по крайней мере. В итоге такие инструменты мне очень понравились.

Могу рассказать про свой первый проект, который я написал на OneScript. Мой первый проект был Gitrules. Он решал следующую задачу – у меня были правила обмена 1С в формате «Конвертации данных 2.0». Была задача все это версионировать. Но, как мы знаем, xml-файл оказывается большим, а Git не умеет хорошо сравнивать эти xml-ки. И получается, когда добавляются какие-то куски кода, все разъезжается, и истории изменения нет.

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

Было написано приложение, которое берет этот xml-файл и разбирает его на файлы, как платформа делает с конфигурацией – она из бинарного документа своего внутреннего скобочного формата раскладывает это на xml-файлы. Соответственно, с ними уже можно как-то работать. Для меня это было хорошим способом себя прокачать в этой сфере, тем более, в Open Source, в рамках такого проекта. Вроде как получилось, помогло сэкономить время. Если бы я писал на другом языке, это было бы для меня намного дольше.

И главное – это помогло вам освоить Git?

Да, освоить Git на хорошем уровне – не просто скачать проект, а пользоваться merge, history, делать перебазирование – эти все специфические вещи, которые для 1С-ников кажутся чудными, даже если они используются в EDT. Эти навыки прокачались. Плюс я познакомился с сообществом, которое образовалось вокруг OneScript. Это было интересно, плюс всегда можно было спросить что-то, и тебя, как на Мисте, не отправляли далеко.

 

 

Вы используете при разработке в 1С какие-то технологии соседних стеков, помимо 1С, потому что платформе 1С чего-то не хватает?

Я веду разработку не только в 1С, я разрабатываю и на других языках – например, на Java. И в не-1С-мире есть много инструментов, которые нужны. Но за много лет существования того же OneScript накопилось множество инструментов, которые помогают в платформе решить такие банальные задачи – допустим, тестирование, поведенческое или модульное. Для этого уже есть готовые Open Source инструменты.

То же самое для снятия покрытия кода – раньше оно выполнялось через Sikuli. Снималась картинка, запускался замер кода, и потом этот отчет конвертировался уже в покрытие. Вообще, для чего нужно покрытие? Чтобы, когда мы что-то тестируем, мы были уверены, какую конкретно логику мы проверили. Например, у нас какое-то множественное условие, и мы проверяем, что мы его полностью покрываем в каких-то бизнес-кейсах.

Чего не хватает в платформе? В свободное время я разрабатываю проект, который называется phoenix-bsl. Смысл этого проекта следующий – так как конфигуратор не расширяемый, то была цель взять проект BSL Language Server, который умеет проверять исходный код – прогонять через свои проверки и выдавать какой-то результат. И мне захотелось, не выходя из среды разработки, получить результат этих проверок. Такие же возможности дает разработка в среде VS Code, там можно все это проверять через специальный плагин, но мне хотелось это делать прямо в конфигураторе.

К сожалению, платформа не предоставляет возможности использовать UI Automation для определения, что у нас открыто определенное окошко 1С, что я там могу выделить текст и что-то сделать с ним. Мне пришлось реализовывать это через «кнопконажималку» – чтобы проанализировать текст, мы в модуле нажимаем Ctrl+A, выделяем его весь, потом копируем его в буфер обмена, обрабатываем и получаем результаты проверок. Такая схема работает, но она не слишком удобная. Поэтому хотелось бы, чтобы в платформе появились открытые интерфейсы, которые позволили бы делать какие-то удобные инструменты под себя. Но, я думаю, что, скорее всего, этого не будет, потому что есть платформа EDT, которая расширяется через плагины, и, соответственно, я сомневаюсь, что в платформе это может появиться. Но хотелось бы.

Для EDT вы же тоже пишете плагины?

Для платформы EDT я написал два плагина, их можно посмотреть в открытом доступе. Первый плагин – для BSL Language Server. Он нужен, чтобы получать в рамках EDT те же самые проверки, но уже в более удобном виде. В конфигураторе проблема в том, что когда вы получаете список проверок, то не видите выделений, всей этой подсветки, которая иногда помогает. А в EDT эта подсветка есть из «коробки», и плагин умеет с ней работать. У нас случилась какая-то проблема на строчке, мы ее выделили определенным цветом, говорим – «Там ошибка, посмотрите, проверьте, что с этим можно сделать».

Второй плагин – это плагин интеграции с платформой SonarQube. Для SonarQube существует множество плагинов различных языков, в том числе, и языка 1С. Причем в качестве плагина для языка 1С в SonarQube можно использовать не только 1C (BSL) Community Plugin, но и коммерческий 1C (BSL) Plugin. В этом коммерческом проекте есть возможность работать по протоколу – вызывать его результаты из других сред, в том числе, из EDT. Этот подход называется SonarLint. Соответственно, можно запускать анализ через SonarQube со всеми настройками (хранить эти настройки централизованно). И проверять код через SonarQube прямо в платформе EDT – делать подсветку замечаний, смотреть их описание. Видеть всю эту информацию, не выходя из среды разработки.

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

А чем?

Документация написана для программистов, которые очень сильно знакомы с Java. Соответственно, если простой 1С-ник, который когда-то в институте изучал Java, захочет это написать, ему нужно сначала понять – что для проектов этих плагинов есть средство сборки maven; что есть репозитории в формате p2, где хранятся зависимости; что есть интеграционное тестирование, которого нет в нормальном виде для 1С; что нужно уметь писать тесты, которые будут открывать платформу EDT, прощелкивать все эти действия, которые мы можем делать ручками, и проверять на ожидаемое поведение. Это все для входа трудно, потому что, если ты этим не занимаешься, будет определенный дискомфорт и трата времени.

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

 

 

В этом году тема конференции – пост-Апокалипсис. Как на вас отразился кризис прошлого года? Открыли ли вы для себя какие-то возможности в этот период?

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

Но коронавирус сделал определенные положительные вещи – теперь многие компании хотят работать удаленно. Не важно, где ты живешь. Сейчас работодатели идут навстречу, и можно работать и удаленно. Этим я и воспользовался, сейчас я работаю полностью удаленно.

Какие направления развития вы выбираете для себя в этом году?

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

Несколько пожеланий нашим гостям конференции, участникам сообщества Инфостарт.

Я бы хотел пожелать, чтобы люди не боялись приезжать на конференцию. Из-за коронавируса у многих паранойя в этом плане: «Нет, я не поеду, там много народа, я боюсь, что все заразятся». На мой взгляд, это неправда. Мы приехали сюда, здесь все хорошо, все стараются ходить в масках. Все общаются. Хочется пожелать, чтобы люди чаще ездили на такие конференции, потому что, во-первых, это обмен знаниями. Во-вторых, можно не только посмотреть на интересные доклады, но и пообщаться между ними – какие-то темы интересные пообсуждать, какие-то новые вещи узнать.
 

https://infostart.ru/events/


Автор:
Аналитик


Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
Оставьте свое сообщение

См. также

ТерраЛинк – партнер конференции «Анализ и Управление в ИТ-проектах»

Новость Aнализ&Управление Мероприятия

Следующий партнер конференции, о котором мы хотим рассказать – компания «ТерраЛинк». Организация входит в ТОП-100 российских ИТ-компаний и в список крупнейших поставщиков ИТ-услуг.

сегодня в 15:00    45    AnastasiaKl    0       

1

Wazzup – партнер конференции «Анализ и Управление в ИТ-проектах 2024»

Новость Aнализ&Управление Мероприятия

Еще один партнер аналитической конференции Инфостарт – компания Wazzup. Команда Wazzup привезет с собой вкусняшки, которые обязательно поднимут настроение участников. А также выступит с докладом в секции «Кейсы крупных компаний».

24.05.2024    300    eselyanina    0       

15

Таймлист – партнер конференции «Анализ и Управление в ИТ-проектах 2024»

Новость Aнализ&Управление Мероприятия

Продолжаем знакомить вас с партнерами конференции «Анализ и Управление в ИТ-проектах». Сегодня мы расскажем про компанию «Таймлист», которая занимается с собственными разработками в сфере искусственного интеллекта и продемонстрирует свой продукт.

23.05.2024    422    eselyanina    0       

17

Собираетесь на конференцию «Анализ и Управление в ИТ-проектах»? Не забудьте ноутбук!

Новость Aнализ&Управление Мероприятия

В расписании конференции «Анализ и Управление в ИТ-проектах 2024» 61 слот занимают мастер-классы, практики, обсуждения и тренинги.

23.05.2024    423    user997184    0       

1

PROF-IT GROUP примет участие в конференции Анализ и Управление в ИТ-проектах 2024

Новость Aнализ&Управление Мероприятия

С 30 мая по 1 июня 2024 года в Санкт-Петербурге состоится конференция «Анализ и Управление в ИТ-проектах 2024». Один из партнеров конференции – PROF-IT GROUP. Компания представит собственный стенд и доклад в секции «Кейсы крупных компаний».

22.05.2024    501    user997184    0       

15

Как идет переход на 1С в «РЖД»: актуальный статус по проекту миграции на 1С:ERP

Новость ИТ-Новость

Глава правительства Михаил Мишустин и гендиректор «РЖД» Олег Белозеров обсудили, как идет переход на 1С для одного из крупнейших российских пользователей 1С:ERP. Критически важные возможности системы уже реализованы. Полный переход намечен на 2028 год.

22.05.2024    2992    ЕленаЧерепнева    5       

5

Звук из текста: новый механизм для синтеза речи уже доступен в 1С:Предприятие

Новость Сервисы ИТС

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

22.05.2024    593    ЕленаЧерепнева    0       

2

Розыгрыш эргономичного кресла Metta Y 4D Triumph на конференции «Анализ и Управление в ИТ-проектах»

Новость Aнализ&Управление Мероприятия

На конференции «Анализ и Управление в ИТ-проектах» Инфостарт разыгрывает эргономичное компьютерное кресло Metta Y 4D Triumph. Это кресло станет вашим надежным помощником в работе, обеспечивая комфорт и здоровье спины.

22.05.2024    453    AnastasiaKl    0       

1

Может ли недавно созданная ИТ-компания платить страховые взносы по льготному тарифу, если она применяет УСН

Новость УСН ИТ-льготы ИТ-Новость

Минфин ответил на вопрос, какие льготы по взносам может получить ИТ-предприятие на УСН с собственным программный продуктом, если оно зарегистрировано в начале 2024 года.

21.05.2024    573    user1915669    0       

1

Reksoft — партнер конференции «Анализ и Управление в ИТ-проектах 2024»

Новость Aнализ&Управление Мероприятия

Представляем еще одного партнера конференции «Анализ и Управление в ИТ-проектах» – компанию «Рексофт». В этом году компания не только выступит партнером события, но и подготовила для участников много интересного

21.05.2024    596    user1950500    0       

15

27 мая состоится открытый вебинар «Практический опыт внедрения и эксплуатации Tantor SE 1C»

Новость

Инфостарт организует бесплатный вебинар по работе с СУБД Tantor Special Edition 1С. Встречу проведут старшие пресейл-инженеры Tantor Борис Шишкин и Кирилл Иванов.

20.05.2024    929    user997184    0       

16

CDEK – партнер конференции «Анализ и Управление в ИТ-проектах 2024»

Новость Aнализ&Управление Мероприятия

За скорость и драйв на конференции будет отвечать компания CDEK. Команда ИТ-продуктов CDEK создает и масштабирует цифровые решения в финансах, e-commerce, маркетинге и логистике.

20.05.2024    560    eselyanina    0       

2

Гринатом – партнер конференции «Анализ и Управление в ИТ-проектах 2024»

Новость Aнализ&Управление Мероприятия

Сегодня поговорим о компании Гринатом: вас ждет доклад в секции «Кейсы крупных компаний» и, конечно, стенд. На стенде для участников подготовили логические задачки и подарки, Но самое ценное здесь – обмен опытом с коллегами. 

17.05.2024    1231    user997184    0       

15

Бесплатное обучение 1С для учителей: поддержка ИТ-образования и встраивание дисциплин в учебный процесс

Новость ИТ-Новость Образование

Фирма «1С» приглашает преподавателей среднего профессионального и высшего образования, а также учителей основного общего образования на бесплатное обучение по программе «Легкий старт». Обучение проводится в дистанционном формате.

17.05.2024    998    ЕленаЧерепнева    0       

2

Новое решение «1С:Обмен данными по учету животных с ФГИС ВетИС Хорриот»

Новость

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

17.05.2024    830    ЕленаЧерепнева    0       

2

КРОК – партнер конференции «Анализ и Управление в ИТ-проектах 2024»

Новость Aнализ&Управление Мероприятия

Команда КРОК уже не в первый раз приезжает на мероприятия Инфостарт в статусе партнера. В этом году на стенде компании всех участников ждет насыщенная программа и много нетворка с экспертами.

16.05.2024    1060    user997184    0       

16

Присоединяйтесь к курсу «1С: Библиотека стандартных подсистем для начинающих»

Новость Обучение

Обучение продлится 2 недели: первый вебинар состоялся вчера, 15 мая. Но у вас еще есть возможность присоединиться к обучению и не пропустить важное. 

16.05.2024    1063    user997184    2       

2

Как избежать проблем с автоматическим обновлением тонкого клиента 1С на старых версиях Windows

Новость Платформа 1С v8.3 Зазеркалье ИТ-Новость

Фирма «1С» предупредила, что при автообновлении тонкого клиента 1С с веб-сервера на некоторых старых версиях операционных систем Microsoft Windows может быть выведена надпись: «Не обнаружена цифровая подпись программы доступа».

15.05.2024    1209    ЕленаЧерепнева    0       

2

«СИТЕК» – партнер конференции «Анализ и Управление в ИТ-проектах 2024» 

Новость Aнализ&Управление Мероприятия

Продолжаем знакомиться с партнерами майской конференции Инфостарт для аналитиков и управленцев. На этот раз расскажем, что подготовила для нас компания «СИТЕК».

15.05.2024    1042    user997184    0       

15

Аутентификация с помощью электронной почты в 1С:Предприятие 8.3.27

Новость Зазеркалье

Официальный технологический блог разместил анонс новых возможностей платформы, которые ожидаются в 8.3.27. Разработчики обещают реализовать вход в систему по паролю, отправленному на электронную почту пользователя.

14.05.2024    1194    ЕленаЧерепнева    0       

1

ГК «КОРУС Консалтинг» – официальный партнер конференции «Анализ и Управление в ИТ-проектах 2024»

Новость Aнализ&Управление Мероприятия

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

14.05.2024    2159    user997184    0       

16

Бухгалтерия 3.0.152: настройка выплаты зарплаты и развитие интеграции с 1С:ДО 3

Новость 1С:Бухгалтерия 3.0 Новый релиз

Вышел очередной релиз прикладного решения 1С:Бухгалтерия 3.0.152. Разработчики добавили новую функциональность для настройки выплаты заработной платы, а также расширили возможности интеграции с 1С:Документооборот 3.0.

14.05.2024    948    ЕленаЧерепнева    0       

2

1С:MDM корпоративного уровня: новый продукт для управления мастер-данными

Новость

Вышел продукт «1С:MDM Управление мастер-данными КОРП». Решение позволит унифицировать НСИ для крупных распределенных компаний. Цена поставки для конечных пользователей будет зависеть от объема мастер-данных, используемых в централизованной базе.

13.05.2024    2721    ЕленаЧерепнева    1       

2

Онлайн-интенсив для новичков: быстрый старт в 1С-программировании 

Новость Обучение

4 июня стартует интенсив по 1С-программированию для новичков. Всего за 2 месяца участники курса научатся работать в самой популярной программе для автоматизации бизнеса «1С:Предприятие» и подготовятся к сдаче сертификационного экзамена 1С:Профессионал. 

13.05.2024    951    user997184    0       

15

Последний шанс купить билеты на конференцию «Анализ и Управление в ИТ-проектах 2024» со скидкой

Новость Aнализ&Управление Мероприятия

С 16 мая цены на участие в конференции «Анализ и Управление в ИТ-проектах 2024» изменятся. Если вы еще не успели купить билеты – не упустите последнюю возможность и воспользуйтесь финальной скидкой до повышения цены. 

13.05.2024    1104    user997184    0       

15