/* * Copyright 2015-2017 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 v1.0 which * accompanies this distribution and is available at * * http://www.eclipse.org/legal/epl-v10.html */ package org.junit.jupiter.engine.discovery; import static org.junit.platform.commons.meta.API.Usage.Experimental; import java.lang.reflect.AnnotatedElement; import java.util.Optional; import java.util.Set; import org.junit.platform.commons.meta.API; import org.junit.platform.engine.TestDescriptor; import org.junit.platform.engine.UniqueId; /** * @since 5.0 */ @API(Experimental) interface ElementResolver { /** * 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 {@link TestDescriptor}. * * <p>Return {@code Optional.empty()} if {@code segment} cannot be resolved. */ Optional<TestDescriptor> resolveUniqueId(UniqueId.Segment segment, TestDescriptor parent); }