carbidecpp22devenv/plugins/org.eclipse.test.source_3.5.0.r20080925/src/org.junit4_4.5.0.v20090423/junitsrc/junit/framework/ComparisonCompactor.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 junit.framework;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     2
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     3
public class ComparisonCompactor {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     4
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     5
	private static final String ELLIPSIS= "...";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     6
	private static final String DELTA_END= "]";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     7
	private static final String DELTA_START= "[";
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     8
	
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
     9
	private int fContextLength;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    10
	private String fExpected;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    11
	private String fActual;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    12
	private int fPrefix;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    13
	private int fSuffix;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    14
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    15
	public ComparisonCompactor(int contextLength, String expected, String actual) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    16
		fContextLength= contextLength;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    17
		fExpected= expected;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    18
		fActual= actual;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    19
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    20
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    21
	public String compact(String message) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    22
		if (fExpected == null || fActual == null || areStringsEqual())
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    23
			return Assert.format(message, fExpected, fActual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    24
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    25
		findCommonPrefix();
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    26
		findCommonSuffix();
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    27
		String expected= compactString(fExpected);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    28
		String actual= compactString(fActual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    29
		return Assert.format(message, expected, actual);
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
	private String compactString(String source) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    33
		String result= DELTA_START + source.substring(fPrefix, source.length() - fSuffix + 1) + DELTA_END;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    34
		if (fPrefix > 0)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    35
			result= computeCommonPrefix() + result;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    36
		if (fSuffix > 0)
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    37
			result= result + computeCommonSuffix();
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    38
		return result;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    39
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    40
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    41
	private void findCommonPrefix() {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    42
		fPrefix= 0;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    43
		int end= Math.min(fExpected.length(), fActual.length());
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    44
		for (; fPrefix < end; fPrefix++) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    45
			if (fExpected.charAt(fPrefix) != fActual.charAt(fPrefix))
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    46
				break;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    47
		}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    48
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    49
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    50
	private void findCommonSuffix() {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    51
		int expectedSuffix= fExpected.length() - 1;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    52
		int actualSuffix= fActual.length() - 1;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    53
		for (; actualSuffix >= fPrefix && expectedSuffix >= fPrefix; actualSuffix--, expectedSuffix--) {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    54
			if (fExpected.charAt(expectedSuffix) != fActual.charAt(actualSuffix))
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    55
				break;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    56
		}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    57
		fSuffix=  fExpected.length() - expectedSuffix;
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    58
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    59
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    60
	private String computeCommonPrefix() {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    61
		return (fPrefix > fContextLength ? ELLIPSIS : "") + fExpected.substring(Math.max(0, fPrefix - fContextLength), fPrefix);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    62
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    63
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    64
	private String computeCommonSuffix() {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    65
		int end= Math.min(fExpected.length() - fSuffix + 1 + fContextLength, fExpected.length());
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    66
		return fExpected.substring(fExpected.length() - fSuffix + 1, end) + (fExpected.length() - fSuffix + 1 < fExpected.length() - fContextLength ? ELLIPSIS : "");
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    67
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    68
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    69
	private boolean areStringsEqual() {
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    70
		return fExpected.equals(fActual);
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    71
	}
3ef299ba838f add files for RCL_2_2
cawthron
parents:
diff changeset
    72
}