feat(hooks): run PHPUnit in pre-commit hook (#67)
All checks were successful
Deploy Feature Branch to Test / PHP Syntax Check (push) Successful in 34s
Lint / PHP Syntax Check (push) Successful in 57s
Deploy Feature Branch to Test / CSS Lint (stylelint) (push) Successful in 1m41s
Deploy Feature Branch to Test / HTML Lint (htmlhint) (push) Successful in 1m39s
Lint / CSS Lint (stylelint) (push) Successful in 1m39s
Lint / HTML Lint (htmlhint) (push) Successful in 1m8s
Deploy Feature Branch to Test / Deploy to Test Environment (push) Successful in 30s

Erweitert den Husky pre-commit-Hook um einen PHPUnit-Schritt.
Ausserdem wird scripts/safe-commit.sh aktualisiert, damit das
Safety-Net dieselbe Logik wie der Hook verwendet (kein doppelter Code).

Vorher: Hook rief nur 'npx lint-staged' auf.
Nachher: Hook ruft scripts/pre-commit-checks.sh auf, das
  - lint-staged ausfuehrt (unveraendert)
  - PHPUnit nur dann ausfuehrt, wenn PHP-relevante Dateien
    gestaged sind (Performance-Optimierung: Issue #67 Anforderung)
  - Bei Test-Fehler den Commit mit Exit-Code 1 abbricht

Closes #67
This commit is contained in:
Hermes
2026-06-03 23:42:31 +00:00
parent 85cf4f3b03
commit b0f769d186
2 changed files with 7 additions and 13 deletions

View File

@@ -1 +1,3 @@
npx lint-staged # Delegiert an scripts/pre-commit-checks.sh
# (gleiche Logik wie safe-commit.sh-Safety-Net, nur einmalig)
./scripts/pre-commit-checks.sh

View File

@@ -2,7 +2,7 @@
# safe-commit.sh Commit with pre-commit hooks guaranteed to run # safe-commit.sh Commit with pre-commit hooks guaranteed to run
# Usage: ./scripts/safe-commit.sh "commit message" # Usage: ./scripts/safe-commit.sh "commit message"
# #
# This script ensures lint checks always execute, even when committing # This script ensures lint + PHPUnit checks always execute, even when committing
# from non-interactive contexts (CI, AI agents, etc.). # from non-interactive contexts (CI, AI agents, etc.).
set -euo pipefail set -euo pipefail
@@ -21,17 +21,9 @@ if [ -d ".husky" ]; then
git config core.hooksPath .husky git config core.hooksPath .husky
fi fi
# Run lint-staged manually as a safety net (in case hook is skipped) # Run pre-commit checks manually as a safety net (in case hook is skipped)
if command -v npx &>/dev/null && [ -f "node_modules/.bin/lint-staged" ]; then # Same logic as .husky/pre-commit, just in case the hook is bypassed.
echo "🔍 Running pre-commit lint checks..." ./scripts/pre-commit-checks.sh
npx lint-staged || {
echo ""
echo "❌ Lint checks failed. Commit aborted."
echo " Fix the errors above and try again."
exit 1
}
echo "✅ All lint checks passed."
fi
# Commit with hooks enabled (no --no-verify) # Commit with hooks enabled (no --no-verify)
git commit -m "$MSG" git commit -m "$MSG"