Олег Тымко: «Open Source помог мне прокачать навыки коллаборации и общения в сообществе»
На конференции 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 (это анализ потока данных). И, соответственно, реализовать это в плагине. Вспомнить институт, где мы изучали что-то подобное – теорию графов и т.д.
Несколько пожеланий нашим гостям конференции, участникам сообщества Инфостарт.
Я бы хотел пожелать, чтобы люди не боялись приезжать на конференцию. Из-за коронавируса у многих паранойя в этом плане: «Нет, я не поеду, там много народа, я боюсь, что все заразятся». На мой взгляд, это неправда. Мы приехали сюда, здесь все хорошо, все стараются ходить в масках. Все общаются. Хочется пожелать, чтобы люди чаще ездили на такие конференции, потому что, во-первых, это обмен знаниями. Во-вторых, можно не только посмотреть на интересные доклады, но и пообщаться между ними – какие-то темы интересные пообсуждать, какие-то новые вещи узнать.
130+ докладов с презентациями спикеров
Подключайтесь к чату в телеграм INFOSTART FRIENDS. В чате будем знакомиться, обсуждать доклады и рабочие задачи. Нас уже более 1000!