in e2e_tests/main.go [60:121]
func main() {
ctx := context.Background()
if err := gcpclients.PopulateClients(ctx); err != nil {
log.Fatal(err)
}
testLogger := log.New(os.Stdout, "[OsConfigTests] ", 0)
testLogger.Println("Starting...")
// Initialize logger for any shared function calls.
opts := logger.LogOpts{LoggerName: "OsConfigTests", Debug: true, Writers: []io.Writer{&logWriter{log: testLogger}}, DisableCloudLogging: true, DisableLocalLogging: true}
logger.Init(ctx, opts)
tests := make(chan *junitxml.TestSuite)
var wg sync.WaitGroup
for _, tf := range testFunctions {
wg.Add(1)
go tf(ctx, &wg, tests, testLogger, config.TestSuiteFilter(), config.TestCaseFilter())
}
go func() {
wg.Wait()
close(tests)
}()
var testSuites []*junitxml.TestSuite
for ret := range tests {
testSuites = append(testSuites, ret)
testSuiteOutPath := filepath.Join(*config.OutDir, fmt.Sprintf("junit_%s.xml", ret.Name))
if err := os.MkdirAll(filepath.Dir(testSuiteOutPath), 0770); err != nil {
testLogger.Fatal(err)
}
testLogger.Printf("Creating junit xml file: %s", testSuiteOutPath)
d, err := xml.MarshalIndent(ret, " ", " ")
if err != nil {
testLogger.Fatal(err)
}
if err := ioutil.WriteFile(testSuiteOutPath, d, 0644); err != nil {
testLogger.Fatal(err)
}
}
var buf bytes.Buffer
for _, ts := range testSuites {
if ts.Failures > 0 {
buf.WriteString(fmt.Sprintf("TestSuite %q has errors:\n", ts.Name))
for _, tc := range ts.TestCase {
if tc.Failure != nil {
buf.WriteString(fmt.Sprintf(" - %q: %s\n", tc.Name, tc.Failure.FailMessage))
}
}
}
}
if buf.Len() > 0 {
testLogger.Fatalf("%sExiting with exit code 1", buf.String())
}
testLogger.Print("All test cases completed successfully.")
}