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

22.06.2021      58605

На конференции 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/


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


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

См. также

Купите участие в конференции «Анализ и Управление в ИТ-проектах 2024» до повышения цен

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

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

вчера в 11:30    180    user997184    0       

15

Разработка прикладных решений с помощью Библиотеки стандартных подсистем: курс по 1С-программированию

Новость Обучение Программист

15 мая стартует онлайн-курс «1С: Библиотека стандартных подсистем для начинающих». На курсе мы будем изучать инструментарий разработчика и создавать прикладные решения на основе Библиотеки стандартных подсистем (БСП).

24.04.2024    989    AnastasiaKl    0       

16

Знакомимся с модератором секции «Открытый микрофон» и продолжаем прием заявок

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

Секция «Открытый микрофон» обрела своего модератора – им стала постоянный докладчик конференций Инфостарт, Елена Дуюн. Знакомимся с Еленой поближе и напоминаем, как подать заявку на доклад для «Открытого микрофона», если вы еще этого не сделали.

23.04.2024    365    user997184    0       

15

Что будем осваивать в мае: онлайн-курс «1C:Предприятие для программистов: Запросы и отчеты»

Новость Обучение Программист

14 мая на Инфостарт начнется обширный онлайн-курс по запросам и возможностям системы компоновки данных в 1С:Предприятии.

23.04.2024    481    user997184    0       

16

Вышла 1С:Предприятие 8.3.25: в новом релизе платформы 55 доработок и 9 оптимизаций

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

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

23.04.2024    5609    ЕленаЧерепнева    2       

3

3 главных причины участвовать в конференции «Анализ и Управление в ИТ-проектах» по VIP-пакету

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

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

22.04.2024    698    user997184    0       

17

Конференция «Анализ и Управление в ИТ-проектах»: что нас ждет на вечеринке

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

Конференция для аналитиков и управленцев пройдет в Санкт-Петербурге и продлится три дня. Традиционное развлекательное мероприятие для всех участников конференции Инфостарт – афтепати в первый вечер мероприятия. Рассказываем, что будет на вечеринке.

22.04.2024    480    AnastasiaKl    0       

15

1С:Предприятие 8.3.26: обновление стандарта ЕСИА и поддержка присоединенной ЭП

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

Фирма «1С» анонсировала дополнительные возможности для работы с электронной подписью в технологической платформе 8.3.26. И сообщила о поддержке нового стандарта 3.34 для Единой системы идентификации и аутентификации (ЕСИА).

22.04.2024    539    ЕленаЧерепнева    0       

3

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

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

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

19.04.2024    972    eselyanina    0       

16

Выпуск новой редакции 1С:PLM 5 и начало продаж модуля PLM для 1С:ERP

Новость 1С:ERP Управление предприятием 2

Фирма «1С» сообщила об обновлении линейки решений 1С:PLM для автоматизации управления жизненным циклом изделия и инженерными данными. А также предупредила о снятии с продаж устаревших версий и скором прекращении их поддержки.

19.04.2024    673    ЕленаЧерепнева    0       

2

Новинка на Инфостарт: онлайн-курс «Автоматизированное тестирование в 1С»

Новость Обучение Программист

6 мая запускаем новый курс от Инфостарт, где мы научимся пользоваться самым популярным и открытым фреймворком тестирования для платформы 1С:Предприятие 8 – Vanessa Automation.

19.04.2024    901    AnastasiaKl    5       

17

Продлеваем прием заявок на конкурс «Современные возможности 1С: нетиповые интеграции и доработки»

Новость Сообщество

Заявки с вашими нетиповыми интеграциями продолжают поступать, поэтому мы ненадолго продлеваем прием. Теперь «заявиться» на конкурс можно до 20 апреля включительно.

17.04.2024    617    user997184    1       

2

Как использовать SmartWay в 1С для планирования командировок

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

