Як покращити Code Review? Як це робить Google?

  Рет қаралды 9,488

Віктор Турський про програмування

Віктор Турський про програмування

Күн бұрын

Пікірлер: 73
@-Oleg1
@-Oleg1 Жыл бұрын
Все по темі, без води, дякую
@cruc1anberg
@cruc1anberg Жыл бұрын
Щастя здоровʼя тобі!!!!
@romanyukartem757
@romanyukartem757 Жыл бұрын
Надавно натрапив на ваш канал. Контент та подача - супер, дякую!
@McKleeM
@McKleeM 2 жыл бұрын
Не встиг і моргнути, дякую)))
@AdminAdmin-sl2qf
@AdminAdmin-sl2qf 11 ай бұрын
❤❤❤❤❤❤❤❤❤❤❤❤
@atsybulsky
@atsybulsky 2 жыл бұрын
Бест практіс великих компаній типа гугла - дуже цікаво =)
@shchekavytsia
@shchekavytsia Жыл бұрын
Прикольні відео! Підписався.
@olegv5793
@olegv5793 2 жыл бұрын
Віктор, дякую за якісний контент! 👍 Було б цікаво дізнатись більше про те як працює зв‘язка PO і Tech Lead. А також про те як працює refinement задач у гуглі.
@ИринаСвет-я3ь
@ИринаСвет-я3ь Жыл бұрын
Дякую за відео 😊
@Vladyslav_Sliusar
@Vladyslav_Sliusar 2 жыл бұрын
О, про анемік модель цікаво послухати)
@AboutProgramming
@AboutProgramming 2 жыл бұрын
Обов'язково буде відео про це
@Vladyslav_Sliusar
@Vladyslav_Sliusar 2 жыл бұрын
@@AboutProgramming дяка
@alexanonymous5823
@alexanonymous5823 2 жыл бұрын
цікаво, дуже дякую
@BelladonGameDeverUA
@BelladonGameDeverUA Жыл бұрын
Толково розповів Добре, що на ДОУ показали розмову і так я знайшов цей канал
@artemtrush
@artemtrush 2 жыл бұрын
Мені подобається частота виходу відео ✨🐸 Як в гуглі з пріоритетністю рев'ю перед поточними задачами? Бо зазвичай рекомендують давати фідбек максимально швидко, щоб не блочити людину/фічі. І ще, десь бачив гарну фразу - Пишіть коментарі до коду, а не до людини, яка його написала. (politeness)
@AboutProgramming
@AboutProgramming 2 жыл бұрын
Звісно краще не блочити людину, але й той, хто створює реквест теж має розуміти, що людина може зараз бути зайнята іншими справами. Якщо рев'ю в рамках одного дня, то це добре. Відносно того, як правильно давати (й сприймати) фідбек, то це окрема тема)
@average-user9
@average-user9 Жыл бұрын
Дякую, аж захотілося попрацювати в схожій компанії чи команді, зі схожими принципами... Було б цікаво почути ще, як відбувається процес постановки тасків/задач, від того як з'являється ідея, хто і як її розбиває на фічі і далі на таски
@invilso4051
@invilso4051 Жыл бұрын
Віктор у інтерв'ю на DOU відповідав на схоже питання, якщо коротко то фічі вигадують розробники, вони ж їх і рубають на менші частинки.
@MS-fu3zf
@MS-fu3zf Жыл бұрын
Дякую за поради і класний контент. Може порадите якісь книги чи ресурси по візуалізації архітектури, типу C4?
@AboutProgramming
@AboutProgramming Жыл бұрын
Я зазвичай або С4 користую, або UML, або просто малюю вже своє щось. Відносно візуалізації, то тут скоріше головне питання в тому, схему чого ми візуалізуємо, а там вже можна підібрати інструмент/стандарт для візуалізаціх. С4 мені дуже подобається, найчастіше малюю container diagram. Якщо про UML, то найчастіше Use Case Diagram та Sequence Diagram. А під все інше все просто квадратики й стрілочки :)
@ВладиславЛевківський-т2у
@ВладиславЛевківський-т2у Жыл бұрын
👍👍👍👍
@ivansepp7928
@ivansepp7928 2 жыл бұрын
Супер.
@bogdannaumenko7571
@bogdannaumenko7571 Жыл бұрын
Дуже цікаво було б послухати про Check-list на прикладі UI... більш детальніше..
@AboutProgramming
@AboutProgramming Жыл бұрын
Важливе питання, тому затягнув з відповіддю. Тільки відповів про чек-лісти в іншому коментарі. Але я тут подумав, можливо варто зробити якийсь спільний комʼюніті чекліст разом з підписниками каналу. Я би накидав базу, а потім зібрати ще фідбек від писників й зробити спільні документи.. Як ідея? :)
@eolit1o
@eolit1o 2 жыл бұрын
Дякую за відео. Більше контенту :) А як отримати статус readability?
@AboutProgramming
@AboutProgramming 2 жыл бұрын
Є якійсь процес, де ти маєш підтвердити знання гайдлайнів й правильних практик для певного технологічного стеку, але я поки ніяк не займусь цим)
@artemkonyukhov6635
@artemkonyukhov6635 Жыл бұрын
Сподобалось, що є ревью архітектури і є ревьювери з редабиліті статусами. Дякую.
@const_g
@const_g Жыл бұрын
Майже нічого нового. Але все одно дякую)) цікаво що за муз обладнання у вас там? Ви музикант ще? Може розкажете трохи про це теж?)
@AboutProgramming
@AboutProgramming Жыл бұрын
Це chromakey)
@const_g
@const_g Жыл бұрын
​@@AboutProgrammingлол)) а виглядає як справжнє)
@hesher2301
@hesher2301 Жыл бұрын
У вас позаду така музична студія добре напакована) це просто бекграунд?
@AboutProgramming
@AboutProgramming Жыл бұрын
Просто картинка)
@hesher2301
@hesher2301 Жыл бұрын
@@AboutProgramming жаль
@AboutProgramming
@AboutProgramming Жыл бұрын
@@hesher2301 ех, сам би хотів
@maxbabych52
@maxbabych52 2 жыл бұрын
На скільки ревьювер повинен бути поглинутий в таск щоб вирішувати чи ця задача вірно зроблена і чи взагалі повинен ревьювер поринати в задачу? Дякую
@AboutProgramming
@AboutProgramming 2 жыл бұрын
Для readability review це не обов'язково. А от для основного рев'ю дуже корисно розуміти контекст задачі. Й це має бути відповідальність інженера забезпечити рев'ювера контекстом - реквест має бути присвяченій одній зміні, детально описати ідею зміни в реквесті, додати скріншоти, додати посилання на опис задачі, обрати рев'ювера, який вже розуміє задачу чи згоден у неї зануритися
@maxbabych52
@maxbabych52 2 жыл бұрын
@@AboutProgramming мені завжди чомусь здавалося що це моя відповідальність розібратися в ревью і виходило що я читаю таск , придумую рішення а потім ще розбираюся як воно реалізовано в пулі , а виходить що було достатньо щоб інженер правильно доніс свою реалізацію. Дуже дякую за слушну пораду і з Новим Роком)
@AboutProgramming
@AboutProgramming 2 жыл бұрын
@@maxbabych52 так, й якщо щось не зрозуміло, тоді рев'ювер буде задавати питання в коментах й просити пояснити ідею й це буде збільшувати час рев'ю й інженеру доведеться декілька разів повертатися до коду й проходити додаткові ітерації. Через пару таких рев'ю вже сам почне додавати більше контексту, якщо хоче якісне рев'ю
@feelthefreedom
@feelthefreedom Жыл бұрын
є можливість поділитись чек-лістом по фронтенду?
@AboutProgramming
@AboutProgramming Жыл бұрын
По фронтенду нажаль чеклістами поділитися не можу, оскільки там частина вимог це приватні вимоги від клієнтів. Але концептуально, це просто документ, який описує стандартні кейси, які мають бути покриті під час розробки фронтенду типу * редірект, коли закінчилася сессія * помилка про проблему з інтернетом, коли пропав звʼязок * лінкі мають відкриватися через CTRL+click й так далі Тут головна ідея в тому, що такі проблеми повторються від проекту до проекту й має сенс десь це документувати, щоб не повторювати помилки. Часом це вирішується за рахунок спільної архітектури, часом процесно, а часом інфраструктурно
@vandriichuk
@vandriichuk 11 ай бұрын
Для Гугла може і норм такий складний ревью, але ж безліч проектів, де це овер. Тому думаю, что все від проектів залежить. Для стартапу швидкість імплементації фічі набагато важливіша технічного боргу
@kbodka
@kbodka Жыл бұрын
Якщо когось цікавить більше деталей про те як працюють процеси в гуглі, раджу прочитати software engineering at google. Дуже класна книжка, свого часу почерпнув для себе багато цікавих речей.
@AboutProgramming
@AboutProgramming Жыл бұрын
Окрім того вона в безкоштовному доступі
@Bohdan-Venhrenovych
@Bohdan-Venhrenovych 2 жыл бұрын
Топчик
@vasylnahuliak
@vasylnahuliak 2 жыл бұрын
Як щодо розбиття merge/pull requests на менші? наприклад створюється окрема гілка в яку попадають такі маленькі МР а потім закидується сквошом в основну гілку
@AboutProgramming
@AboutProgramming 2 жыл бұрын
Будь-яка довгоживуча гілка створює проблеми, навіть якщо в неї регулярно тягнуться дані за мастера. Чим менші реквести й частіше, тим краще. В Google взагалі все живе тільки в основній гілчці й мерджитися можливо тільки в основну гілку. В WebbyLab ми використовуємо переважно "Git One Flow branching model" - такий собі варіант trunk based development
@eolit1o
@eolit1o 2 жыл бұрын
Є якісь обмеження у кількості строк коду на один pr?
@AboutProgramming
@AboutProgramming 2 жыл бұрын
Технічного обмеження немає, є просто рекомендація, що менше зазвичай краще
@mikemakhovyk6941
@mikemakhovyk6941 Жыл бұрын
Привіт! Ти в інтерв’ю казав, що працюєш над фічами, які можуть розроблятися дуже довго. Як в гуглі відбувається цей процес, коли створюються МРи, де ще не весь функціонал реалізовано, десь work in progress, десь можливо якісь заглушки? Чи залишаються явні коменти/ToDo? Чи МР має бути максимально фіналізований, наскільки можливо?
@AboutProgramming
@AboutProgramming Жыл бұрын
Все живе в одній гілці й фічі сховані за feature флагами
@v.ilchenko
@v.ilchenko 2 жыл бұрын
Ми недавно впровадили стайлгайди (до цього тільки лінтер був) і це прямо суттєво спростило рев‘ю. Більшість коментарів зараз - лінки на док. Тут є питання - чи варто в стайлгайд виносити речі, які покриває статичний аналіз? Умовно «використлвуй let/const замість var» Додав би що корисно на проекті налаштувати codeowners, щоб відповідні люди/команди автоматично асайнились. По архітектурному ревю - як це може виглядати в продукті? Коли у нас одна команда працює над одним проектом. Зараз є декілька senior людей, які можуть зарефакторити проект, але це працює поки для команди в ~50 розробників. Коли вас стає 500, по ідеї потрібна окрема команда під це? Гугл гайди рекомендують робити код рев‘ю протягом 1 дня. Як у вас цього дотримуються? Просто цікаво :)
@AboutProgramming
@AboutProgramming 2 жыл бұрын
Чим більше стайлгайдів вийде замінити статичним аналізом, тим краще. Тоді вже посилання на доки може давати сам лінтер й рев'юверу не треба витрачати час. Відносно codeowners, то це теж є, але чисто для регулювання прав доступу (тобто галочка від овнера теж завжди потрібна). Відносно архітектурного рев'ю в продукті, то можна роботи рев'ю й командою, яка працює над проектом. Тут головне, щоб це просто було й був менеджмент технічного боргу. Коли над продуктом працює 500 людей, тоді це буде 30-50 команд й тут вже питання як узгодити команди між собою. Різні компанії підходять по різному - хтось за повну автономію, хтось за більше централізацію. Я за децентралізацію, але максимальну стандартизацію й узгодження. Це можна зробити за рахунок: 1. Спільна інфраструктура. Вона зможе прогарантувати схожі процеси й підходи, один й той самий статичний аналіз, один механізм деплойменту й моніторінгу та інше. 2. Спільна документація - рекомендаці по процесам, спільні стайлгайди та інше. 3. Спільна дизайн система й набір компонентів/бібліотек 4. Обмін знаннями (презентації рішень від однієї команди іншим та інше) 5. Різні cross team (company wide) efforts. Часто визначаються, як цілі на рівні директорів й кожна команда забов'язана зарезервувати певний час на іх виконання. Відносно код рев'ю протягом одного дня, то тут просто - бачиш, що вісить на тобі реквест, то почав ранок з цього (або як прийшов з обіду). Якщо у рев'ювера немає часу подивитися, а тобі треба терміново, то можеш попросити напряму або ще додати інших людей для рев'ю у кого є час. Або написати в спільному чаті й спитати, хто може швидко глянути.
@v.ilchenko
@v.ilchenko 2 жыл бұрын
Дуже інформативно, дякую 🎉
@thankfulperson3309
@thankfulperson3309 2 жыл бұрын
Як заохотити всю команду до процесу код рев'ю, коли тільки частина більш-менш активна в цьому питанні?
@AboutProgramming
@AboutProgramming 2 жыл бұрын
Команда має бачити цінність в код рев'ю. Й тут або вони не розуміють цінність й це треба донести (наприклад, що станеться, якщо всі на проекті відмовляться в код рев'ю), або цінності немає - наприклад, якість коду для керівництва не є важливою й тут можливо треба донести спочатку цінність до керівництва.
@logcom482
@logcom482 Жыл бұрын
В пітоні з стильом написання коду все простіше не зробив відступи і ніфіга не запуститься)))На С хоч пиши весь код в одному рядку)
@AboutProgramming
@AboutProgramming Жыл бұрын
Ну там відступи, а там дужки фігурні)
@roman1961
@roman1961 Ай бұрын
Зазирни у pip ruff
@eolit1o
@eolit1o 2 жыл бұрын
На який позиції ви працюєте в Google? І який у вас левел?
@AboutProgramming
@AboutProgramming 2 жыл бұрын
L5
@AboutProgramming
@AboutProgramming 2 жыл бұрын
й додав посилання на мій Linkedin в опис під відео
@suhovN
@suhovN Жыл бұрын
питання щодо review від людини яка має readability status. Хто ассайнить цю людину, автоматизація чи власник ПРу вручну? Чи є явний дозвіл або заборона на те щоб запросити review у декількох таких людей одночасно. Якщо вручну та така людина в іншій команді, як знати що ця людина взагалі доступна, можливо вона out of office у найближчий тиждень або у неї черга подивитись review на стільки велика що твій ПР подивиться тільки через тиждень?
@AboutProgramming
@AboutProgramming Жыл бұрын
Може бути й вручну й автоматично. Якщо автоматично, то всі перевірки пройдуть автоматично. Якщо вручну, то перевірки можна зробити вручну (написати людині, глянути чи на роботі й тд). Про заборону в декілька людей не чув.
@SvoyakD
@SvoyakD Жыл бұрын
Послухав це все і страшно уявити кінцеву вартість реалізуємих фіч в гуглі. Осообливо коли в аналіз коду повинні включатися розробники, які не працювали над поточною задачею. Бо для якісного ревью потрібне повне занурення, потрібно знати всю архітектуру проекта\модуля, інакше такий аналіз будет дуже поверхневий і неякісний.
@AboutProgramming
@AboutProgramming Жыл бұрын
Сам жахаюся, бо дуже дуже дорого виходить. Але вартість помилки ще вища
@vasylnahuliak
@vasylnahuliak 2 жыл бұрын
Цілий рік записував відео і на кінець вирішив залити? 😂
@AboutProgramming
@AboutProgramming 2 жыл бұрын
Аби) Завтра вранці планую зняти ще 2 з готеля))
@mrart5498
@mrart5498 2 жыл бұрын
Гарний початок! З нетерпінням чекаємо!
@LyubomyrSemkiv
@LyubomyrSemkiv Жыл бұрын
З мого досвіду, 8 з 10 ревю які я роблю є неправильними. Воно ніби вирішує проблему, алк створює якісь інші проблеми різного хврактеру, або просто калічно - зайві дії. Глибоке коуд рев‘ю, де перевіряється валідність фікса, а не відповідність якимось сумнівним поактикам є найбільш цінним. Я не подивився все відео, але здається здатність робити такі ревю тут називається рідабіліті статус. Це дцже поавильно і розумно, лише я не розумію, чому у вас при тому дають дизайнити і овнити фічу з непідтвердженими навиками дизайну. Так само як більшість програмістів не вміють програмувати, так само вони не вміють дизайнити.
@AboutProgramming
@AboutProgramming Жыл бұрын
Всі починають з того, що не вміють дизайнити й треба починати з чогось, щоб отримати цей скіл. Тому проектування корисно й для джунів, просто треба ім допомогати в цьому й задачі мають бути відповідного рівня. Відносно рідабіліті це в першу чергу на відповідність стандартним практикам конкретного стеку, проекту й тут не треба глибокого контексту по фічі, але це теж важливо. Тому рідабіліті апрув завжди має бути до стандартного ревʼю від когось з команди (але це може бути одна й та сами людина, яка й рідабіліті апрувить)
@LyubomyrSemkiv
@LyubomyrSemkiv Жыл бұрын
​@@AboutProgrammingага, тоді це інше. Це не ability to read code а апрув що code is readable. А дизайнити вичтися краще працюючи "підймайстром" в того, хто вміє дизайнити. Це такий класичний ремеслярський підхід.
Як працює Base64 й навіщо він потрібен?
20:00
Віктор Турський про програмування
Рет қаралды 12 М.
3 речі, які роблять програміста кращим
20:12
Віктор Турський про програмування
Рет қаралды 18 М.
Сестра обхитрила!
00:17
Victoria Portfolio
Рет қаралды 958 М.
Что-что Мурсдей говорит? 💭 #симбочка #симба #мурсдей
00:19
The evil clown plays a prank on the angel
00:39
超人夫妇
Рет қаралды 53 МЛН
Как Получить Работу в Google в Европе/США
14:12
Чому алгоритми важливі? Розберемо на прикладі
23:44
Віктор Турський про програмування
Рет қаралды 15 М.
Як працює Інтернет? Основні питання про DNS
22:58
Віктор Турський про програмування
Рет қаралды 48 М.
Хешування, кодування, шифрування. В чому різниця?
8:40
Віктор Турський про програмування
Рет қаралды 10 М.
3 речі, що псують програміста
10:55
Віктор Турський про програмування
Рет қаралды 14 М.
Стрим с Code Review вашего Python кода
3:06:08
Диджитализируй!
Рет қаралды 68 М.
Дерева. Пошук. Алгоритми. Бази даних
15:56
Віктор Турський про програмування
Рет қаралды 12 М.
Код ревью (code review): лучшие практики, как проводить.
8:40
Сестра обхитрила!
00:17
Victoria Portfolio
Рет қаралды 958 М.