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

io.cucumber.spring.CucumberContextConfiguration Maven / Gradle / Ivy

package io.cucumber.spring;

import org.apiguardian.api.API;

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

/**
 * This annotation is used on a configuration class to make the Cucumber aware
 * of the test configuration. This is to be used in conjunction with
 * {@code @ContextConfiguration}, {@code @ContextHierarchy} or
 * {@code @BootstrapWith}. In case of SpringBoot, the configuration class can be
 * annotated as follows:
 * 

* *

 * @CucumberContextConfiguration
 * @SpringBootTest(classes = TestConfig.class)
 * public class CucumberSpringConfiguration {
 * }
 * 
*

* Notes: *

    *
  • Only one glue class should be annotated with * {@code @CucumberContextConfiguration} otherwise an exception will be * thrown.
  • *
  • Cucumber Spring uses Spring's {@code TestContextManager} framework * internally. As a result a single Cucumber scenario will mostly behave like a * JUnit test.
  • *
  • The class annotated with {@code CucumberContextConfiguration} is * instantiated but not initialized by Spring. This instance is processed by * Springs {@link org.springframework.test.context.TestExecutionListener * TestExecutionListeners}. So features that depend on a test execution listener * such as mock beans will work on the annotated class - but not on other step * definition classes. Features that depend on initializing beans - such as * AspectJ - will not work on the annotated class - but will work on step * definition classes.
  • *
  • *
*/ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.TYPE) @API(status = API.Status.STABLE) public @interface CucumberContextConfiguration { }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy