All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.junitpioneer.jupiter.SetSystemProperty Maven / Gradle / Ivy

There is a newer version: 2.3.0
Show newest version
/*
 * Copyright 2016-2022 the original author or authors.
 *
 * All rights reserved. This program and the accompanying materials are
 * made available under the terms of the Eclipse Public License v2.0 which
 * accompanies this distribution and is available at
 *
 * http://www.eclipse.org/legal/epl-v20.html
 */

package org.junitpioneer.jupiter;

import java.lang.annotation.ElementType;
import java.lang.annotation.Inherited;
import java.lang.annotation.Repeatable;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

import org.junit.jupiter.api.extension.ExtendWith;

/**
 * {@code @SetSystemProperty} is a JUnit Jupiter extension to set the value of a
 * system property for a test execution.
 *
 * 

The key and value of the system property to be set must be specified via * {@link #key()} and {@link #value()}. After the annotated method has been * executed, the original value or the value of the higher-level container is * restored.

* *

{@code SetSystemProperty} can be used on the method and on the class level. * It is repeatable and inherited from higher-level containers. If a class is * annotated, the configured property will be set before every test inside that * class. Any method-level configurations will override the class-level * configurations.

* *

During * parallel test execution, * all tests annotated with {@link ClearSystemProperty}, {@link SetSystemProperty}, {@link ReadsSystemProperty}, and {@link WritesSystemProperty} * are scheduled in a way that guarantees correctness under mutation of shared global state. *

* *

For more details and examples, see * the documentation on @ClearSystemProperty and @SetSystemProperty. *

* * @since 0.5 */ @Retention(RetentionPolicy.RUNTIME) @Target({ ElementType.METHOD, ElementType.TYPE }) @Inherited @Repeatable(SetSystemProperty.SetSystemProperties.class) @WritesSystemProperty @ExtendWith(SystemPropertyExtension.class) public @interface SetSystemProperty { /** * The key of the system property to be set. */ String key(); /** * The value of the system property to be set. */ String value(); /** * Containing annotation of repeatable {@code @SetSystemProperty}. */ @Retention(RetentionPolicy.RUNTIME) @Target({ ElementType.METHOD, ElementType.TYPE }) @Inherited @WritesSystemProperty @ExtendWith(SystemPropertyExtension.class) @interface SetSystemProperties { SetSystemProperty[] value(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy