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

mockit.Delegate Maven / Gradle / Ivy

Go to download

JMockit is a Java toolkit for automated developer testing. It contains APIs for the creation of the objects to be tested, for mocking dependencies, and for faking external APIs; JUnit (4 & 5) and TestNG test runners are supported. It also contains an advanced code coverage tool.

There is a newer version: 1.49
Show newest version
/*
 * Copyright (c) 2006 Rogério Liesenfeld
 * This file is subject to the terms of the MIT license (see LICENSE.txt).
 */
package mockit;

/**
 * An empty interface to be used with the {@link Expectations#result} field or the
 * Invocations#with(Delegate) method, allowing test code to define
 * varying invocation results or argument matching rules, respectively.
 * 

* When combined with the result field, a test will typically assign it with an anonymous class object * implementing this interface and containing a delegate method: *

 *    new Expectations() {{
 *       mock.doSomething(anyInt, anyString);
 *       result = new Delegate() {
 *          String delegate(int i, String s) {
 *             return i > 0 ? s : "";
 *          }
 *       };
 *    }};
 *
 *    tested.exerciseCodeUnderTest();
 * 
* The delegate class (either named or anonymous) must contain exactly one non-private instance method to * be executed when the mocked method or mocked constructor is invoked; it can contain any number of private * or static methods, though. * The name of the delegate method can be anything. * Its parameters, however, should be the same as the parameters of the corresponding mocked method/constructor, or at * least be compatible with them. * Optionally, the delegate method can have an extra parameter of type {@link Invocation}, provided it appears as the * first one. * The delegate method is also allowed to have no parameters (without counting the optional Invocation * parameter). *

* When used with the result field, the result of a delegate method execution can be any return value compatible * with the recorded method's return type, or a thrown error/exception. *

* When used with the with(Delegate) method, the delegate method must return a boolean, being * true for a successfully matched argument or false otherwise. *

* Finally, note that a static method in the mocked type can have a delegate as well. * The same is true for private, final, and native methods. * * @see Tutorial * * @param the type of the argument to be matched, when used with the with(Delegate) method */ public interface Delegate { }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy