software.amazon.awssdk.testutils.EnvironmentVariableHelper Maven / Gradle / Ivy
/*
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://aws.amazon.com/apache2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package software.amazon.awssdk.testutils;
import java.util.function.Consumer;
import org.junit.rules.ExternalResource;
import software.amazon.awssdk.utils.SystemSetting;
import software.amazon.awssdk.utils.internal.SystemSettingUtilsTestBackdoor;
/**
* A utility that can temporarily forcibly set environment variables and then allows resetting them to the original values.
*
* This only works for environment variables read by the SDK.
*/
public class EnvironmentVariableHelper extends ExternalResource {
public void remove(SystemSetting setting) {
remove(setting.environmentVariable());
}
public void remove(String key) {
SystemSettingUtilsTestBackdoor.addEnvironmentVariableOverride(key, null);
}
public void set(SystemSetting setting, String value) {
set(setting.environmentVariable(), value);
}
public void set(String key, String value) {
SystemSettingUtilsTestBackdoor.addEnvironmentVariableOverride(key, value);
}
public void reset() {
SystemSettingUtilsTestBackdoor.clearEnvironmentVariableOverrides();
}
@Override
protected void after() {
reset();
}
/**
* Static run method that allows for "single-use" environment variable modification.
*
* Example use:
*
* {@code
* EnvironmentVariableHelper.run(helper -> {
* helper.set("variable", "value");
* //run some test that uses "variable"
* });
* }
*
*
* Will call {@link #reset} at the end of the block (even if the block exits exceptionally).
*
* @param helperConsumer a code block to run that gets an {@link EnvironmentVariableHelper} as an argument
*/
public static void run(Consumer helperConsumer) {
EnvironmentVariableHelper helper = new EnvironmentVariableHelper();
try {
helperConsumer.accept(helper);
} finally {
helper.reset();
}
}
}