/* * 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.params.converter; import static org.junit.platform.commons.meta.API.Usage.Experimental; import org.junit.jupiter.api.extension.ParameterContext; import org.junit.platform.commons.meta.API; /** * {@code ArgumentConverter} is an abstraction that allows an input object to * be converted to an instance of a different class. * * <p>Such an {@code ArgumentConverter} is applied to the method parameter * of a {@link org.junit.jupiter.params.ParameterizedTest @ParameterizedTest} * method with the help of a * {@link org.junit.jupiter.params.converter.ConvertWith @ConvertWith} annotation. * * @since 5.0 * @see org.junit.jupiter.params.ParameterizedTest * @see org.junit.jupiter.params.converter.ConvertWith */ @API(Experimental) public interface ArgumentConverter { Object convert(Object input, ParameterContext context) throws ArgumentConversionException; }