mirror of https://github.com/hashicorp/consul
ci: Run all connect/ca tests from the integration suite
To reduce the chance of some tests not being run because it does not match the regex passed to '-run'. Also document why some tests are allowed to be skipped on CI.pull/7485/head
parent
f4a35dfd84
commit
61ec7aa5c9
|
@ -569,8 +569,8 @@ jobs:
|
||||||
ENVOY_VERSIONS: "1.13.0"
|
ENVOY_VERSIONS: "1.13.0"
|
||||||
steps: *ENVOY_INTEGRATION_TEST_STEPS
|
steps: *ENVOY_INTEGRATION_TEST_STEPS
|
||||||
|
|
||||||
# run tests on vault ca provider integration tests
|
# run integration tests for the connect ca providers
|
||||||
vault-ca-provider:
|
test-connect-ca-providers:
|
||||||
docker:
|
docker:
|
||||||
- image: *GOLANG_IMAGE
|
- image: *GOLANG_IMAGE
|
||||||
environment:
|
environment:
|
||||||
|
@ -586,7 +586,7 @@ jobs:
|
||||||
# Gather deps to run go tests
|
# Gather deps to run go tests
|
||||||
- checkout
|
- checkout
|
||||||
# Run go tests
|
# Run go tests
|
||||||
- run: make test-vault-ca-provider
|
- run: make test-connect-ca-providers
|
||||||
- store_test_results:
|
- store_test_results:
|
||||||
path: *TEST_RESULTS_DIR
|
path: *TEST_RESULTS_DIR
|
||||||
|
|
||||||
|
@ -635,6 +635,8 @@ workflows:
|
||||||
- go-test
|
- go-test
|
||||||
- go-test-api
|
- go-test-api
|
||||||
- go-test-sdk
|
- go-test-sdk
|
||||||
|
- test-connect-ca-providers: *go-test
|
||||||
|
|
||||||
build-distros:
|
build-distros:
|
||||||
jobs:
|
jobs:
|
||||||
- check-vendor:
|
- check-vendor:
|
||||||
|
@ -686,9 +688,7 @@ workflows:
|
||||||
- envoy-integration-test-1.13.0:
|
- envoy-integration-test-1.13.0:
|
||||||
requires:
|
requires:
|
||||||
- dev-build
|
- dev-build
|
||||||
- vault-ca-provider:
|
|
||||||
requires:
|
|
||||||
- dev-build
|
|
||||||
website:
|
website:
|
||||||
jobs:
|
jobs:
|
||||||
- build-website
|
- build-website
|
||||||
|
|
|
@ -381,14 +381,14 @@ ui-docker: ui-build-image
|
||||||
test-envoy-integ: $(ENVOY_INTEG_DEPS)
|
test-envoy-integ: $(ENVOY_INTEG_DEPS)
|
||||||
@$(SHELL) $(CURDIR)/test/integration/connect/envoy/run-tests.sh
|
@$(SHELL) $(CURDIR)/test/integration/connect/envoy/run-tests.sh
|
||||||
|
|
||||||
test-vault-ca-provider:
|
test-connect-ca-providers:
|
||||||
ifeq ("$(CIRCLECI)","true")
|
ifeq ("$(CIRCLECI)","true")
|
||||||
# Run in CI
|
# Run in CI
|
||||||
gotestsum --format=short-verbose --junitfile "$(TEST_RESULTS_DIR)/gotestsum-report.xml" -- $(CURDIR)/agent/connect/ca/* -run 'TestVault(CA)?Provider'
|
gotestsum --format=short-verbose --junitfile "$(TEST_RESULTS_DIR)/gotestsum-report.xml" -- ./agent/connect/ca
|
||||||
else
|
else
|
||||||
# Run locally
|
# Run locally
|
||||||
@echo "Running /agent/connect/ca TestVault(CA)?Provider tests in verbose mode"
|
@echo "Running /agent/connect/ca tests in verbose mode"
|
||||||
@go test $(CURDIR)/agent/connect/ca/* -run 'TestVault(CA)?Provider' -v
|
@go test -v ./agent/connect/ca
|
||||||
endif
|
endif
|
||||||
|
|
||||||
proto-delete:
|
proto-delete:
|
||||||
|
|
|
@ -10,6 +10,13 @@ import (
|
||||||
"github.com/stretchr/testify/require"
|
"github.com/stretchr/testify/require"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// skipIfAWSNotConfigured skips the test unless ENABLE_AWS_PCA_TESTS=true.
|
||||||
|
//
|
||||||
|
// These tests are not run in CI. If you are making changes to the AWS provider
|
||||||
|
// you probably want to run these tests locally. The tests will run using any
|
||||||
|
// credentials available to the AWS SDK. See
|
||||||
|
// https://docs.aws.amazon.com/sdk-for-go/v1/developer-guide/configuring-sdk.html#specifying-credentials
|
||||||
|
// for a list of options.
|
||||||
func skipIfAWSNotConfigured(t *testing.T) {
|
func skipIfAWSNotConfigured(t *testing.T) {
|
||||||
enabled := os.Getenv("ENABLE_AWS_PCA_TESTS")
|
enabled := os.Getenv("ENABLE_AWS_PCA_TESTS")
|
||||||
ok, err := strconv.ParseBool(enabled)
|
ok, err := strconv.ParseBool(enabled)
|
||||||
|
|
|
@ -385,10 +385,10 @@ func testVaultProviderWithConfig(t *testing.T, isPrimary bool, rawConf map[strin
|
||||||
return provider, testVault
|
return provider, testVault
|
||||||
}
|
}
|
||||||
|
|
||||||
var printedVaultVersion sync.Once
|
// skipIfVaultNotPresent skips the test if the vault binary is not in PATH.
|
||||||
|
//
|
||||||
var mustAlwaysRun = os.Getenv("CI") == "true"
|
// These tests may be skipped in CI. They are run as part of a separate
|
||||||
|
// integration test suite.
|
||||||
func skipIfVaultNotPresent(t *testing.T) {
|
func skipIfVaultNotPresent(t *testing.T) {
|
||||||
vaultBinaryName := os.Getenv("VAULT_BINARY_NAME")
|
vaultBinaryName := os.Getenv("VAULT_BINARY_NAME")
|
||||||
if vaultBinaryName == "" {
|
if vaultBinaryName == "" {
|
||||||
|
@ -397,9 +397,6 @@ func skipIfVaultNotPresent(t *testing.T) {
|
||||||
|
|
||||||
path, err := exec.LookPath(vaultBinaryName)
|
path, err := exec.LookPath(vaultBinaryName)
|
||||||
if err != nil || path == "" {
|
if err != nil || path == "" {
|
||||||
if mustAlwaysRun {
|
|
||||||
t.Fatalf("%q not found on $PATH", vaultBinaryName)
|
|
||||||
}
|
|
||||||
t.Skipf("%q not found on $PATH - download and install to run this test", vaultBinaryName)
|
t.Skipf("%q not found on $PATH - download and install to run this test", vaultBinaryName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -474,6 +471,8 @@ type testVaultServer struct {
|
||||||
returnPortsFn func()
|
returnPortsFn func()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var printedVaultVersion sync.Once
|
||||||
|
|
||||||
func (v *testVaultServer) WaitUntilReady(t *testing.T) {
|
func (v *testVaultServer) WaitUntilReady(t *testing.T) {
|
||||||
var version string
|
var version string
|
||||||
retry.Run(t, func(r *retry.R) {
|
retry.Run(t, func(r *retry.R) {
|
||||||
|
|
Loading…
Reference in New Issue