Пол — это Java
152 subscribers
13 photos
2 videos
2 files
25 links
Канал, в котором живет вымышленный на основе реальных событий разработчик Пол, и вместе с ним мы пробуем узнать, что такое Java и не только👨🏻‍💻

@polyackov_ot
Download Telegram
Channel photo updated
Привет Пол (и привет всем)

Последние месяцы мы с товарищами много обдумываем собственные проекты и мечту развития комьюнити.

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

С начала года уже случилось много интересного, например, две Q&A сессии с внешними комьюнити разработчиков (про первую я рассказал тут). За организацию и моральную поддержку большое спасибо моем другу и коллеге @sliceoflife0101

Сейчас же мы с моим partner in crime @diakaiuti дорабатываем последние штрихи нескольких нетривиальных для меня образовательных и дискуссионных форматов, так что уже совсем скоро расскажем what we do in the shadows.

P.S. Фраза "Пол — это Java", обросшая внутренними шутками и смыслами, когда-то стала названием этого канала. Думаю, новое фото отлично отражает ее многомерность.
🔥113🤯3
Привет Пол (и привет всем)

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

Игорь Овчинин и Евгения Медникова, представляющие творческий тандем небезразличных аналитиков, тоже это понимают, а потому написали подробную статью, закрывающую основные вопросы простым и понятным языком.
А я помог наполнить ее good practice из своего прикладного опыта, но вовсе даже не поэтому рекомендую ее к прочтению.
9🔥64
👋 Привет Пол (и всем привет)

С Днем программиста! Пусть код становится чище, баги будут редкими, а Java – еще увлекательнее. Пол бы сказал, что идеальный код — миф, но каждый может сделать его лучше. Вперед к новым свершениям! 🎉
Please open Telegram to view this post
VIEW IN TELEGRAM
8👍6🔥4🤩2💯1
👋 Привет Пол (и все, кто интересуется улучшением процесса тестирования)

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

Преимущества подхода:

1️⃣ Наглядность данных
На мой взгляд, JSON-файлы гораздо нагляднее, чем использование билдеров в коде. Данные можно легко читать и редактировать.

2️⃣ Понятность данных для стейкхолдеров
Один из ключевых плюсов вытекает из предыдущего пункта: на прошлом проекте я мог прямо на встрече с бизнес-стейкхолдерами изменять тестовые данные в JSON-файле и после встречи начать править код.

3️⃣ Лаконичность тестов
В тестировании есть замечательное правило: "Тест должен охватываться одним взглядом", что дает возможность использовать тесты как спецификацию.

Вынесение данных в JSON позволяет свести их представление в тесте к одной строке. Такой подход помогает абстрагироваться от подготовки тестовых данных и сосредоточиться на главной ответственности тестов — непосредственном тестировании.

4️⃣ Работа с большими и сложными запросами
JSON позволяет хранить сложные структуры данных, которые максимально приближены к тем, что используются в боевой среде и без излишней громоздкости.

5️⃣ Легкость дебага
В случае необходимости можно взять JSON с боевой среды и использовать его для отладки проблемы прямо в юнит-тестах.

6️⃣ Интеграция с IDEA
Еще одно удобство заключается в том, что с помощью IntelliJ IDEA можно легко навигироваться из теста прямо в JSON-файл. Это значительно ускоряет работу, ведь вы можете быстро переходить к данным, менять их и сразу видеть результат в тесте. (Скрин приложу в комментариях)

Однако у такого подхода есть и свои недостатки:

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

Некорректные данные
Данные в JSON-файле могут не соответствовать актуальной валидации. Из-за этого есть риск потратить время зря на поиск проблемы в коде, хотя истинная проблема будет сокрыта в тестовых данных.

В следующем посте обещаю рассказать про свою библиотеку, которая как раз решает перечисленные недостатки и значительно упрощает мою работу по написанию хороших тестов уже несколько лет.
Please open Telegram to view this post
VIEW IN TELEGRAM
74🔥42
👋 Привет Пол (и все, кто интересуется улучшением процесса тестирования)

Как и обещал, рассказываю о своей библиотеке для работы с тестовыми данными в формате JSON, которая закрывает недостатки подхода, описанного ранее, и делает тестирование еще удобнее.
Когда-то она начиналась с 2х простых методов getJson и getObject, и я дорабатывал и улучшал ее на протяжение последних 3х лет, пока не пришел к формату, которым с удовольствием делюсь с вами.

Мой репозиторий: polyackov-test-util

Проблемы подхода, которые решает моя библиотека:

01. Накопление неиспользуемых данных
Со временем в JSON-файлах могут накапливаться лишние поля, которые перестали использоваться в коде. Библиотека помогает выявить такие лишние поля благодаря настройке:

mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, true);


02. Некорректные данные
Данные в JSON-файле могут не соответствовать актуальной валидации. В библиотеке есть методы getValid***, которые провалидируют данные перед их использованием, обеспечивая их корректность.

03. Локализация ошибок
Когда тесты ломаются из-за некорректных JSON-данных, они завершаются не как Failed (красные), а как Ignored (серые). Это помогает локализовать причину проблемы и точно указывает на ошибку в тестовых данных, а не в самом тесте.

*️⃣Дополнительно в репозитории можно найти тесты, которые демонстрируют ключевые особенности работы с библиотекой. Это позволит быстро познакомиться с ее возможностями и начать использовать в своих проектах.

Кроме того, даже если вы не используете Spring или Jackson, всегда можно адаптировать библиотеку, заменив компоненты на привычные.

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

Буду благодарен, если поделитесь своим опытом и отзывами и покликаете на звездочку!
Please open Telegram to view this post
VIEW IN TELEGRAM
11🔥431
👋 Привет Пол (и все, кто любит чистый код)

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

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

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


От префикса I я отказался довольно быстро, но отказаться от постфикса Impl, честно говоря, было куда труднее.

Лишь спустя время, когда я настроил цветовую схему в IntelliJ IDEA, я полностью перешел на более лаконичный подход без "синтаксических костылей".

Настройка цветовой схемы стала для меня must-have в разработке по следующим причинам:

01. Легкость восприятия кода

Используя цвета для разных типов классов, я сразу визуально понимаю, какой тип объекта передо мной. Это особенно удобно в больших проектах, где легко потеряться в многочисленных классах и интерфейсах. Цвета моментально привлекают внимание и позволяют "считывать" структуру кода без необходимости изучать его подробности.

02. Отказ от синтаксического сахара

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

*️⃣ Дополнительное преимущество:

Если у вас больше нет возможности использовать I & Impl, это предотвращает возникновение таких имен, как Service & ServiceImpl. Вместо этого вы столкнетесь с ситуацией, где интерфейс и его реализация имеют одинаковые имена — например, Service & Service.

Такой подход еще раз напоминает про ответственность (Single Responsibility) классов. Благодаря этому вы назовете свои классы более точно или даже решите отказаться от избыточного интерфейса, задавшись вопросами:

— Правильно ли мы называем наши классы?
— Может быть интерфейс заслуживает более абстрактного названия, а реализация — более конкретного?


В следующем посте расскажу, как цветовая схема настроена у меня.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍3🤔322
⚙️ Как настроить цветовую схему в IntelliJ IDEA

В предыдущем посте я делился своими выводами по преимуществам использования цветовых схем в коде.

Небольшой tutorial, как эти настройки применить:

» » Откройте Settings -> Editor -> Color Scheme -> Java.
» » Найдите разделы Interface, Abstract class и Enum.
» » Установите удобные вам цвета для каждого типа класса.

Моя цветовая схема:

Interface — #88E062 (зеленый оттенок)
Abstract class — #66A8E9 (голубой оттенок)
Enum — #EBC4FF (пастельно-фиолетовый)
Record — #FFB86C (янтарный/персиковый)


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

А какие инструменты или фичи IntelliJ IDEA помогают вам? Делитесь в комментариях!

#intellijideafeature
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥74🆒3
👋 Привет Пол (и все, кто интересуется новыми архитектурными подходами)

