carbidecpp22devenv/plugins/org.eclipse.test.source_3.5.0.r20080925/src/org.junit4_4.5.0.v20090423/junitsrc/org/junit/Assert.java
author cawthron
Fri, 04 Dec 2009 11:49:54 -0600
changeset 636 3ef299ba838f
permissions -rw-r--r--
add files for RCL_2_2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
636
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     1
package org.junit;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     2
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     3
import java.lang.reflect.Array;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     4
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     5
import org.hamcrest.Description;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     6
import org.hamcrest.Matcher;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     7
import org.hamcrest.StringDescription;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     8
import org.junit.internal.ArrayComparisonFailure;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     9
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    10
/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    11
 * A set of assertion methods useful for writing tests. Only failed assertions
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    12
 * are recorded. These methods can be used directly:
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    13
 * <code>Assert.assertEquals(...)</code>, however, they read better if they
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    14
 * are referenced through static import:<br/>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    15
 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    16
 * <pre>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    17
 * import static org.junit.Assert.*;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    18
 *    ...
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    19
 *    assertEquals(...);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    20
 * </pre>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    21
 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    22
 * @see AssertionError
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    23
 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    24
public class Assert {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    25
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    26
	 * Protect constructor since it is a static only class
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    27
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    28
	protected Assert() {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    29
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    30
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    31
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    32
	 * Asserts that a condition is true. If it isn't it throws an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    33
	 * {@link AssertionError} with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    34
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    35
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    36
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    37
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    38
	 * @param condition
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    39
	 *            condition to be checked
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    40
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    41
	static public void assertTrue(String message, boolean condition) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    42
		if (!condition)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    43
			fail(message);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    44
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    45
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    46
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    47
	 * Asserts that a condition is true. If it isn't it throws an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    48
	 * {@link AssertionError} without a message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    49
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    50
	 * @param condition
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    51
	 *            condition to be checked
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    52
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    53
	static public void assertTrue(boolean condition) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    54
		assertTrue(null, condition);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    55
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    56
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    57
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    58
	 * Asserts that a condition is false. If it isn't it throws an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    59
	 * {@link AssertionError} with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    60
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    61
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    62
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    63
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    64
	 * @param condition
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    65
	 *            condition to be checked
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    66
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    67
	static public void assertFalse(String message, boolean condition) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    68
		assertTrue(message, !condition);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    69
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    70
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    71
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    72
	 * Asserts that a condition is false. If it isn't it throws an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    73
	 * {@link AssertionError} without a message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    74
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    75
	 * @param condition
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    76
	 *            condition to be checked
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    77
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    78
	static public void assertFalse(boolean condition) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    79
		assertFalse(null, condition);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    80
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    81
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    82
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    83
	 * Fails a test with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    84
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    85
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    86
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    87
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    88
	 * @see AssertionError
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    89
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    90
	static public void fail(String message) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    91
		throw new AssertionError(message == null ? "" : message);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    92
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    93
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    94
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    95
	 * Fails a test with no message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    96
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    97
	static public void fail() {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    98
		fail(null);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    99
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   100
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   101
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   102
	 * Asserts that two objects are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   103
	 * {@link AssertionError} is thrown with the given message. If
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   104
	 * <code>expected</code> and <code>actual</code> are <code>null</code>,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   105
	 * they are considered equal.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   106
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   107
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   108
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   109
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   110
	 * @param expected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   111
	 *            expected value
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   112
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   113
	 *            actual value
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   114
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   115
	static public void assertEquals(String message, Object expected,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   116
			Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   117
		if (expected == null && actual == null)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   118
			return;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   119
		if (expected != null && isEquals(expected, actual))
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   120
			return;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   121
		else if (expected instanceof String && actual instanceof String) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   122
			String cleanMessage= message == null ? "" : message;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   123
			throw new ComparisonFailure(cleanMessage, (String) expected,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   124
					(String) actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   125
		} else
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   126
			failNotEquals(message, expected, actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   127
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   128
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   129
	private static boolean isEquals(Object expected, Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   130
		return expected.equals(actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   131
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   132
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   133
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   134
	 * Asserts that two objects are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   135
	 * {@link AssertionError} without a message is thrown. If
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   136
	 * <code>expected</code> and <code>actual</code> are <code>null</code>,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   137
	 * they are considered equal.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   138
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   139
	 * @param expected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   140
	 *            expected value
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   141
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   142
	 *            the value to check against <code>expected</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   143
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   144
	static public void assertEquals(Object expected, Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   145
		assertEquals(null, expected, actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   146
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   147
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   148
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   149
	 * Asserts that two object arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   150
	 * {@link AssertionError} is thrown with the given message. If
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   151
	 * <code>expecteds</code> and <code>actuals</code> are <code>null</code>,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   152
	 * they are considered equal.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   153
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   154
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   155
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   156
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   157
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   158
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   159
	 *            expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   160
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   161
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   162
	 *            actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   163
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   164
	public static void assertArrayEquals(String message, Object[] expecteds,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   165
			Object[] actuals) throws ArrayComparisonFailure {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   166
		internalArrayEquals(message, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   167
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   168
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   169
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   170
	 * Asserts that two object arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   171
	 * {@link AssertionError} is thrown. If <code>expected</code> and
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   172
	 * <code>actual</code> are <code>null</code>, they are considered
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   173
	 * equal.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   174
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   175
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   176
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   177
	 *            expected values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   178
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   179
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   180
	 *            actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   181
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   182
	public static void assertArrayEquals(Object[] expecteds, Object[] actuals) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   183
		assertArrayEquals(null, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   184
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   185
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   186
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   187
	 * Asserts that two byte arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   188
	 * {@link AssertionError} is thrown with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   189
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   190
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   191
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   192
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   193
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   194
	 *            byte array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   195
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   196
	 *            byte array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   197
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   198
	public static void assertArrayEquals(String message, byte[] expecteds,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   199
			byte[] actuals) throws ArrayComparisonFailure {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   200
		internalArrayEquals(message, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   201
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   202
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   203
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   204
	 * Asserts that two byte arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   205
	 * {@link AssertionError} is thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   206
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   207
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   208
	 *            byte array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   209
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   210
	 *            byte array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   211
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   212
	public static void assertArrayEquals(byte[] expecteds, byte[] actuals) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   213
		assertArrayEquals(null, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   214
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   215
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   216
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   217
	 * Asserts that two char arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   218
	 * {@link AssertionError} is thrown with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   219
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   220
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   221
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   222
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   223
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   224
	 *            char array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   225
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   226
	 *            char array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   227
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   228
	public static void assertArrayEquals(String message, char[] expecteds,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   229
			char[] actuals) throws ArrayComparisonFailure {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   230
		internalArrayEquals(message, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   231
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   232
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   233
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   234
	 * Asserts that two char arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   235
	 * {@link AssertionError} is thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   236
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   237
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   238
	 *            char array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   239
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   240
	 *            char array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   241
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   242
	public static void assertArrayEquals(char[] expecteds, char[] actuals) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   243
		assertArrayEquals(null, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   244
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   245
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   246
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   247
	 * Asserts that two short arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   248
	 * {@link AssertionError} is thrown with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   249
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   250
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   251
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   252
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   253
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   254
	 *            short array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   255
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   256
	 *            short array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   257
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   258
	public static void assertArrayEquals(String message, short[] expecteds,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   259
			short[] actuals) throws ArrayComparisonFailure {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   260
		internalArrayEquals(message, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   261
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   262
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   263
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   264
	 * Asserts that two short arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   265
	 * {@link AssertionError} is thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   266
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   267
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   268
	 *            short array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   269
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   270
	 *            short array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   271
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   272
	public static void assertArrayEquals(short[] expecteds, short[] actuals) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   273
		assertArrayEquals(null, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   274
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   275
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   276
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   277
	 * Asserts that two int arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   278
	 * {@link AssertionError} is thrown with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   279
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   280
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   281
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   282
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   283
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   284
	 *            int array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   285
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   286
	 *            int array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   287
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   288
	public static void assertArrayEquals(String message, int[] expecteds,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   289
			int[] actuals) throws ArrayComparisonFailure {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   290
		internalArrayEquals(message, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   291
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   292
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   293
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   294
	 * Asserts that two int arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   295
	 * {@link AssertionError} is thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   296
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   297
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   298
	 *            int array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   299
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   300
	 *            int array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   301
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   302
	public static void assertArrayEquals(int[] expecteds, int[] actuals) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   303
		assertArrayEquals(null, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   304
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   305
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   306
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   307
	 * Asserts that two long arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   308
	 * {@link AssertionError} is thrown with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   309
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   310
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   311
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   312
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   313
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   314
	 *            long array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   315
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   316
	 *            long array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   317
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   318
	public static void assertArrayEquals(String message, long[] expecteds,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   319
			long[] actuals) throws ArrayComparisonFailure {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   320
		internalArrayEquals(message, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   321
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   322
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   323
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   324
	 * Asserts that two long arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   325
	 * {@link AssertionError} is thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   326
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   327
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   328
	 *            long array with expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   329
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   330
	 *            long array with actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   331
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   332
	public static void assertArrayEquals(long[] expecteds, long[] actuals) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   333
		assertArrayEquals(null, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   334
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   335
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   336
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   337
	 * Asserts that two object arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   338
	 * {@link AssertionError} is thrown with the given message. If
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   339
	 * <code>expecteds</code> and <code>actuals</code> are <code>null</code>,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   340
	 * they are considered equal.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   341
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   342
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   343
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   344
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   345
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   346
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   347
	 *            expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   348
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   349
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   350
	 *            actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   351
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   352
	private static void internalArrayEquals(String message, Object expecteds,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   353
			Object actuals) throws ArrayComparisonFailure {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   354
		if (expecteds == actuals)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   355
			return;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   356
		String header= message == null ? "" : message + ": ";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   357
		if (expecteds == null)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   358
			fail(header + "expected array was null");
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   359
		if (actuals == null)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   360
			fail(header + "actual array was null");
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   361
		int actualsLength= Array.getLength(actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   362
		int expectedsLength= Array.getLength(expecteds);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   363
		if (actualsLength != expectedsLength)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   364
			fail(header + "array lengths differed, expected.length="
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   365
					+ expectedsLength + " actual.length=" + actualsLength);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   366
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   367
		for (int i= 0; i < expectedsLength; i++) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   368
			Object expected= Array.get(expecteds, i);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   369
			Object actual= Array.get(actuals, i);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   370
			if (isArray(expected) && isArray(actual)) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   371
				try {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   372
					internalArrayEquals(message, expected, actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   373
				} catch (ArrayComparisonFailure e) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   374
					e.addDimension(i);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   375
					throw e;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   376
				}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   377
			} else
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   378
				try {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   379
					assertEquals(expected, actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   380
				} catch (AssertionError e) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   381
					throw new ArrayComparisonFailure(header, e, i);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   382
				}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   383
		}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   384
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   385
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   386
	private static boolean isArray(Object expected) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   387
		return expected != null && expected.getClass().isArray();
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   388
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   389
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   390
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   391
	 * Asserts that two doubles or floats are equal to within a positive delta.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   392
	 * If they are not, an {@link AssertionError} is thrown with the given
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   393
	 * message. If the expected value is infinity then the delta value is
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   394
	 * ignored. NaNs are considered equal:
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   395
	 * <code>assertEquals(Double.NaN, Double.NaN, *)</code> passes
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   396
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   397
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   398
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   399
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   400
	 * @param expected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   401
	 *            expected value
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   402
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   403
	 *            the value to check against <code>expected</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   404
	 * @param delta
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   405
	 *            the maximum delta between <code>expected</code> and
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   406
	 *            <code>actual</code> for which both numbers are still
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   407
	 *            considered equal.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   408
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   409
	static public void assertEquals(String message, double expected,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   410
			double actual, double delta) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   411
		if (Double.compare(expected, actual) == 0)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   412
			return;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   413
		if (!(Math.abs(expected - actual) <= delta))
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   414
			failNotEquals(message, new Double(expected), new Double(actual));
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   415
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   416
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   417
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   418
	 * Asserts that two longs are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   419
	 * {@link AssertionError} is thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   420
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   421
	 * @param expected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   422
	 *            expected long value.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   423
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   424
	 *            actual long value
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   425
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   426
	static public void assertEquals(long expected, long actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   427
		assertEquals(null, expected, actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   428
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   429
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   430
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   431
	 * Asserts that two longs are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   432
	 * {@link AssertionError} is thrown with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   433
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   434
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   435
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   436
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   437
	 * @param expected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   438
	 *            long expected value.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   439
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   440
	 *            long actual value
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   441
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   442
	static public void assertEquals(String message, long expected, long actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   443
		assertEquals(message, (Long) expected, (Long) actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   444
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   445
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   446
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   447
	 * @deprecated Use
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   448
	 *             <code>assertEquals(double expected, double actual, double epsilon)</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   449
	 *             instead
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   450
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   451
	@Deprecated
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   452
	static public void assertEquals(double expected, double actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   453
		assertEquals(null, expected, actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   454
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   455
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   456
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   457
	 * @deprecated Use
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   458
	 *             <code>assertEquals(String message, double expected, double actual, double epsilon)</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   459
	 *             instead
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   460
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   461
	@Deprecated
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   462
	static public void assertEquals(String message, double expected,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   463
			double actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   464
		fail("Use assertEquals(expected, actual, delta) to compare floating-point numbers");
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   465
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   466
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   467
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   468
	 * Asserts that two doubles or floats are equal to within a positive delta.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   469
	 * If they are not, an {@link AssertionError} is thrown. If the expected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   470
	 * value is infinity then the delta value is ignored.NaNs are considered
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   471
	 * equal: <code>assertEquals(Double.NaN, Double.NaN, *)</code> passes
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   472
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   473
	 * @param expected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   474
	 *            expected value
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   475
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   476
	 *            the value to check against <code>expected</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   477
	 * @param delta
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   478
	 *            the maximum delta between <code>expected</code> and
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   479
	 *            <code>actual</code> for which both numbers are still
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   480
	 *            considered equal.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   481
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   482
	static public void assertEquals(double expected, double actual, double delta) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   483
		assertEquals(null, expected, actual, delta);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   484
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   485
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   486
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   487
	 * Asserts that an object isn't null. If it is an {@link AssertionError} is
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   488
	 * thrown with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   489
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   490
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   491
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   492
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   493
	 * @param object
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   494
	 *            Object to check or <code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   495
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   496
	static public void assertNotNull(String message, Object object) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   497
		assertTrue(message, object != null);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   498
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   499
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   500
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   501
	 * Asserts that an object isn't null. If it is an {@link AssertionError} is
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   502
	 * thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   503
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   504
	 * @param object
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   505
	 *            Object to check or <code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   506
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   507
	static public void assertNotNull(Object object) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   508
		assertNotNull(null, object);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   509
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   510
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   511
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   512
	 * Asserts that an object is null. If it is not, an {@link AssertionError}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   513
	 * is thrown with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   514
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   515
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   516
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   517
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   518
	 * @param object
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   519
	 *            Object to check or <code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   520
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   521
	static public void assertNull(String message, Object object) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   522
		assertTrue(message, object == null);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   523
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   524
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   525
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   526
	 * Asserts that an object is null. If it isn't an {@link AssertionError} is
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   527
	 * thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   528
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   529
	 * @param object
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   530
	 *            Object to check or <code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   531
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   532
	static public void assertNull(Object object) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   533
		assertNull(null, object);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   534
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   535
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   536
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   537
	 * Asserts that two objects refer to the same object. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   538
	 * {@link AssertionError} is thrown with the given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   539
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   540
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   541
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   542
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   543
	 * @param expected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   544
	 *            the expected object
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   545
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   546
	 *            the object to compare to <code>expected</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   547
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   548
	static public void assertSame(String message, Object expected, Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   549
		if (expected == actual)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   550
			return;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   551
		failNotSame(message, expected, actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   552
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   553
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   554
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   555
	 * Asserts that two objects refer to the same object. If they are not the
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   556
	 * same, an {@link AssertionError} without a message is thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   557
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   558
	 * @param expected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   559
	 *            the expected object
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   560
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   561
	 *            the object to compare to <code>expected</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   562
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   563
	static public void assertSame(Object expected, Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   564
		assertSame(null, expected, actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   565
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   566
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   567
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   568
	 * Asserts that two objects do not refer to the same object. If they do
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   569
	 * refer to the same object, an {@link AssertionError} is thrown with the
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   570
	 * given message.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   571
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   572
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   573
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   574
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   575
	 * @param unexpected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   576
	 *            the object you don't expect
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   577
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   578
	 *            the object to compare to <code>unexpected</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   579
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   580
	static public void assertNotSame(String message, Object unexpected,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   581
			Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   582
		if (unexpected == actual)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   583
			failSame(message);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   584
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   585
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   586
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   587
	 * Asserts that two objects do not refer to the same object. If they do
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   588
	 * refer to the same object, an {@link AssertionError} without a message is
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   589
	 * thrown.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   590
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   591
	 * @param unexpected
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   592
	 *            the object you don't expect
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   593
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   594
	 *            the object to compare to <code>unexpected</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   595
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   596
	static public void assertNotSame(Object unexpected, Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   597
		assertNotSame(null, unexpected, actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   598
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   599
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   600
	static private void failSame(String message) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   601
		String formatted= "";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   602
		if (message != null)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   603
			formatted= message + " ";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   604
		fail(formatted + "expected not same");
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   605
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   606
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   607
	static private void failNotSame(String message, Object expected,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   608
			Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   609
		String formatted= "";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   610
		if (message != null)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   611
			formatted= message + " ";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   612
		fail(formatted + "expected same:<" + expected + "> was not:<" + actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   613
				+ ">");
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   614
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   615
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   616
	static private void failNotEquals(String message, Object expected,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   617
			Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   618
		fail(format(message, expected, actual));
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   619
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   620
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   621
	static String format(String message, Object expected, Object actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   622
		String formatted= "";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   623
		if (message != null && !message.equals(""))
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   624
			formatted= message + " ";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   625
		String expectedString= String.valueOf(expected);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   626
		String actualString= String.valueOf(actual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   627
		if (expectedString.equals(actualString))
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   628
			return formatted + "expected: "
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   629
					+ formatClassAndValue(expected, expectedString)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   630
					+ " but was: " + formatClassAndValue(actual, actualString);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   631
		else
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   632
			return formatted + "expected:<" + expectedString + "> but was:<"
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   633
					+ actualString + ">";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   634
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   635
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   636
	private static String formatClassAndValue(Object value, String valueString) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   637
		String className= value == null ? "null" : value.getClass().getName();
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   638
		return className + "<" + valueString + ">";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   639
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   640
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   641
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   642
	 * Asserts that two object arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   643
	 * {@link AssertionError} is thrown with the given message. If
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   644
	 * <code>expecteds</code> and <code>actuals</code> are <code>null</code>,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   645
	 * they are considered equal.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   646
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   647
	 * @param message
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   648
	 *            the identifying message for the {@link AssertionError} (<code>null</code>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   649
	 *            okay)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   650
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   651
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   652
	 *            expected values.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   653
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   654
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   655
	 *            actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   656
	 * @deprecated use assertArrayEquals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   657
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   658
	@Deprecated
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   659
	public static void assertEquals(String message, Object[] expecteds,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   660
			Object[] actuals) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   661
		assertArrayEquals(message, expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   662
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   663
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   664
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   665
	 * Asserts that two object arrays are equal. If they are not, an
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   666
	 * {@link AssertionError} is thrown. If <code>expected</code> and
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   667
	 * <code>actual</code> are <code>null</code>, they are considered
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   668
	 * equal.
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   669
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   670
	 * @param expecteds
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   671
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   672
	 *            expected values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   673
	 * @param actuals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   674
	 *            Object array or array of arrays (multi-dimensional array) with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   675
	 *            actual values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   676
	 * @deprecated use assertArrayEquals
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   677
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   678
	@Deprecated
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   679
	public static void assertEquals(Object[] expecteds, Object[] actuals) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   680
		assertArrayEquals(expecteds, actuals);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   681
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   682
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   683
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   684
	 * Asserts that <code>actual</code> satisfies the condition specified by
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   685
	 * <code>matcher</code>. If not, an {@link AssertionError} is thrown with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   686
	 * information about the matcher and failing value. Example:
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   687
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   688
	 * <pre>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   689
	 *   assertThat(0, is(1)); // fails:
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   690
	 *     // failure message:
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   691
	 *     // expected: is &lt;1&gt; 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   692
	 *     // got value: &lt;0&gt;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   693
	 *   assertThat(0, is(not(1))) // passes
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   694
	 * </pre>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   695
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   696
	 * @param <T>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   697
	 *            the static type accepted by the matcher (this can flag obvious
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   698
	 *            compile-time problems such as {@code assertThat(1, is("a"))}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   699
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   700
	 *            the computed value being compared
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   701
	 * @param matcher
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   702
	 *            an expression, built of {@link Matcher}s, specifying allowed
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   703
	 *            values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   704
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   705
	 * @see org.hamcrest.CoreMatchers
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   706
	 * @see org.junit.matchers.JUnitMatchers
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   707
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   708
	public static <T> void assertThat(T actual, Matcher<T> matcher) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   709
		assertThat("", actual, matcher);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   710
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   711
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   712
	/**
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   713
	 * Asserts that <code>actual</code> satisfies the condition specified by
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   714
	 * <code>matcher</code>. If not, an {@link AssertionError} is thrown with
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   715
	 * the reason and information about the matcher and failing value. Example:
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   716
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   717
	 * <pre>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   718
	 * :
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   719
	 *   assertThat(&quot;Help! Integers don't work&quot;, 0, is(1)); // fails:
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   720
	 *     // failure message:
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   721
	 *     // Help! Integers don't work
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   722
	 *     // expected: is &lt;1&gt; 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   723
	 *     // got value: &lt;0&gt;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   724
	 *   assertThat(&quot;Zero is one&quot;, 0, is(not(1))) // passes
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   725
	 * </pre>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   726
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   727
	 * @param reason
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   728
	 *            additional information about the error
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   729
	 * @param <T>
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   730
	 *            the static type accepted by the matcher (this can flag obvious
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   731
	 *            compile-time problems such as {@code assertThat(1, is("a"))}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   732
	 * @param actual
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   733
	 *            the computed value being compared
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   734
	 * @param matcher
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   735
	 *            an expression, built of {@link Matcher}s, specifying allowed
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   736
	 *            values
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   737
	 * 
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   738
	 * @see org.hamcrest.CoreMatchers
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   739
	 * @see org.junit.matchers.JUnitMatchers
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   740
	 */
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   741
	public static <T> void assertThat(String reason, T actual,
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   742
			Matcher<T> matcher) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   743
		if (!matcher.matches(actual)) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   744
			Description description= new StringDescription();
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   745
			description.appendText(reason);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   746
			description.appendText("\nExpected: ");
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   747
			matcher.describeTo(description);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   748
			description.appendText("\n     got: ").appendValue(actual)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   749
					.appendText("\n");
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   750
			throw new java.lang.AssertionError(description.toString());
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   751
		}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   752
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
   753
}