org.junit.jupiter.api.extension.TestInstancePreDestroyCallback Maven / Gradle / Ivy
Show all versions of junit-jupiter-api Show documentation
/*
* Copyright 2015-2021 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.extension;
import static org.apiguardian.api.API.Status.EXPERIMENTAL;
import static org.apiguardian.api.API.Status.STABLE;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Optional;
import java.util.function.Consumer;
import org.apiguardian.api.API;
import org.junit.jupiter.api.Nested;
import org.junit.jupiter.api.TestInstance.Lifecycle;
/**
* {@code TestInstancePreDestroyCallback} defines the API for {@link Extension
* Extensions} that wish to process test instances after they have been
* used in tests but before they are destroyed.
*
* Common use cases include releasing resources that have been created for
* the test instance, invoking custom clean-up methods on the test instance, etc.
*
*
Extensions that implement {@code TestInstancePreDestroyCallback} must be
* registered at the class level if the test class is configured with
* {@link Lifecycle @TestInstance(Lifecycle.PER_CLASS)}
* semantics. If the test class is configured with
* {@link Lifecycle @TestInstance(Lifecycle.PER_METHOD)}
* semantics, {@code TestInstancePreDestroyCallback} extensions may be registered
* at the class level or at the method level. In the latter case, the
* {@code TestInstancePreDestroyCallback} extension will only be applied to the
* test method for which it is registered.
*
*
Constructor Requirements
*
* Consult the documentation in {@link Extension} for details on constructor
* requirements.
*
* @since 5.6
* @see #preDestroyTestInstance(ExtensionContext)
* @see TestInstancePostProcessor
* @see TestInstanceFactory
* @see ParameterResolver
*/
@FunctionalInterface
@API(status = STABLE, since = "5.7")
public interface TestInstancePreDestroyCallback extends Extension {
/**
* Callback for processing test instances before they are destroyed.
*
*
Contrary to {@link TestInstancePostProcessor#postProcessTestInstance}
* this method is only called once for each {@link ExtensionContext} even if
* there are multiple test instances about to be destroyed in case of
* {@link Nested @Nested} tests. Please use the provided
* {@link #preDestroyTestInstances(ExtensionContext, Consumer)} utility
* method to ensure that all test instances are handled.
*
* @param context the current extension context; never {@code null}
* @see ExtensionContext#getTestInstance()
* @see ExtensionContext#getRequiredTestInstance()
* @see ExtensionContext#getTestInstances()
* @see ExtensionContext#getRequiredTestInstances()
* @see #preDestroyTestInstances(ExtensionContext, Consumer)
*/
void preDestroyTestInstance(ExtensionContext context) throws Exception;
/**
* Utility method for processing all test instances of an
* {@link ExtensionContext} that are not present in any of its parent
* contexts.
*
*
This method should be called in order to implement this interface
* correctly since it ensures that the right test instances are processed
* regardless of the used {@linkplain Lifecycle lifecycle}. The supplied
* callback is called once per test instance that is about to be destroyed
* starting with the innermost one.
*
*
This method is intended to be called from an implementation of
* {@link #preDestroyTestInstance(ExtensionContext)} like this:
*
*
{@code class MyExtension implements TestInstancePreDestroyCallback {
* @Override
* public void preDestroyTestInstance(ExtensionContext context) {
* TestInstancePreDestroyCallback.preDestroyTestInstances(context, testInstance -> {
* // custom logic that processes testInstance
* });
* }
*}}
*
* @param context the current extension context; never {@code null}
* @param callback the callback to be invoked for every test instance of the
* current extension context that is about to be destroyed; never
* {@code null}
* @since 5.7.1
*/
@API(status = EXPERIMENTAL, since = "5.7.1")
static void preDestroyTestInstances(ExtensionContext context, Consumer