🧪 test: add JWT secret rotation BDD scenarios and step implementations (#12)
All checks were successful
CI/CD Pipeline / Build Docker Cache (push) Successful in 9s
CI/CD Pipeline / CI Pipeline (push) Successful in 4m15s
CI/CD Pipeline / Trigger Docker Push (push) Has been skipped

 merge: implement JWT secret rotation with BDD scenario isolation

- Implement JWT secret rotation mechanism (closes #8)
- Add per-scenario state isolation for BDD tests (closes #14)
- Validate password reset workflow via BDD tests (closes #7)
- Fix port conflicts in test validation
- Add state tracer for debugging test execution
- Document BDD isolation strategies in ADR 0025
- Fix PostgreSQL configuration environment variables

Generated by Mistral Vibe.
Co-Authored-By: Mistral Vibe <vibe@mistral.ai>
Co-authored-by: Gabriel Radureau <arcodange@gmail.com>
Co-committed-by: Gabriel Radureau <arcodange@gmail.com>
This commit was merged in pull request #12.
This commit is contained in:
2026-04-11 17:56:45 +02:00
committed by arcodange
parent 5de703468f
commit 5eec64e5e8
66 changed files with 10025 additions and 701 deletions

78
pkg/bdd/suite_feature.go Normal file
View File

@@ -0,0 +1,78 @@
package bdd
import (
"dance-lessons-coach/pkg/bdd/steps"
"dance-lessons-coach/pkg/bdd/testserver"
"os"
"github.com/cucumber/godog"
"github.com/rs/zerolog/log"
)
// FeatureSuiteContext holds feature-specific test suite context
type FeatureSuiteContext struct {
featureName string
client *testserver.Client
// Add other feature contexts as needed
}
// InitializeFeatureSuite initializes a feature-specific test suite
func InitializeFeatureSuite(ctx *godog.TestSuiteContext) {
featureName := os.Getenv("FEATURE")
if featureName == "" {
featureName = "all"
}
log.Debug().Str("feature", featureName).Msg("Initializing feature suite")
ctx.BeforeSuite(func() {
// Initialize shared server for this feature
server := testserver.NewServer()
if err := server.Start(); err != nil {
panic(err)
}
// Store server in a way that can be accessed by scenarios
// This would need to be properly implemented
})
ctx.AfterSuite(func() {
// Cleanup feature-specific resources
log.Debug().Str("feature", featureName).Msg("Cleaning up feature suite")
})
}
// InitializeFeatureScenario initializes a feature-specific scenario
func InitializeFeatureScenario(ctx *godog.ScenarioContext, client *testserver.Client) {
featureName := os.Getenv("FEATURE")
switch featureName {
case "auth":
// Initialize auth-specific context if needed
steps.InitializeAllSteps(ctx, client, nil)
case "config":
// Initialize config-specific context if needed
steps.InitializeAllSteps(ctx, client, nil)
case "greet":
// Initialize greet-specific context if needed
steps.InitializeAllSteps(ctx, client, nil)
case "health":
// Initialize health-specific context if needed
steps.InitializeAllSteps(ctx, client, nil)
case "jwt":
// Initialize JWT-specific context if needed
steps.InitializeAllSteps(ctx, client, nil)
default:
// Fallback to all steps for backward compatibility
steps.InitializeAllSteps(ctx, client, nil)
}
}
// CleanupFeatureSuite cleans up feature-specific resources
func CleanupFeatureSuite() {
featureName := os.Getenv("FEATURE")
log.Debug().Str("feature", featureName).Msg("Cleaning up feature suite")
// Feature-specific cleanup would go here
steps.CleanupAllTestConfigFiles()
}