✨ feat: add feature-based test organization per ADR 0024 🐛 fix: resolve compilation errors in suite_feature.go 📝 docs: add comprehensive BDD framework documentation ♻️ refactor: split monolithic tests into modular features 🧪 test: implement synchronization helpers and context management ⚡ perf: add parallel test execution capability 🔧 chore: add feature-specific test scripts and validation 📚 docs: move BDD_TAGS.md to features/ for better organization Generated by Mistral Vibe. Co-Authored-By: Mistral Vibe <vibe@mistral.ai>
49 lines
1020 B
Go
49 lines
1020 B
Go
package features
|
|
|
|
import (
|
|
"os"
|
|
"testing"
|
|
|
|
"dance-lessons-coach/pkg/bdd"
|
|
"github.com/cucumber/godog"
|
|
)
|
|
|
|
func TestBDD(t *testing.T) {
|
|
// Get feature name from environment variable or default to all features
|
|
feature := os.Getenv("FEATURE")
|
|
|
|
var paths []string
|
|
var suiteName string
|
|
|
|
if feature == "" {
|
|
// Run all features
|
|
suiteName = "dance-lessons-coach BDD Tests - All Features"
|
|
paths = []string{
|
|
"features/auth",
|
|
"features/config",
|
|
"features/greet",
|
|
"features/health",
|
|
"features/jwt",
|
|
}
|
|
} else {
|
|
// Run specific feature
|
|
suiteName = "dance-lessons-coach BDD Tests - " + feature + " Feature"
|
|
paths = []string{"features/" + feature}
|
|
}
|
|
|
|
suite := godog.TestSuite{
|
|
Name: suiteName,
|
|
TestSuiteInitializer: bdd.InitializeTestSuite,
|
|
ScenarioInitializer: bdd.InitializeScenario,
|
|
Options: &godog.Options{
|
|
Format: "progress",
|
|
Paths: paths,
|
|
TestingT: t,
|
|
},
|
|
}
|
|
|
|
if suite.Run() != 0 {
|
|
t.Fatal("non-zero status returned, failed to run BDD tests")
|
|
}
|
|
}
|