IAnswer.java revision 47d431f63a66505a645f282416659a9758a91f1c
147d431f63a66505a645f282416659a9758a91f1cBrett Chabot/* 247d431f63a66505a645f282416659a9758a91f1cBrett Chabot * Copyright 2001-2009 OFFIS, Tammo Freese 347d431f63a66505a645f282416659a9758a91f1cBrett Chabot * 447d431f63a66505a645f282416659a9758a91f1cBrett Chabot * Licensed under the Apache License, Version 2.0 (the "License"); 547d431f63a66505a645f282416659a9758a91f1cBrett Chabot * you may not use this file except in compliance with the License. 647d431f63a66505a645f282416659a9758a91f1cBrett Chabot * You may obtain a copy of the License at 747d431f63a66505a645f282416659a9758a91f1cBrett Chabot * 847d431f63a66505a645f282416659a9758a91f1cBrett Chabot * http://www.apache.org/licenses/LICENSE-2.0 947d431f63a66505a645f282416659a9758a91f1cBrett Chabot * 1047d431f63a66505a645f282416659a9758a91f1cBrett Chabot * Unless required by applicable law or agreed to in writing, software 1147d431f63a66505a645f282416659a9758a91f1cBrett Chabot * distributed under the License is distributed on an "AS IS" BASIS, 1247d431f63a66505a645f282416659a9758a91f1cBrett Chabot * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 1347d431f63a66505a645f282416659a9758a91f1cBrett Chabot * See the License for the specific language governing permissions and 1447d431f63a66505a645f282416659a9758a91f1cBrett Chabot * limitations under the License. 1547d431f63a66505a645f282416659a9758a91f1cBrett Chabot */ 1647d431f63a66505a645f282416659a9758a91f1cBrett Chabotpackage org.easymock; 1747d431f63a66505a645f282416659a9758a91f1cBrett Chabot 1847d431f63a66505a645f282416659a9758a91f1cBrett Chabot/** 1947d431f63a66505a645f282416659a9758a91f1cBrett Chabot * Used to answer expected calls. 2047d431f63a66505a645f282416659a9758a91f1cBrett Chabot * @param <T> the type to return. 2147d431f63a66505a645f282416659a9758a91f1cBrett Chabot */ 2247d431f63a66505a645f282416659a9758a91f1cBrett Chabotpublic interface IAnswer<T> { 2347d431f63a66505a645f282416659a9758a91f1cBrett Chabot /** 2447d431f63a66505a645f282416659a9758a91f1cBrett Chabot * is called by EasyMock to answer an expected call. 2547d431f63a66505a645f282416659a9758a91f1cBrett Chabot * The answer may be to return a value, or to throw an exception. 2647d431f63a66505a645f282416659a9758a91f1cBrett Chabot * The arguments of the call for which the answer is generated 2747d431f63a66505a645f282416659a9758a91f1cBrett Chabot * are available via {@link EasyMock#getCurrentArguments()} - be careful 2847d431f63a66505a645f282416659a9758a91f1cBrett Chabot * here, using the arguments is not refactoring-safe. 2947d431f63a66505a645f282416659a9758a91f1cBrett Chabot * 3047d431f63a66505a645f282416659a9758a91f1cBrett Chabot * @return the value to be returned 3147d431f63a66505a645f282416659a9758a91f1cBrett Chabot * @throws Throwable the throwable to be thrown 3247d431f63a66505a645f282416659a9758a91f1cBrett Chabot */ 3347d431f63a66505a645f282416659a9758a91f1cBrett Chabot T answer() throws Throwable; 3447d431f63a66505a645f282416659a9758a91f1cBrett Chabot} 35