Сегодня я хочу поделиться своими впечатлениями от статьи про Cell-Based Architecture.

Сell-based Architecture (CBA)
— это подход, при котором система делится на независимые ячейки (cells), каждая из которых полностью самодостаточна и выполняет определенную бизнес-логику.

Основная идея
— каждая ячейка содержит все необходимые ресурсы для своей работы, что упрощает масштабирование и изоляцию проблем.

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

Самодостаточность ячейки, как свойство, кажется мне довольно похожим на самодостаточность микросервиса.
Однако в MSA самодостаточность сервисов направлена на устранение краеугольной проблемы — распределённых транзакций.
В CBA же сама концепция объединения нескольких сервисов в одну ячейку порождает эту самую проблему, что загадочно выставляется преимуществом, хотя она сгубила бессчетное число микросервисов.

Если рассматривать обе архитектуры в контексте запуска в Kubernetes кластере, то единственная разница — в MSA Helm будет контролировать только один сервис, а в CBA несколько.

Поэтому, если подытожить первое впечатление, то кажется, что CBA — скорее маркетинговый ход AWS, поскольку это оптимизация именно для самого AWS.

А как вам кажется, есть ли реальные преимущества Cell-Based Architecture по сравнению с Микросервисами?
🔥73👍3🤔1
ЧИСТЫЙ КОД (Part 1)

👋 Привет Пол (и все, кто задумывается о чистом коде)

Семь месяцев назад я сменил работу, и теперь одна из моих ключевых задач — обучать и делиться экспертизой. И за это время мне часто приходилось отвечать на вопросы, так или иначе связанные с чистотой кода.

Что такое чистый код?

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

Сам подход подразумевает, что иногда важно придерживаться принципов, а иногда осознанно от них отходить.

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

P.S. А еще оказалось, что многие вещи делаются настолько бессознательно и интуитивно, что при необходимости передачи знания приходится буквально воссоздавать с нуля алгоритм действий.

Поэтому я был бы очень рад и благодарен, если вы поделитесь в комментариях своим опытом или мнениями под грядущими постами!
7🔥4👍3
ЧИСТЫЙ КОД (Part 2)

👋 Привет Пол (и снова привет всем)

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

Перед тем как писать код, важно все же понять контекст, в котором он будет существовать. Для этого я задаю себе (и коллегам) несколько ключевых вопросов:

1️⃣ Кто наши стейкхолдеры (технические и бизнес)?

Стейкхолдеры, в свою очередь, помогут нам ответить на вопросы ниже.

2️⃣ Каковы архитектурные риски и ключевые качества системы?

Это понимание позволит валидировать каждое принимаемое решение.

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

3️⃣ Какой объем изменений ожидается в будущем?

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

4️⃣ Долгосрочная или краткосрочная ли ожидается поддержка?

Долгосрочная → код должен быть гибким и легко поддерживаемым.
Краткосрочная → можно принять больше компромиссов.

5️⃣ Насколько жесткие дедлайны?

Сжатые сроки → приходится делать упрощенные решения.
Гибкие сроки → можно уделить больше времени качеству.

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

По итогу: чем выше уровень неопределенности, тем выше шанс принять некачественное и неподходящее решение.

P.S. В следующих постах я хотел бы разобрать разные вариации контекстов и поразмышлять, какие решения можно принять на их основе. Буду рад вашим мнениям!
6👍6🔥5
ЧИСТЫЙ КОД (Part 3)

Скажи свое мнение и беги: не откладывай на завтра то, что можно сделать послезавтра

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

Под профессиональный контекст это можно перефразировать как
Откладывай принятие важных архитектурных решений как можно дольше.

Оно же верно и в концепции чистого кода.

Это не значит избегать решений и ответственности вовсе. Скорее наоборот, это значит принимать только те решения, без которых невозможно двигаться дальше прямо сейчас. Остальные же будет дальновиднее оставить на момент, когда появится больше данных о контексте задачи (про план сбора контекста я писал в посте выше).

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

P.S. А какие принципы у вас есть в работе?
👍83🔥21
👋 Привет Пол (и все, кто любит полезные фичи IntelliJ IDEA)

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

