Created
January 14, 2012 07:25
-
-
Save haacked/1610603 to your computer and use it in GitHub Desktop.
String Comparison Unit Test Helper
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
public static class TestHelpers | |
{ | |
public static void ShouldEqualWithDiff(this string actualValue, string expectedValue) | |
{ | |
ShouldEqualWithDiff(actualValue, expectedValue, DiffStyle.Full, Console.Out); | |
} | |
public static void ShouldEqualWithDiff(this string actualValue, string expectedValue, DiffStyle diffStyle) | |
{ | |
ShouldEqualWithDiff(actualValue, expectedValue, diffStyle, Console.Out); | |
} | |
public static void ShouldEqualWithDiff(this string actualValue, string expectedValue, DiffStyle diffStyle, TextWriter output) | |
{ | |
if(actualValue == null || expectedValue == null) | |
{ | |
//Assert.AreEqual(expectedValue, actualValue); | |
Assert.Equal(expectedValue, actualValue); | |
return; | |
} | |
if (actualValue.Equals(expectedValue, StringComparison.Ordinal)) return; | |
output.WriteLine(" Idx Expected Actual"); | |
output.WriteLine("-------------------------"); | |
int maxLen = Math.Max(actualValue.Length, expectedValue.Length); | |
int minLen = Math.Min(actualValue.Length, expectedValue.Length); | |
for (int i = 0; i < maxLen; i++) | |
{ | |
if (diffStyle != DiffStyle.Minimal || i >= minLen || actualValue[i] != expectedValue[i]) | |
{ | |
output.WriteLine("{0} {1,-3} {2,-4} {3,-3} {4,-4} {5,-3}", | |
i < minLen && actualValue[i] == expectedValue[i] ? " " : "*", // put a mark beside a differing row | |
i, // the index | |
i < expectedValue.Length ? ((int)expectedValue[i]).ToString() : "", // character decimal value | |
i < expectedValue.Length ? expectedValue[i].ToSafeString() : "", // character safe string | |
i < actualValue.Length ? ((int)actualValue[i]).ToString() : "", // character decimal value | |
i < actualValue.Length ? actualValue[i].ToSafeString() : "" // character safe string | |
); | |
} | |
} | |
output.WriteLine(); | |
//Assert.AreEqual(expectedValue, actualValue); | |
Assert.Equal(expectedValue, actualValue); | |
} | |
private static string ToSafeString(this char c) | |
{ | |
if (Char.IsControl(c) || Char.IsWhiteSpace(c)) | |
{ | |
switch (c) | |
{ | |
case '\r': | |
return @"\r"; | |
case '\n': | |
return @"\n"; | |
case '\t': | |
return @"\t"; | |
case '\a': | |
return @"\a"; | |
case '\v': | |
return @"\v"; | |
case '\f': | |
return @"\f"; | |
default: | |
return String.Format("\\u{0:X};", (int)c); | |
} | |
} | |
return c.ToString(CultureInfo.InvariantCulture); | |
} | |
} | |
public enum DiffStyle | |
{ | |
Full, | |
Minimal | |
} |
@dotnetzebra good suggestion. I made the change.
Thx man.
This helper class help me A LOT with some tricky tests.
I like this. Helped me out a lot.
Maybe consider creating a NuGet package just for this source file. You can create NuGet packages for source pretty easily. I am doing just that now with common files I used to drag around.
http://www.rhyous.com/2016/03/03/nuget-for-source-using-add-as-link-1
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
@haacked & @sinairv, for readability, I would suggest removing the call to string.Format & using the overload output.WriteLine(string format, params object[] args)