|
|
2bed83 |
diff -r d382aea89c3d easymock/src/main/java/org/easymock/EasyMock.java
|
|
|
2bed83 |
--- a/easymock/src/main/java/org/easymock/EasyMock.java Thu Feb 23 10:32:43 2012 +0100
|
|
|
2bed83 |
+++ b/easymock/src/main/java/org/easymock/EasyMock.java Thu Feb 23 11:25:46 2012 +0100
|
|
|
2bed83 |
@@ -1452,81 +1452,200 @@
|
|
|
2bed83 |
|
|
|
2bed83 |
/**
|
|
|
2bed83 |
* Expect any object but captures it for later use.
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
- * @param <T> Type of the captured object
|
|
|
2bed83 |
- * @param captured Where the parameter is captured
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
+ * @param <T>
|
|
|
2bed83 |
+ * Type of the captured object
|
|
|
2bed83 |
+ * @param captured
|
|
|
2bed83 |
+ * Where the parameter is captured
|
|
|
2bed83 |
* @return null
|
|
|
2bed83 |
*/
|
|
|
2bed83 |
- public static <T> T capture(Capture<T> captured) {
|
|
|
2bed83 |
+ public static <T> T capture(final Capture<T> captured) {
|
|
|
2bed83 |
reportMatcher(new Captures<T>(captured));
|
|
|
2bed83 |
return null;
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ /**
|
|
|
2bed83 |
+ * Expect any boolean but captures it for later use.
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
+ * @param captured
|
|
|
2bed83 |
+ * Where the parameter is captured
|
|
|
2bed83 |
+ * @return false
|
|
|
2bed83 |
+ */
|
|
|
2bed83 |
+ public static boolean captureBoolean(final Capture<Boolean> captured) {
|
|
|
2bed83 |
+ reportMatcher(new Captures<Boolean>(captured));
|
|
|
2bed83 |
+ return false;
|
|
|
2bed83 |
+ }
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+// /**
|
|
|
2bed83 |
+// * Expect any boolean but captures it for later use.
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @param captured
|
|
|
2bed83 |
+// * Where the parameter is captured
|
|
|
2bed83 |
+// * @return 0
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @deprecated Because of harder erasure enforcement, doesn't compile in
|
|
|
2bed83 |
+// * Java 7
|
|
|
2bed83 |
+// */
|
|
|
2bed83 |
+// @Deprecated
|
|
|
2bed83 |
+// public static boolean capture(final Capture<Boolean> captured) {
|
|
|
2bed83 |
+// return captureBoolean(captured);
|
|
|
2bed83 |
+// }
|
|
|
2bed83 |
+
|
|
|
2bed83 |
/**
|
|
|
2bed83 |
* Expect any int but captures it for later use.
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
- * @param captured Where the parameter is captured
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
+ * @param captured
|
|
|
2bed83 |
+ * Where the parameter is captured
|
|
|
2bed83 |
* @return 0
|
|
|
2bed83 |
*/
|
|
|
2bed83 |
- public static int capture(Capture<Integer> captured) {
|
|
|
2bed83 |
+ public static int captureInt(final Capture<Integer> captured) {
|
|
|
2bed83 |
reportMatcher(new Captures<Integer>(captured));
|
|
|
2bed83 |
return 0;
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+// /**
|
|
|
2bed83 |
+// * Expect any int but captures it for later use.
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @param captured
|
|
|
2bed83 |
+// * Where the parameter is captured
|
|
|
2bed83 |
+// * @return 0
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @deprecated Because of harder erasure enforcement, doesn't compile in
|
|
|
2bed83 |
+// * Java 7
|
|
|
2bed83 |
+// */
|
|
|
2bed83 |
+// @Deprecated
|
|
|
2bed83 |
+// public static int capture(final Capture<Integer> captured) {
|
|
|
2bed83 |
+// return captureInt(captured);
|
|
|
2bed83 |
+// }
|
|
|
2bed83 |
+
|
|
|
2bed83 |
/**
|
|
|
2bed83 |
* Expect any long but captures it for later use.
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
- * @param captured Where the parameter is captured
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
+ * @param captured
|
|
|
2bed83 |
+ * Where the parameter is captured
|
|
|
2bed83 |
* @return 0
|
|
|
2bed83 |
*/
|
|
|
2bed83 |
- public static long capture(Capture<Long> captured) {
|
|
|
2bed83 |
+ public static long captureLong(final Capture<Long> captured) {
|
|
|
2bed83 |
reportMatcher(new Captures<Long>(captured));
|
|
|
2bed83 |
return 0;
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+// /**
|
|
|
2bed83 |
+// * Expect any long but captures it for later use.
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @param captured
|
|
|
2bed83 |
+// * Where the parameter is captured
|
|
|
2bed83 |
+// * @return 0
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @deprecated Because of harder erasure enforcement, doesn't compile in
|
|
|
2bed83 |
+// * Java 7
|
|
|
2bed83 |
+// */
|
|
|
2bed83 |
+// @Deprecated
|
|
|
2bed83 |
+// public static long capture(final Capture<Long> captured) {
|
|
|
2bed83 |
+// return captureLong(captured);
|
|
|
2bed83 |
+// }
|
|
|
2bed83 |
+
|
|
|
2bed83 |
/**
|
|
|
2bed83 |
* Expect any float but captures it for later use.
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
- * @param captured Where the parameter is captured
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
+ * @param captured
|
|
|
2bed83 |
+ * Where the parameter is captured
|
|
|
2bed83 |
* @return 0
|
|
|
2bed83 |
*/
|
|
|
2bed83 |
- public static float capture(Capture<Float> captured) {
|
|
|
2bed83 |
+ public static float captureFloat(final Capture<Float> captured) {
|
|
|
2bed83 |
reportMatcher(new Captures<Float>(captured));
|
|
|
2bed83 |
return 0;
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+// /**
|
|
|
2bed83 |
+// * Expect any float but captures it for later use.
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @param captured
|
|
|
2bed83 |
+// * Where the parameter is captured
|
|
|
2bed83 |
+// * @return 0
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @deprecated Because of harder erasure enforcement, doesn't compile in
|
|
|
2bed83 |
+// * Java 7
|
|
|
2bed83 |
+// */
|
|
|
2bed83 |
+// @Deprecated
|
|
|
2bed83 |
+// public static float capture(final Capture<Float> captured) {
|
|
|
2bed83 |
+// return captureFloat(captured);
|
|
|
2bed83 |
+// }
|
|
|
2bed83 |
+
|
|
|
2bed83 |
/**
|
|
|
2bed83 |
* Expect any double but captures it for later use.
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
- * @param captured Where the parameter is captured
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
+ * @param captured
|
|
|
2bed83 |
+ * Where the parameter is captured
|
|
|
2bed83 |
* @return 0
|
|
|
2bed83 |
*/
|
|
|
2bed83 |
- public static double capture(Capture<Double> captured) {
|
|
|
2bed83 |
+ public static double captureDouble(final Capture<Double> captured) {
|
|
|
2bed83 |
reportMatcher(new Captures<Double>(captured));
|
|
|
2bed83 |
return 0;
|
|
|
2bed83 |
}
|
|
|
2bed83 |
+// /**
|
|
|
2bed83 |
+// * Expect any double but captures it for later use.
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @param captured
|
|
|
2bed83 |
+// * Where the parameter is captured
|
|
|
2bed83 |
+// * @return 0
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @deprecated Because of harder erasure enforcement, doesn't compile in
|
|
|
2bed83 |
+// * Java 7
|
|
|
2bed83 |
+// */
|
|
|
2bed83 |
+// @Deprecated
|
|
|
2bed83 |
+// public static double capture(final Capture<Double> captured) {
|
|
|
2bed83 |
+// return captureDouble(captured);
|
|
|
2bed83 |
+// }
|
|
|
2bed83 |
|
|
|
2bed83 |
/**
|
|
|
2bed83 |
* Expect any byte but captures it for later use.
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
- * @param captured Where the parameter is captured
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
+ * @param captured
|
|
|
2bed83 |
+ * Where the parameter is captured
|
|
|
2bed83 |
* @return 0
|
|
|
2bed83 |
*/
|
|
|
2bed83 |
- public static byte capture(Capture<Byte> captured) {
|
|
|
2bed83 |
+ public static byte captureByte(final Capture<Byte> captured) {
|
|
|
2bed83 |
reportMatcher(new Captures<Byte>(captured));
|
|
|
2bed83 |
return 0;
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+// /**
|
|
|
2bed83 |
+// * Expect any byte but captures it for later use.
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @param captured
|
|
|
2bed83 |
+// * Where the parameter is captured
|
|
|
2bed83 |
+// * @return 0
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @deprecated Because of harder erasure enforcement, doesn't compile in
|
|
|
2bed83 |
+// * Java 7
|
|
|
2bed83 |
+// */
|
|
|
2bed83 |
+// @Deprecated
|
|
|
2bed83 |
+// public static byte capture(final Capture<Byte> captured) {
|
|
|
2bed83 |
+// return captureByte(captured);
|
|
|
2bed83 |
+// }
|
|
|
2bed83 |
+
|
|
|
2bed83 |
/**
|
|
|
2bed83 |
* Expect any char but captures it for later use.
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
- * @param captured Where the parameter is captured
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
+ * @param captured
|
|
|
2bed83 |
+ * Where the parameter is captured
|
|
|
2bed83 |
* @return 0
|
|
|
2bed83 |
*/
|
|
|
2bed83 |
- public static char capture(Capture<Character> captured) {
|
|
|
2bed83 |
+ public static char captureChar(final Capture<Character> captured) {
|
|
|
2bed83 |
reportMatcher(new Captures<Character>(captured));
|
|
|
2bed83 |
return 0;
|
|
|
2bed83 |
}
|
|
|
2bed83 |
+// /**
|
|
|
2bed83 |
+// * Expect any char but captures it for later use.
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @param captured
|
|
|
2bed83 |
+// * Where the parameter is captured
|
|
|
2bed83 |
+// * @return 0
|
|
|
2bed83 |
+// *
|
|
|
2bed83 |
+// * @deprecated Because of harder erasure enforcement, doesn't compile in
|
|
|
2bed83 |
+// * Java 7
|
|
|
2bed83 |
+// */
|
|
|
2bed83 |
+// @Deprecated
|
|
|
2bed83 |
+// public static char capture(final Capture<Character> captured) {
|
|
|
2bed83 |
+// return captureChar(captured);
|
|
|
2bed83 |
+// }
|
|
|
2bed83 |
|
|
|
2bed83 |
/**
|
|
|
2bed83 |
* Switches the given mock objects (more exactly: the controls of the mock
|
|
|
2bed83 |
diff -r d382aea89c3d easymock/src/test/java/org/easymock/tests2/CaptureTest.java
|
|
|
2bed83 |
--- a/easymock/src/test/java/org/easymock/tests2/CaptureTest.java Thu Feb 23 10:32:43 2012 +0100
|
|
|
2bed83 |
+++ b/easymock/src/test/java/org/easymock/tests2/CaptureTest.java Thu Feb 23 11:25:46 2012 +0100
|
|
|
2bed83 |
@@ -1,12 +1,12 @@
|
|
|
2bed83 |
-/*
|
|
|
2bed83 |
- * Copyright 2003-2009 OFFIS, Henri Tremblay
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
+/**
|
|
|
2bed83 |
+ * Copyright 2001-2011 the original author or authors.
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
2bed83 |
* you may not use this file except in compliance with the License.
|
|
|
2bed83 |
* You may obtain a copy of the License at
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
2bed83 |
- *
|
|
|
2bed83 |
+ *
|
|
|
2bed83 |
* Unless required by applicable law or agreed to in writing, software
|
|
|
2bed83 |
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
2bed83 |
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
2bed83 |
@@ -27,10 +27,13 @@
|
|
|
2bed83 |
import org.junit.Before;
|
|
|
2bed83 |
import org.junit.Test;
|
|
|
2bed83 |
|
|
|
2bed83 |
+/**
|
|
|
2bed83 |
+ * @author Henri Tremblay
|
|
|
2bed83 |
+ */
|
|
|
2bed83 |
public class CaptureTest {
|
|
|
2bed83 |
|
|
|
2bed83 |
public static class A {
|
|
|
2bed83 |
- public String foo(IMethods methods) {
|
|
|
2bed83 |
+ public String foo(final IMethods methods) {
|
|
|
2bed83 |
return methods.oneArg(2);
|
|
|
2bed83 |
}
|
|
|
2bed83 |
}
|
|
|
2bed83 |
@@ -42,16 +45,16 @@
|
|
|
2bed83 |
@After
|
|
|
2bed83 |
public void tearDown() throws Exception {
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
- private Capture<Integer> testCaptureType(CaptureType type) {
|
|
|
2bed83 |
- IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
- Capture<Integer> captured = new Capture<Integer>(type);
|
|
|
2bed83 |
-
|
|
|
2bed83 |
- expect(mock.oneArg(capture(captured))).andReturn("1");
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ private Capture<Integer> testCaptureType(final CaptureType type) {
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+ final Capture<Integer> captured = new Capture<Integer>(type);
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ expect(mock.oneArg(captureInt(captured))).andReturn("1");
|
|
|
2bed83 |
expect(mock.oneArg(anyInt())).andReturn("1");
|
|
|
2bed83 |
- expect(mock.oneArg(capture(captured))).andReturn("2").times(2);
|
|
|
2bed83 |
- mock.twoArgumentMethod(capture(captured), eq(5));
|
|
|
2bed83 |
- mock.twoArgumentMethod(capture(captured), capture(captured));
|
|
|
2bed83 |
+ expect(mock.oneArg(captureInt(captured))).andReturn("2").times(2);
|
|
|
2bed83 |
+ mock.twoArgumentMethod(captureInt(captured), eq(5));
|
|
|
2bed83 |
+ mock.twoArgumentMethod(captureInt(captured), captureInt(captured));
|
|
|
2bed83 |
|
|
|
2bed83 |
replay(mock);
|
|
|
2bed83 |
|
|
|
2bed83 |
@@ -66,28 +69,28 @@
|
|
|
2bed83 |
|
|
|
2bed83 |
return captured;
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCaptureFirst() {
|
|
|
2bed83 |
- Capture<Integer> captured = testCaptureType(CaptureType.FIRST);
|
|
|
2bed83 |
+ final Capture<Integer> captured = testCaptureType(CaptureType.FIRST);
|
|
|
2bed83 |
assertEquals(0, (int) captured.getValue());
|
|
|
2bed83 |
}
|
|
|
2bed83 |
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCaptureLast() {
|
|
|
2bed83 |
- Capture<Integer> captured = testCaptureType(CaptureType.LAST);
|
|
|
2bed83 |
+ final Capture<Integer> captured = testCaptureType(CaptureType.LAST);
|
|
|
2bed83 |
assertEquals(7, (int) captured.getValue());
|
|
|
2bed83 |
}
|
|
|
2bed83 |
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCaptureAll() {
|
|
|
2bed83 |
- Capture<Integer> captured = testCaptureType(CaptureType.ALL);
|
|
|
2bed83 |
+ final Capture<Integer> captured = testCaptureType(CaptureType.ALL);
|
|
|
2bed83 |
assertEquals(Arrays.asList(0, 2, 3, 4, 6, 7), captured.getValues());
|
|
|
2bed83 |
}
|
|
|
2bed83 |
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCaptureNone() {
|
|
|
2bed83 |
- Capture<Integer> captured = testCaptureType(CaptureType.NONE);
|
|
|
2bed83 |
+ final Capture<Integer> captured = testCaptureType(CaptureType.NONE);
|
|
|
2bed83 |
assertFalse(captured.hasCaptured());
|
|
|
2bed83 |
}
|
|
|
2bed83 |
|
|
|
2bed83 |
@@ -96,11 +99,10 @@
|
|
|
2bed83 |
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCaptureRightOne() {
|
|
|
2bed83 |
- Capture<String> captured = new Capture<String>();
|
|
|
2bed83 |
- IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+ final Capture<String> captured = new Capture<String>();
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
|
|
|
2bed83 |
- expect(mock.oneArg(and(eq("test"), capture(captured)))).andReturn(
|
|
|
2bed83 |
- "answer1");
|
|
|
2bed83 |
+ expect(mock.oneArg(and(eq("test"), capture(captured)))).andReturn("answer1");
|
|
|
2bed83 |
expect(mock.oneArg("a")).andReturn("answer2");
|
|
|
2bed83 |
|
|
|
2bed83 |
replay(mock);
|
|
|
2bed83 |
@@ -114,10 +116,11 @@
|
|
|
2bed83 |
verify(mock);
|
|
|
2bed83 |
}
|
|
|
2bed83 |
|
|
|
2bed83 |
+ @SuppressWarnings("deprecation")
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testPrimitiveVsObject() {
|
|
|
2bed83 |
- Capture<Integer> capture = new Capture<Integer>();
|
|
|
2bed83 |
- IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+ final Capture<Integer> capture = new Capture<Integer>();
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
|
|
|
2bed83 |
expect(mock.oneArg(capture(capture))).andReturn("answer");
|
|
|
2bed83 |
expect(mock.oneArg((Integer) capture(capture))).andReturn("answer");
|
|
|
2bed83 |
@@ -135,11 +138,10 @@
|
|
|
2bed83 |
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testAnd() {
|
|
|
2bed83 |
- Capture<String> captured = new Capture<String>();
|
|
|
2bed83 |
- IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+ final Capture<String> captured = new Capture<String>();
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
|
|
|
2bed83 |
- expect(mock.oneArg(and(capture(captured), eq("test")))).andReturn(
|
|
|
2bed83 |
- "answer");
|
|
|
2bed83 |
+ expect(mock.oneArg(and(capture(captured), eq("test")))).andReturn("answer");
|
|
|
2bed83 |
|
|
|
2bed83 |
replay(mock);
|
|
|
2bed83 |
|
|
|
2bed83 |
@@ -148,17 +150,19 @@
|
|
|
2bed83 |
|
|
|
2bed83 |
verify(mock);
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ @SuppressWarnings("deprecation")
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
- public void testPrimitive() {
|
|
|
2bed83 |
- Capture<Integer> captureI = new Capture<Integer>();
|
|
|
2bed83 |
- Capture<Long> captureL = new Capture<Long>();
|
|
|
2bed83 |
- Capture<Float> captureF = new Capture<Float>();
|
|
|
2bed83 |
- Capture<Double> captureD = new Capture<Double>();
|
|
|
2bed83 |
- Capture<Byte> captureB = new Capture<Byte>();
|
|
|
2bed83 |
- Capture<Character> captureC = new Capture<Character>();
|
|
|
2bed83 |
+ public void testPrimitiveDeprecated() {
|
|
|
2bed83 |
+ final Capture<Integer> captureI = new Capture<Integer>();
|
|
|
2bed83 |
+ final Capture<Long> captureL = new Capture<Long>();
|
|
|
2bed83 |
+ final Capture<Float> captureF = new Capture<Float>();
|
|
|
2bed83 |
+ final Capture<Double> captureD = new Capture<Double>();
|
|
|
2bed83 |
+ final Capture<Byte> captureB = new Capture<Byte>();
|
|
|
2bed83 |
+ final Capture<Character> captureC = new Capture<Character>();
|
|
|
2bed83 |
+ final Capture<Boolean> captureBool = new Capture<Boolean>();
|
|
|
2bed83 |
|
|
|
2bed83 |
- IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
|
|
|
2bed83 |
expect(mock.oneArg(capture(captureI))).andReturn("answerI");
|
|
|
2bed83 |
expect(mock.oneArg(capture(captureL))).andReturn("answerL");
|
|
|
2bed83 |
@@ -166,6 +170,7 @@
|
|
|
2bed83 |
expect(mock.oneArg(capture(captureD))).andReturn("answerD");
|
|
|
2bed83 |
expect(mock.oneArg(capture(captureB))).andReturn("answerB");
|
|
|
2bed83 |
expect(mock.oneArg(capture(captureC))).andReturn("answerC");
|
|
|
2bed83 |
+ expect(mock.oneArg(capture(captureBool))).andReturn("answerZ");
|
|
|
2bed83 |
|
|
|
2bed83 |
replay(mock);
|
|
|
2bed83 |
|
|
|
2bed83 |
@@ -175,6 +180,7 @@
|
|
|
2bed83 |
assertEquals("answerD", mock.oneArg(4.0));
|
|
|
2bed83 |
assertEquals("answerB", mock.oneArg((byte) 5));
|
|
|
2bed83 |
assertEquals("answerC", mock.oneArg((char) 6));
|
|
|
2bed83 |
+ assertEquals("answerZ", mock.oneArg(true));
|
|
|
2bed83 |
|
|
|
2bed83 |
assertEquals(1, captureI.getValue().intValue());
|
|
|
2bed83 |
assertEquals(2l, captureL.getValue().longValue());
|
|
|
2bed83 |
@@ -182,19 +188,60 @@
|
|
|
2bed83 |
assertEquals(4.0, captureD.getValue().doubleValue(), 0.0);
|
|
|
2bed83 |
assertEquals((byte) 5, captureB.getValue().byteValue());
|
|
|
2bed83 |
assertEquals((char) 6, captureC.getValue().charValue());
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+ assertEquals(true, captureBool.getValue().booleanValue());
|
|
|
2bed83 |
+
|
|
|
2bed83 |
verify(mock);
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ @Test
|
|
|
2bed83 |
+ public void testPrimitive() {
|
|
|
2bed83 |
+ final Capture<Integer> captureI = new Capture<Integer>();
|
|
|
2bed83 |
+ final Capture<Long> captureL = new Capture<Long>();
|
|
|
2bed83 |
+ final Capture<Float> captureF = new Capture<Float>();
|
|
|
2bed83 |
+ final Capture<Double> captureD = new Capture<Double>();
|
|
|
2bed83 |
+ final Capture<Byte> captureB = new Capture<Byte>();
|
|
|
2bed83 |
+ final Capture<Character> captureC = new Capture<Character>();
|
|
|
2bed83 |
+ final Capture<Boolean> captureBool = new Capture<Boolean>();
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ expect(mock.oneArg(captureInt(captureI))).andReturn("answerI");
|
|
|
2bed83 |
+ expect(mock.oneArg(captureLong(captureL))).andReturn("answerL");
|
|
|
2bed83 |
+ expect(mock.oneArg(captureFloat(captureF))).andReturn("answerF");
|
|
|
2bed83 |
+ expect(mock.oneArg(captureDouble(captureD))).andReturn("answerD");
|
|
|
2bed83 |
+ expect(mock.oneArg(captureByte(captureB))).andReturn("answerB");
|
|
|
2bed83 |
+ expect(mock.oneArg(captureChar(captureC))).andReturn("answerC");
|
|
|
2bed83 |
+ expect(mock.oneArg(captureBoolean(captureBool))).andReturn("answerZ");
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ replay(mock);
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ assertEquals("answerI", mock.oneArg(1));
|
|
|
2bed83 |
+ assertEquals("answerL", mock.oneArg(2l));
|
|
|
2bed83 |
+ assertEquals("answerF", mock.oneArg(3.0f));
|
|
|
2bed83 |
+ assertEquals("answerD", mock.oneArg(4.0));
|
|
|
2bed83 |
+ assertEquals("answerB", mock.oneArg((byte) 5));
|
|
|
2bed83 |
+ assertEquals("answerC", mock.oneArg((char) 6));
|
|
|
2bed83 |
+ assertEquals("answerZ", mock.oneArg(true));
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ assertEquals(1, captureI.getValue().intValue());
|
|
|
2bed83 |
+ assertEquals(2l, captureL.getValue().longValue());
|
|
|
2bed83 |
+ assertEquals(3.0f, captureF.getValue().floatValue(), 0.0);
|
|
|
2bed83 |
+ assertEquals(4.0, captureD.getValue().doubleValue(), 0.0);
|
|
|
2bed83 |
+ assertEquals((byte) 5, captureB.getValue().byteValue());
|
|
|
2bed83 |
+ assertEquals((char) 6, captureC.getValue().charValue());
|
|
|
2bed83 |
+ assertEquals(true, captureBool.getValue().booleanValue());
|
|
|
2bed83 |
+
|
|
|
2bed83 |
+ verify(mock);
|
|
|
2bed83 |
+ }
|
|
|
2bed83 |
+
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCapture() {
|
|
|
2bed83 |
- Capture<String> capture = new Capture<String>();
|
|
|
2bed83 |
+ final Capture<String> capture = new Capture<String>();
|
|
|
2bed83 |
assertFalse(capture.hasCaptured());
|
|
|
2bed83 |
try {
|
|
|
2bed83 |
capture.getValue();
|
|
|
2bed83 |
fail("Should not be allowed");
|
|
|
2bed83 |
- }
|
|
|
2bed83 |
- catch(AssertionError e) {
|
|
|
2bed83 |
+ } catch (final AssertionError e) {
|
|
|
2bed83 |
assertEquals("Nothing captured yet", e.getMessage());
|
|
|
2bed83 |
}
|
|
|
2bed83 |
assertEquals("Nothing captured yet", capture.toString());
|
|
|
2bed83 |
@@ -207,29 +254,26 @@
|
|
|
2bed83 |
try {
|
|
|
2bed83 |
capture.getValue();
|
|
|
2bed83 |
fail();
|
|
|
2bed83 |
- }
|
|
|
2bed83 |
- catch(AssertionError e) {
|
|
|
2bed83 |
+ } catch (final AssertionError e) {
|
|
|
2bed83 |
assertEquals("Nothing captured yet", e.getMessage());
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
capture.setValue(null);
|
|
|
2bed83 |
assertTrue(capture.hasCaptured());
|
|
|
2bed83 |
assertNull(capture.getValue());
|
|
|
2bed83 |
assertEquals("null", capture.toString());
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCaptureMultiple() {
|
|
|
2bed83 |
- Capture<String> capture = new Capture<String>(CaptureType.ALL);
|
|
|
2bed83 |
+ final Capture<String> capture = new Capture<String>(CaptureType.ALL);
|
|
|
2bed83 |
capture.setValue("a");
|
|
|
2bed83 |
capture.setValue("b");
|
|
|
2bed83 |
try {
|
|
|
2bed83 |
capture.getValue();
|
|
|
2bed83 |
fail();
|
|
|
2bed83 |
- } catch (AssertionError e) {
|
|
|
2bed83 |
- assertEquals(
|
|
|
2bed83 |
- "More than one value captured: " + capture.getValues(), e
|
|
|
2bed83 |
- .getMessage());
|
|
|
2bed83 |
+ } catch (final AssertionError e) {
|
|
|
2bed83 |
+ assertEquals("More than one value captured: " + capture.getValues(), e.getMessage());
|
|
|
2bed83 |
}
|
|
|
2bed83 |
assertEquals(Arrays.asList("a", "b"), capture.getValues());
|
|
|
2bed83 |
}
|
|
|
2bed83 |
@@ -237,30 +281,26 @@
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCapture_2617107() {
|
|
|
2bed83 |
|
|
|
2bed83 |
- IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
|
|
|
2bed83 |
- Capture<String> cap1 = new Capture<String>();
|
|
|
2bed83 |
- Capture<String> cap2 = new Capture<String>();
|
|
|
2bed83 |
- Capture<String> cap3 = new Capture<String>();
|
|
|
2bed83 |
- Capture<String> cap4 = new Capture<String>();
|
|
|
2bed83 |
+ final Capture<String> cap1 = new Capture<String>();
|
|
|
2bed83 |
+ final Capture<String> cap2 = new Capture<String>();
|
|
|
2bed83 |
+ final Capture<String> cap3 = new Capture<String>();
|
|
|
2bed83 |
+ final Capture<String> cap4 = new Capture<String>();
|
|
|
2bed83 |
|
|
|
2bed83 |
- mock.simpleMethodWithArgument(and(isA(String.class),
|
|
|
2bed83 |
- capture(cap1)));
|
|
|
2bed83 |
- mock.simpleMethodWithArgument(and(isA(String.class),
|
|
|
2bed83 |
- capture(cap2)));
|
|
|
2bed83 |
- mock.simpleMethodWithArgument(and(isA(String.class),
|
|
|
2bed83 |
- capture(cap3)));
|
|
|
2bed83 |
- mock.simpleMethodWithArgument(and(isA(String.class),
|
|
|
2bed83 |
- capture(cap4)));
|
|
|
2bed83 |
+ mock.simpleMethodWithArgument(and(isA(String.class), capture(cap1)));
|
|
|
2bed83 |
+ mock.simpleMethodWithArgument(and(isA(String.class), capture(cap2)));
|
|
|
2bed83 |
+ mock.simpleMethodWithArgument(and(isA(String.class), capture(cap3)));
|
|
|
2bed83 |
+ mock.simpleMethodWithArgument(and(isA(String.class), capture(cap4)));
|
|
|
2bed83 |
|
|
|
2bed83 |
replay(mock);
|
|
|
2bed83 |
|
|
|
2bed83 |
final String[] s = { "one", "two", "three", "four" };
|
|
|
2bed83 |
|
|
|
2bed83 |
- for (int i = 0; i < s.length; i++) {
|
|
|
2bed83 |
- mock.simpleMethodWithArgument(s[i]);
|
|
|
2bed83 |
+ for (final String element : s) {
|
|
|
2bed83 |
+ mock.simpleMethodWithArgument(element);
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
assertEquals("one", cap1.getValue());
|
|
|
2bed83 |
assertEquals("two", cap2.getValue());
|
|
|
2bed83 |
assertEquals("three", cap3.getValue());
|
|
|
2bed83 |
@@ -268,7 +308,7 @@
|
|
|
2bed83 |
|
|
|
2bed83 |
verify(mock);
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCaptureNonStrictControl_2133741() {
|
|
|
2bed83 |
testCaptureHelper(createMock(IMethods.class));
|
|
|
2bed83 |
@@ -279,9 +319,9 @@
|
|
|
2bed83 |
testCaptureHelper(createStrictMock(IMethods.class));
|
|
|
2bed83 |
}
|
|
|
2bed83 |
|
|
|
2bed83 |
- protected void testCaptureHelper(IMethods mock) {
|
|
|
2bed83 |
- Capture<String> capture1 = new Capture<String>();
|
|
|
2bed83 |
- Capture<String> capture2 = new Capture<String>();
|
|
|
2bed83 |
+ protected void testCaptureHelper(final IMethods mock) {
|
|
|
2bed83 |
+ final Capture<String> capture1 = new Capture<String>();
|
|
|
2bed83 |
+ final Capture<String> capture2 = new Capture<String>();
|
|
|
2bed83 |
|
|
|
2bed83 |
mock.simpleMethodWithArgument(capture(capture1));
|
|
|
2bed83 |
mock.simpleMethodWithArgument(capture(capture2));
|
|
|
2bed83 |
@@ -294,25 +334,25 @@
|
|
|
2bed83 |
assertTrue(capture1.hasCaptured());
|
|
|
2bed83 |
assertTrue(capture2.hasCaptured());
|
|
|
2bed83 |
assertFalse(capture1.getValue() == capture2.getValue());
|
|
|
2bed83 |
- }
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+ }
|
|
|
2bed83 |
+
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCapture1_2446744() {
|
|
|
2bed83 |
- Capture<String> capture1 = new Capture<String>();
|
|
|
2bed83 |
- Capture<String> capture2 = new Capture<String>();
|
|
|
2bed83 |
- Capture<String> capture3 = new Capture<String>();
|
|
|
2bed83 |
- IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+ final Capture<String> capture1 = new Capture<String>();
|
|
|
2bed83 |
+ final Capture<String> capture2 = new Capture<String>();
|
|
|
2bed83 |
+ final Capture<String> capture3 = new Capture<String>();
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
expect(mock.oneArg(capture(capture1))).andReturn("1").once();
|
|
|
2bed83 |
expect(mock.oneArg(capture(capture2))).andReturn("2").once();
|
|
|
2bed83 |
expect(mock.oneArg(capture(capture3))).andReturn("3").once();
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
replay(mock);
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
for (int i = 0; i < 3; i++) {
|
|
|
2bed83 |
- String string = "Run" + (i + 1);
|
|
|
2bed83 |
+ final String string = "Run" + (i + 1);
|
|
|
2bed83 |
mock.oneArg(string);
|
|
|
2bed83 |
}
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
assertEquals("Run3", capture3.getValue());
|
|
|
2bed83 |
assertEquals("Run2", capture2.getValue());
|
|
|
2bed83 |
assertEquals("Run1", capture1.getValue());
|
|
|
2bed83 |
@@ -320,16 +360,16 @@
|
|
|
2bed83 |
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCapture2_2446744() {
|
|
|
2bed83 |
- Capture<String> capture = new Capture<String>(CaptureType.ALL);
|
|
|
2bed83 |
- IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+ final Capture<String> capture = new Capture<String>(CaptureType.ALL);
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
expect(mock.oneArg(capture(capture))).andReturn("1").once();
|
|
|
2bed83 |
expect(mock.oneArg(capture(capture))).andReturn("2").once();
|
|
|
2bed83 |
expect(mock.oneArg(capture(capture))).andReturn("3").once();
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
replay(mock);
|
|
|
2bed83 |
-
|
|
|
2bed83 |
+
|
|
|
2bed83 |
for (int i = 0; i < 3; i++) {
|
|
|
2bed83 |
- String string = "Run" + (i + 1);
|
|
|
2bed83 |
+ final String string = "Run" + (i + 1);
|
|
|
2bed83 |
mock.oneArg(string);
|
|
|
2bed83 |
}
|
|
|
2bed83 |
|
|
|
2bed83 |
@@ -338,8 +378,8 @@
|
|
|
2bed83 |
|
|
|
2bed83 |
@Test
|
|
|
2bed83 |
public void testCaptureFromStub() {
|
|
|
2bed83 |
- Capture<String> capture = new Capture<String>(CaptureType.ALL);
|
|
|
2bed83 |
- IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
+ final Capture<String> capture = new Capture<String>(CaptureType.ALL);
|
|
|
2bed83 |
+ final IMethods mock = createMock(IMethods.class);
|
|
|
2bed83 |
expect(mock.oneArg(capture(capture))).andStubReturn("1");
|
|
|
2bed83 |
|
|
|
2bed83 |
replay(mock);
|