А сейчас увидел отличный материал про Live Templates — тоже классная фишка для ускорения работы. Репостнул оригинал ниже ⬇️

🎯 Что сделал для себя по мотивам поста


Добавил несколько своих шаблонов для тестов:
@org.junit.jupiter.api.Test
void $NAME$_when$WHEN$_then$THEN$() {
$END$

var actual = $SUT_NAME$.$NAME$();

var expected = $EXPECTED$;
assertEquals(expected, actual);
}

@org.junit.jupiter.api.Test
void $NAME$_when$WHEN$_thenThrow() { $END$
var actual = assertThrows($EXCEPTION$.class, () -> {
$SUT_NAME$.$NAME$();
});

assertEquals($EXPECTED_MESSAGE$, actual.getMessage());
}


Отредактировал стандартный шаблон для тестов. Теперь метод создаётся сразу в формате, принятым моей командой:
@org.junit.jupiter.api.Test
void ${NAME}_when_then() {
${BODY}
}


Навигация для изменения стандартных шаблонов:
Command + N (macOS) / Alt + Insert (Windows)
→ три точки
Edit Template

🎥 Также очень рекомендую видео, где показано, как настраивать переменные Live Templates, например, указать default value или конвертацию в camelCase.
👍84🔥3
⚙️ Live Templates в IntelliJ IDEA

Надоело писать одни и те же конструкции снова и снова? На помощь приходят Live Templates — инструмент, который позволит генерировать фрагменты кода по паре букв.

Live Templates — это заготовки кода, которые можно вставлять по сокращённым ключам. Например, вместо того чтобы каждый раз писать System.out.println(), достаточно написать sout и нажать Enter. IDEA сама развернёт код.

Live Templates поддерживают Java, Kotlin, JS, Groovy, SQL и XML/HTML.

📌 Полезные шаблоны по умолчанию

🟢 sout → System.out.println();
🟢 fori → for (int i=0; i< ; i++) {}
🟢 psvm → public static void main(String[] args) {...}
🟢 ifn → if (obj == null) {}
🟢 prsf → private static final

Полный список live templates: File → Settings→ Editor → Live Templates.

⚙️ Как создать свой шаблон

1️⃣ Открываем File → Settings→ Editor → Live Templates
2️⃣ Выбираем группу или создаём свою.
3️⃣ Нажимаем "+" и задаём аббревиатуру (триггер шаблона).
4️⃣ Пишем в поле Template text код с переменными ($VAR$).
5️⃣ Указываем Context, где шаблон будет работать (Java, SQL, XML и т. д.).
6️⃣ Применяем и тестируем.

Live Templates – это must-have инструмент для ускорения написания кода. Настройте под себя и забудьте про шаблонный код.

💬 Делитесь интересными кастомными шаблонами

Java библиотека #java
Please open Telegram to view this post
VIEW IN TELEGRAM
👍721🔥1
ЧИСТЫЙ КОД (Part 4)

👋 Привет Пол (и привет всем)

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

Теперь спустимся на уровень конкретных примеров и подумаем, а как можно в разном контексте действовать.

💼 Представим, что мы работаем в крупной корпорации N, где есть ресурсы на реализацию максимально качественных решений.

🎯 Нам была поставлена задача:

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

Ответим на вопросы о контексте:

🧑🏻‍💻 Кто наши стейкхолдеры? Каковы их запросы и ожидания?

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

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

Финансовый контроль — косвенный стейкходлер, который заинтересован в точности расчетов и прозрачности начислений, чтобы исключить возможные ошибки.

⚠️ Каковы архитектурные риски и ключевые качества системы?

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

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

• Бизнес ожидает, что со временем появятся новые требования
Система должна обладать расширяемостью. Если изначальная архитектура не учитывает возможность модульного расширения, стоимость доработок может вырасти в разы.

• Калькулятор комиссий, скорее всего, будет зависеть от других сервисов (биллинг, CRM, внешние платежные системы)
Непродуманная работа с интеграциями может стать узким местом.

