A timeout doesn't make sense on this level, because it is very difficult to estimate how long downloading rpm metadata takes. Drop it completely in favor of higher-level timeouts in the test runner. Fixes #601
52 lines
1.1 KiB
Go
52 lines
1.1 KiB
Go
// Package client - integration_test contains functions to setup integration tests
|
|
// Copyright (C) 2020 by Red Hat, Inc.
|
|
|
|
// +build integration
|
|
|
|
package client
|
|
|
|
import (
|
|
"fmt"
|
|
"os"
|
|
"testing"
|
|
|
|
"github.com/osbuild/osbuild-composer/internal/test"
|
|
)
|
|
|
|
// Hold test state to share between tests
|
|
var testState *TestState
|
|
|
|
// Setup the socket to use for running the tests
|
|
// Also makes sure there is a running server to test against
|
|
func executeTests(m *testing.M) int {
|
|
var err error
|
|
testState, err = setUpTestState("/run/weldr/api.socket", false)
|
|
if err != nil {
|
|
fmt.Printf("ERROR: Test setup failed: %s\n", err)
|
|
panic(err)
|
|
}
|
|
|
|
// Setup the test repo
|
|
dir, err := test.SetUpTemporaryRepository()
|
|
if err != nil {
|
|
fmt.Printf("ERROR: Test repo setup failed: %s\n", err)
|
|
panic(err)
|
|
}
|
|
|
|
// Cleanup after the tests
|
|
defer func() {
|
|
err := test.TearDownTemporaryRepository(dir)
|
|
if err != nil {
|
|
fmt.Printf("ERROR: Failed to clean up temporary repository: %s\n", err)
|
|
}
|
|
}()
|
|
|
|
testState.repoDir = dir
|
|
|
|
// Run the tests
|
|
return m.Run()
|
|
}
|
|
|
|
func TestMain(m *testing.M) {
|
|
os.Exit(executeTests(m))
|
|
}
|