Smartway – решение для планирования и организации командировок, разработанный на базе российского ПО. Просто задайте направления и даты, а Smartway сравнит цены на билеты или гостиницы в режиме реального времени, предложит выгодные варианты

17.04.2024    929    user997184    0       

17

Расширяем возможности типового 1С-ЭПД: автозаполнение электронной транспортной накладной для нескольких реализаций

Новость Маркетплейс ЭДО

Из документа «Транспортная накладная», входящего в состав расширения «Мастер ТТН», теперь можно отправлять ЭТрН через типовую подсистему 1С-ЭДО, расширяя ее возможности автозаполнением всех требуемых реквизитов.

16.04.2024    711    Olga_Amelchenkova    0       

4

Приглашаем на первый бесплатный вебинар Комплексного курса по управлению ИТ-проектами

Новость Обучение Руководитель проекта

17 апреля стартует Комплексный курс по управлению ИТ-проектами. Курс начнется с бесплатного welcome-вебинара, где мы поговорим о компетенциях современного руководителя и расскажем подробно о программе курса.

16.04.2024    861    AnastasiaKl    1       

14

Обновлены материалы для подготовки к сертификации по 1С:ERP

Новость 1С:ERP Управление предприятием 2

Фирма «1С» доработала материалы для подготовки к тестированиям 1С:Профессионал и 1С:Специалист-консультант по конфигурации 1С:ERP Управление предприятием 2. С 26 апреля тестирование будет проводиться по обновленному комплекту вопросов.

16.04.2024    604    ЕленаЧерепнева    0       

1

Фирма «1С» возглавила ежегодный рейтинг франшиз по версии РБК

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

РБК ежегодно составляет рейтинг наиболее популярных российских франшиз. На протяжении многих лет фирма «1С» лидирует среди прочих предложений на рынке франчайзинга.

15.04.2024    622    ЕленаЧерепнева    0       

2

Фирма «1С» дополнила перечень продуктов, которые подорожают с 1 июля 2024 года

Новость

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

15.04.2024    1767    ЕленаЧерепнева    0       

1

Сегодня, в 12:00, стартует бесплатный вебинар Марии Темчиной по разбору ошибок в управлении ИТ-проектами

Новость Обучение Руководитель проекта

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

15.04.2024    1186    AnastasiaKl    0       

2

Обновление «1С:Документооборот КОРП 3.014»: очень много приятных мелочей

Новость

В релиз «1С:Документооборот КОРП 3.014» вошли улучшенные интеграции с 1С-сервисами: они расширяют возможности конфигурации. Улучшена функциональность самого продукта – разработчики добавили новые инструменты для работы с документами и файлами.

12.04.2024    1855    ЕленаЧерепнева    0       

2

Бесплатный онлайн-вебинар «1С:Аналитика – BI-система на платформе 1С»

Новость

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

11.04.2024    1959    AnastasiaKl    1       

15

Отвечаем на вопрос: зачем публиковать свои решения в Базе знаний Инфостарт

Новость Сообщество

Если вы еще сомневаетесь, вливаться ли в наше сообщество, обязательно прочитайте эту статью.

11.04.2024    1101    Sofya_Sukur    6       

26

Фирма «1С» актуализировала состояние плана задач для 1С:Предприятие 8.3.27

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

Опубликован перечень задач, которые планируется реализовать для технологической платформы версии 8.3.27. Большая часть задач отмечена как выполненные, часть перенесена на следующий релиз, задач со статусом «в работе» в плане не осталось.

10.04.2024    813    ЕленаЧерепнева    0       

2

Учет по проектам в 1С Бухгалтерии v 2.9: главные обновления

Новость Маркетплейс

Учет рабочего времени по проектам и распределение заработной платы по отработанным часам в новой версии расширения «Учет по проектам в 1С:Бухгалтерии 3.0». Рассказываем об обновлениях подробнее.

09.04.2024    1222    user997184    0       

2