🛠 Какой объем изменений ожидается в будущем? Долгосрочная или краткосрочная ли ожидается поддержка?

Значительный объем изменений

Долгосрочная поддержка

Насколько жесткие дедлайны?

Сроки гибкие, но первый тип комиссии должен начать работать через 2 месяца.
После этого начнется этап переноса остальных комиссий и, при необходимости, разработка новых.

⸻ ⸻ ⸻ ⸻ ⸻

Даже получив ответы на вопросы выше, объем известного значительно меньше того, что мы до сих пор не знаем. Но откладывать больше нельзя — пора начинать писать код.

Думаю, все мы знаем это чувство, когда легче начать, а разбираться уже при необходимости по ходу дела. Благо, agile давно помог нам справляться с этой сложностью.

В нашем кейсе уже изначально мы можем предсказать, что и core, и integration слои будут сложными.

Интеграции — это больше техническая проблема, поэтому решать её нам легче — применяем гексагональную архитектуру. Со второй же проблемой так просто не получится, поэтому применяем мудрость из прошлого поста и просто откладываем решение до лучших времён. А текущую реализацию делаем максимально простой, но при этом не забываем про 100% покрытие core тестами, которые дадут нам уверенность при необходимости менять код по 50 раз в день.

Уже в дальнейшем, когда наберётся некоторая критическая масса кода в ядре, мы сможем его отрефакторить и реализовать onion / clean architecture / DDD.

💬 Как бы вы подступились к решению этой задачи? Делитесь в комментах!
62🔥22👍1
📚 Время пробовать новые форматы, а потому мы с коллегами анонсируем запуск ридинг-клуба "Пол — это Java" 📚

В чем особенность формата, и почему мы ему уже рады?

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

Мы заранее подберем наиболее ключевые и интересные работы по теме для ознакомления.

Они не будут слишком большими, чтобы все участники успели подготовиться!

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

• Все это делает формат прекрасным как для тех, кто еще ничего знает о теме, так и для погруженных:

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

✔️Опытные осмыслят и отрефлексируют знания, обменяются инсайтами с другими профессионалами.

☕️Тема первой встречи: Роль архитектора в Agile-командах

✔️Мы проанализируем подходы к распределению архитектурных задач в командах
✔️Подискутируем, как меняется понимание архитектуры в условиях гибкой разработки
✔️Обсудим, нужен ли архитектор в классическом смысле или команды могут справляться сами, полагаясь на собственную экспертизу

Когда:
25 мая (воскресенье)
12:00–15:00 (по Мск, GMT +3)
онлайн

📼 Записаться можно здесь: 📼
https://forms.gle/af4KWj4fQRno6v2L9

Все участники будут добавлены в Telegram-чат, где получат статьи для подготовки и вопросы для саморефлексии.
Please open Telegram to view this post
VIEW IN TELEGRAM
9🔥5😱3👍1
Уже в это воскресенье в 12:00 по Мск мы проведем первую встречу читального клуба, в котором есть еще пара мест для желающих 📚

Подробнее про формат и тему описали в посте выше ⬆️

А записаться можно здесь:
https://forms.gle/af4KWj4fQRno6v2L9

До встречи!
Please open Telegram to view this post
VIEW IN TELEGRAM
7🔥3🤩3
Пол (и все-все-все) — это исполнилось 30 лет лучшему языку программирования 📱
Please open Telegram to view this post
VIEW IN TELEGRAM
9🔥3🍾3
Сегодня идея меня встретила так
🔥8🍾54
🎙️ Ищем людей для короткого исследования!

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

Интересны все, кто:
1. За последний год проходил платные курсы по программированию или смежным темам (не важно, онлайн/оффлайн, длинные/короткие).
2. Или использовал AI (ChatGPT, Copilot и др.) для учёбы, практики или экспериментов.

Если был опыт обеих активностей, то ещё лучше 🙌

🗣️ Исследование пройдёт в формате беседы/интервью и займёт примерно 40-45 минут.

Если вы были бы рады поучаствовать, напишите, пожалуйста в личку или оставьте сообщение в комментариях. Спасибо!
5👍3