PHP / Magento Dev Blog

  • Publikacje
  • O autorze
  • Kontakt

Kurs Gita #5 – workflow zespolowy: Git Flow, trunk-based, PR, code review

by Henryk Tews / czwartek, 14 maja 2026 / Opublikowano w Git

Wybór workflow gitowego ma większy wpływ na produktywność zespołu niż większość decyzji technicznych. Git Flow, GitHub Flow, trunk-based development – to kompletne modele pracy, code review i deploymentu. Pokażę kiedy co stosować i co odróżnia dobry pull request od złego.

Git Flow

Git Flow definiuje kilka typów branchów: main (produkcja), develop (integracja), feature/xxx, release/x.y, hotfix/xxx. Sprawdza się przy oprogramowaniu z numerowanymi wersjami.

git flow init
git flow feature start order-export
git flow feature finish order-export
git flow release start 1.2.0
git flow release finish 1.2.0
git flow hotfix start critical-tax-bug
git flow hotfix finish critical-tax-bug

Trunk-Based Development

Jeden główny branch, krótkie feature branche (max kilka dni), CI/CD przy każdym pushu, deploy po merge do main. Wymaga feature flags do ukrywania niegotowych funkcji.

git checkout -b feature/add-loyalty-points
git push -u origin feature/add-loyalty-points
# Otwórz Pull Request, code review, CI przechodzi
# Squash and merge do main, automatyczny deployment

Pull Request – struktura

## Co zrobilem
Dodaem eksport zamowien do CSV. Refs: #247

## Jak testowac
1. Admin > Sales > Orders
2. Zaznacz zamowienia, Export > CSV

## Checklist
- [x] Testy przechodza
- [x] phpstan --level=8 bez bledow
- [x] Breaking changes: brak

Code review – priorytety

Weryfikuj w kolejności: architektura (DI, brak ObjectManager, Service Contracts), logika biznesowa, edge cases, styl kodu. Nie odwrotnie. Sprawdź czy SearchCriteria ma setPageSize – brak limitu to tykająca bomba na dużych katalogach.

Branch naming

feature/JIRA-123-order-export-csv
fix/JIRA-456-tax-calculation-virtual
refactor/order-service-di-cleanup
chore/upgrade-php-84

Podsumowanie

Git Flow – dla zespołów z wersjonowanymi releasami. Trunk-based – dla ciągłego deploymentu. Dobry PR zawiera opis co, dlaczego i jak testować. Code review zaczynaj od architektury, nie stylu. Następny wpis: Git hooks i automatyzacja – pre-commit z PHPStan i integracja z DDEV.

About Henryk Tews

Co możesz przeczytać następne

Kurs Gita #7 – debugging i ratowanie: bisect, reflog, reset vs revert
Kurs Gita #6 – hooki i automatyzacja: pre-commit, PHPStan, commit-msg, DDEV
Kurs Gita #1 – model danych: blobs, trees, commity, refs
  • Publikacje
  • O autorze
  • Kontakt

© 2026 Created by

GÓRA
Zarządzaj zgodą
Aby zapewnić jak najlepsze wrażenia, korzystamy z technologii, takich jak pliki cookie, do przechowywania i/lub uzyskiwania dostępu do informacji o urządzeniu. Zgoda na te technologie pozwoli nam przetwarzać dane, takie jak zachowanie podczas przeglądania lub unikalne identyfikatory na tej stronie. Brak wyrażenia zgody lub wycofanie zgody może niekorzystnie wpłynąć na niektóre cechy i funkcje.
Funkcjonalne Zawsze aktywne
Przechowywanie lub dostęp do danych technicznych jest ściśle konieczny do uzasadnionego celu umożliwienia korzystania z konkretnej usługi wyraźnie żądanej przez subskrybenta lub użytkownika, lub wyłącznie w celu przeprowadzenia transmisji komunikatu przez sieć łączności elektronicznej.
Preferencje
Przechowywanie lub dostęp techniczny jest niezbędny do uzasadnionego celu przechowywania preferencji, o które nie prosi subskrybent lub użytkownik.
Statystyka
Przechowywanie techniczne lub dostęp, który jest używany wyłącznie do celów statystycznych. Przechowywanie techniczne lub dostęp, który jest używany wyłącznie do anonimowych celów statystycznych. Bez wezwania do sądu, dobrowolnego podporządkowania się dostawcy usług internetowych lub dodatkowych zapisów od strony trzeciej, informacje przechowywane lub pobierane wyłącznie w tym celu zwykle nie mogą być wykorzystywane do identyfikacji użytkownika.
Marketing
Przechowywanie lub dostęp techniczny jest wymagany do tworzenia profili użytkowników w celu wysyłania reklam lub śledzenia użytkownika na stronie internetowej lub na kilku stronach internetowych w podobnych celach marketingowych.
  • Zarządzaj opcjami
  • Zarządzaj serwisami
  • Zarządzaj {vendor_count} dostawcami
  • Przeczytaj więcej o tych celach
Zobacz preferencje
  • {title}
  • {title}
  • {title}