我有这样的测试:
String dir = "/foo";
String fileName = "hello.txt";
String pathString = dir + "/" + fileName;
String text = "hello world!";
MyTask task = new MyTask();
FileSystem fs = Jimfs.newFileSystem(Configuration.unix());
Path foo = fs.getPath(dir);
Files.createDirectory(foo);
Path hello = foo.resolve(fileName);
Files.write(hello, ImmutableList.of(text), StandardCharsets.UTF_8);
task.setFileSystem(fs);
String fileValue = task.readFile(pathString);
// Doing this just shows "fail whale: hello world!"
// fail("fail whale: " + fileValue);
// Failure from here adds brackets
assertEquals(text, fileValue);
我这样失败了:
org.junit.ComparisonFailure: expected:<hello world![]> but was:<hello world![
]>
如果我反转参数,我可以看到readFile
肯定会创建新行,而不仅仅是我的终端截断。
我根本不知道为什么JUnit会在我的字符串之后显示括号,并且更加混淆为什么会添加一个空格。
readFile
就是这样:
public String readFile(String path) {
try {
return new String(Files.readAllBytes(fs.getPath(path)));
} catch (Exception e) {
e.printStackTrace();
return "";
}
}
Java: Is assertEquals(String, String) reliable?引用String
为Object
,但如果是这种情况,括号只是暗示Object
,仍然对这一新行感到困惑
答案 0 :(得分:7)
JUnit assertEquals
方法在字符串中出现差异的部分周围放置方括号,以帮助突出显示问题。 (使用assertEquals("abcde", "acedc")
等进行游戏,以更直观的方式查看。)
在这种情况下,它显示一个字符串后面没有任何内容,而另一个字符串在其末尾有一个换行符。
每一行都是一个char序列,并按顺序写入文件,每行由平台的行分隔符终止,由系统属性
line.separator
定义。
答案 1 :(得分:2)
括号用于突出显示字符串不同的位置。
在您的情况下,它会在实际结果的末尾突出显示意外的换行符。