databricks-cli/integration/bundle
Pieter Noordhuis 70b7bbfd81
Remove calls to `t.Setenv` from integration tests (#2018)
## Changes

The `Setenv` helper function configures an environment variable and
resets it to its original value when exiting the test scope. It is
incompatible with running tests in parallel because it modifies
process-wide state. The `libs/env` package defines functions to interact
with the environment but records `Setenv` calls on a `context.Context`.
This enables us to override/specialize the environment scoped to a
context.

Pre-requisites for removing the `t.Setenv` calls:
* Make `cmdio.NewIO` accept a context and use it with `libs/env`
* Make all `internal/testcli` functions use a context

The rest of this change:
* Modifies integration tests to initialize a context to use if there
wasn't already one
* Updates `t.Setenv` calls to use `env.Set`

## Tests

n/a
2024-12-16 12:34:37 +01:00
..
bundles Move integration tests to `integration` package (#2009) 2024-12-13 15:38:58 +01:00
testdata/init/field-does-not-exist Move integration tests to `integration` package (#2009) 2024-12-13 15:38:58 +01:00
artifacts_test.go Remove calls to `t.Setenv` from integration tests (#2018) 2024-12-16 12:34:37 +01:00
basic_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
bind_resource_test.go Remove calls to `t.Setenv` from integration tests (#2018) 2024-12-16 12:34:37 +01:00
clusters_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
dashboards_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
deploy_test.go Remove calls to `t.Setenv` from integration tests (#2018) 2024-12-16 12:34:37 +01:00
deploy_then_remove_resources_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
deploy_to_shared_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
deployment_state_test.go Remove calls to `t.Setenv` from integration tests (#2018) 2024-12-16 12:34:37 +01:00
destroy_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
empty_bundle_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
environments_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
generate_job_test.go Remove calls to `t.Setenv` from integration tests (#2018) 2024-12-16 12:34:37 +01:00
generate_pipeline_test.go Remove calls to `t.Setenv` from integration tests (#2018) 2024-12-16 12:34:37 +01:00
helpers_test.go Remove calls to `t.Setenv` from integration tests (#2018) 2024-12-16 12:34:37 +01:00
init_test.go Remove calls to `t.Setenv` from integration tests (#2018) 2024-12-16 12:34:37 +01:00
job_metadata_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
local_state_staleness_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
main_test.go Move integration tests to `integration` package (#2009) 2024-12-13 15:38:58 +01:00
python_wheel_test.go Remove superfluous name prefix for integration tests (#2012) 2024-12-13 15:47:50 +01:00
spark_jar_test.go Remove calls to `testutil.GetEnvOrSkipTest(t, "CLOUD_ENV")` (#2014) 2024-12-13 16:09:51 +00:00
validate_test.go Remove calls to `testutil.GetEnvOrSkipTest(t, "CLOUD_ENV")` (#2014) 2024-12-13 16:09:51 +00:00