🧪 test: fix BDD step registration and update CI/CD workflow
Some checks failed
CI/CD Pipeline / Build Docker Cache (push) Successful in 17s
CI/CD Pipeline / CI Pipeline (push) Has been cancelled

- Fix step pattern escaping in pkg/bdd/steps/steps.go:80
- Update CI/CD workflow to use run-bdd-tests.sh script
- Enhance run-bdd-tests.sh for both local and CI environments
- Add strict validation for undefined/pending/skipped steps
- Update BDD testing documentation with pattern requirements

The CI/CD pipeline now properly validates BDD tests and fails on any
undefined, pending, or skipped steps. All 22 BDD scenarios are passing
with correct step pattern registration.
This commit is contained in:
2026-04-08 12:13:17 +02:00
parent f013a1771d
commit 5bfb08abc7
7 changed files with 854 additions and 51 deletions

View File

@@ -15,7 +15,12 @@ Feature: Greet Service
Then the response should be "..." # ??? UNDEFINED STEP
```
**Root Cause:** Step patterns don't match Godog's exact expectations.
**Root Cause:** Step patterns don't match Godog's exact expectations. Godog is very particular about regex escaping.
**Common Pattern Issues:**
- `\"` vs `\\"` (single vs double escaping)
- Exact quote handling in JSON patterns
- Parameter capture group syntax
**Debugging Steps:**
@@ -28,25 +33,30 @@ Feature: Greet Service
```
You can implement step definitions for the undefined steps with these snippets:
func theServerIsRunning() error {
func theResponseShouldBe(arg1, arg2 string) error {
return godog.ErrPending
}
func iRequestTheDefaultGreeting() error {
return godog.ErrPending
func InitializeScenario(ctx *godog.ScenarioContext) {
ctx.Step(`^the response should be "{\\"([^"]*)\\":\\"([^"]*)\\"}"$`, theResponseShouldBe)
}
```
3. **Compare with your implementation:**
```go
// ❌ Wrong pattern
ctx.Step(`^the server is running$`, sc.theServerIsRunning)
// ❌ Wrong pattern (single escaping)
ctx.Step(`^the response should be "{\"([^"]*)\":\"([^"]*)\"}"$`, sc.commonSteps.theResponseShouldBe)
// ✅ Correct pattern (matches Godog's suggestion)
ctx.Step(`^the server is running$`, sc.theServerIsRunning)
// ✅ Correct pattern (double escaping - matches Godog's suggestion)
ctx.Step(`^the response should be "{\\"([^"]*)\\":\\"([^"]*)\\"}"$`, sc.commonSteps.theResponseShouldBe)
```
**Solution:** Use Godog's EXACT regex patterns.
**Key Insight:** Godog expects `\\"` (four backslashes + quote) for escaped quotes in JSON patterns, not `\"` (two backslashes + quote).
**Solution:** Use Godog's EXACT regex patterns, paying special attention to:
- JSON escaping: `\\"` not `\"`
- Parameter names: Use `arg1, arg2` as suggested
- Capture groups: Match Godog's exact regex syntax
### 2. JSON Comparison Failures

View File

@@ -87,4 +87,10 @@ Godog's step matching is **very specific by design**:
- It provides exact patterns to ensure consistency
- Following its suggestions guarantees your steps will be recognized
**Remember**: The "undefined" warnings are Godog telling you exactly how to fix your step definitions!
**Remember**: The "undefined" warnings are Godog telling you exactly how to fix your step definitions!
## Critical Pattern Fix
**File:** `pkg/bdd/steps/steps.go`
**Line:** 80
**Issue:** Step pattern must use double escaping (4 backslashes + quote) not single escaping (2 backslashes + quote)
**Pattern:** `^the response should be "{\\"([^"]*)\\":\\"([^"]*)\\"}"$`