/*
* Copyright 2015-2019 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.junit.jupiter.engine.discovery;
import java.lang.reflect.AnnotatedElement;
import java.util.Optional;
import java.util.Set;
import org.junit.platform.engine.TestDescriptor;
import org.junit.platform.engine.UniqueId;
Since: 5.0
/**
* @since 5.0
*/
interface ElementResolver {
Return a set of TestDescriptors
that can be resolved by this resolver. Returned set must be empty if element
cannot be resolved.
/**
* Return a set of {@link TestDescriptor TestDescriptors} that can be
* resolved by this resolver.
*
* <p>Returned set must be empty if {@code element} cannot be resolved.
*/
Set<TestDescriptor> resolveElement(AnnotatedElement element, TestDescriptor parent);
Return an optional TestDescriptor
. Return Optional.empty()
if segment
cannot be resolved.
/**
* Return an optional {@link TestDescriptor}.
*
* <p>Return {@code Optional.empty()} if {@code segment} cannot be resolved.
*/
Optional<TestDescriptor> resolveUniqueId(UniqueId.Segment segment, TestDescriptor parent);
}