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

org.junit.jupiter.api.Nested Maven / Gradle / Ivy

There is a newer version: 5.11.4
Show newest version
/*
 * Copyright 2015-2024 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
 *
 * https://www.eclipse.org/legal/epl-v20.html
 */

package org.junit.jupiter.api;

import static org.apiguardian.api.API.Status.STABLE;

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

import org.apiguardian.api.API;
import org.junit.jupiter.api.TestInstance.Lifecycle;

/**
 * {@code @Nested} is used to signal that the annotated class is a nested,
 * non-static test class (i.e., an inner class) that can share
 * setup and state with an instance of its {@linkplain Class#getEnclosingClass()
 * enclosing class}. The enclosing class may be a top-level test class or
 * another {@code @Nested} test class, and nesting can be arbitrarily deep.
 *
 * 

{@code @Nested} test classes may be ordered via * {@link TestClassOrder @TestClassOrder} or a global {@link ClassOrderer}. * *

Test Instance Lifecycle

* *
    *
  • A {@code @Nested} test class can be configured with its own * {@link Lifecycle} mode which may differ from that of an enclosing test * class.
  • *
  • A {@code @Nested} test class cannot change the {@link Lifecycle} * mode of an enclosing test class.
  • *
* * @since 5.0 * @see Test * @see TestInstance * @see TestClassOrder */ @Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME) @Documented @API(status = STABLE, since = "5.0") public @interface Nested { }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy