我正在尝试单元测试我的覆盖文件的方法(或者创建一个新的,如果给定的文件不存在)。我的想法是在覆盖之前和覆盖之后比较两个数组,所以我做了它,但不幸的是,它说实际数组是空的。我正在使用TemporaryFolder,这样在测试后可以很容易地删除它。
方法我想要单元测试+方法,这是测试覆盖方法所需的。
package rankingsystem;
import contentfile.ContentFileRetriever;
import java.io.BufferedWriter;
import java.io.FileWriter;
import java.io.IOException;
import java.util.*;
import java.util.stream.Collectors;
public class RankingSystemService {
private ContentFileRetriever contentFileRetriever;
public RankingSystemService(ContentFileRetriever contentFileRetriever) {
this.contentFileRetriever = contentFileRetriever;
}
...
String[] retrieveRankingData(String rankingPathFile) {
return contentFileRetriever.getContent(rankingPathFile);
}
void overwriteFileWithGivenResult(String name, long timeOfFinishingGame, String rankingPathFile) {
try (FileWriter writer = new FileWriter(rankingPathFile, true);
BufferedWriter bufferedWriter = new BufferedWriter(writer)) {
bufferedWriter.write(name + " " + timeOfFinishingGame);
bufferedWriter.newLine();
} catch (IOException e) {
e.printStackTrace();
}
}
}
public class RankingSystemServiceTest {
@Rule
public TemporaryFolder tempFolder = new TemporaryFolder();
@Mock
ContentFileRetriever contentFileRetriever;
private RankingSystemService rankingSystemService = new RankingSystemService(contentFileRetriever);
@Before
public void setup() {
MockitoAnnotations.initMocks(this);
rankingSystemService = new RankingSystemService(contentFileRetriever);
}
@Test
public void overwriteFileWithGivenResult() throws IOException {
File rankingFile = tempFolder.newFile("rankingText.txt");
String rankingFilePath = rankingFile.getPath();
String[] actualResultBeforeOverwriting = rankingSystemService.retrieveRankingData(rankingFilePath);
String[] expectedResultBeforeOverwriting = {};
assertArrayEquals(expectedResultBeforeOverwriting, actualResultBeforeOverwriting);
rankingSystemService.overwriteFileWithGivenResult("Piotr", 1L, rankingFilePath);
String[] afterOverwriting = rankingSystemService.retrieveRankingData(rankingFilePath);
String[] expectedResultAfterOverwriting = {"Piotr 1"};
assertArrayEquals(expectedResultAfterOverwriting, afterOverwriting);
}
@Override
public String[] getContent(String pathName) {
try (Stream<String> contentFileStream = Files.lines(Paths.get(pathName))) {
return contentFileStream.toArray(String[]::new);
} catch (IOException e) {
throw new IllegalArgumentException(e);
}
}
java.lang.AssertionError: actual array was null
at org.junit.Assert.fail(Assert.java:88)
at org.junit.internal.ComparisonCriteria.assertArraysAreSameLength(ComparisonCriteria.java:71)
at org.junit.internal.ComparisonCriteria.arrayEquals(ComparisonCriteria.java:37)
at org.junit.Assert.internalArrayEquals(Assert.java:532)
at org.junit.Assert.assertArrayEquals(Assert.java:283)
at org.junit.Assert.assertArrayEquals(Assert.java:298)
at rankingsystem.RankingSystemServiceTest.overwriteFileWithGivenResult(RankingSystemServiceTest.java:61)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:564)
at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:50)
at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:12)
at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:47)
at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:17)
at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:26)
at org.junit.rules.ExternalResource$1.evaluate(ExternalResource.java:48)
at org.junit.rules.RunRules.evaluate(RunRules.java:20)
at org.junit.runners.ParentRunner.runLeaf(ParentRunner.java:325)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:78)
at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:57)
at org.junit.runners.ParentRunner$3.run(ParentRunner.java:290)
at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:71)
at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:288)
at org.junit.runners.ParentRunner.access$000(ParentRunner.java:58)
at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:268)
at org.junit.runners.ParentRunner.run(ParentRunner.java:363)
at org.junit.runner.JUnitCore.run(JUnitCore.java:137)
at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:68)
at com.intellij.rt.execution.junit.IdeaTestRunner$Repeater.startRunnerWithArgs(IdeaTestRunner.java:47)
at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:242)
at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:70)
根据JB Nizet用户的要求,我需要删除ContentFileRetriever的mock并创建ContentFileRetriever的实例,它可以工作。
ContentFileRetrieverService contentFileRetrieverService = new ContentFileRetrieverService();
问题内容: (最新的说只是添加硬编码的引号,即,但是我做不到,我正在调用一个返回数组的函数) 所以这是我的代码(请注意,问题出在空数组 ): 简单吗?这是我的PHP代码: 结果如下: 如果我将非空数组更改为非空,即: 结果是: 因此,这显然意味着当有一个空Array()要发送时,它将被忽略,并且 不会添加到POST变量中 。 我想念什么吗? PS:我的jQuery版本来自最新的Google CDN
问题内容: 在我的一种方法中,我实例化了一个DOM,并且自从我使用以下方法转储它以来,似乎已正确初始化了它: 它输出应该存在的SOAP消息的有效和当前内容。 但是只有一个语句(之前和之后)显示为: 它们之间都显示完全 有效的内容 。 这对我来说没有意义…我想念什么? 根据评论中的建议进行更新:我将日志语句更改为 输出为: INFO:doc BEFORE = [#document:null],[#d
问题内容: 我有一个类Hra1,它定义了游戏规则(game = hra)。问题是,尽管在构造函数中创建了poleMinci数组,但我得到的是空值,例如poleMinci == null。换句话说,玩家的move方法始终返回false。 构造函数: 球员的移动方法: 问题答案: 您正在阴影变量: 在该构造函数中,由于poleMinci是在构造函数内部声明的,因此仅在构造函数内部可见。如果您在类中具有
问题内容: 我试图找出一种通过使用group by函数返回结果的方法。 GROUP BY正在按预期工作,但是我的问题是:是否有可能让group by忽略NULL字段。这样就不会将NULL分组在一起,因为我仍然需要指定字段为NULL的所有行。 所以现在说我有5行,并且祖先字段为NULL,它返回我1行....但是我要全部5。 问题答案: 也许您应该在null列中添加一些内容,以使它们唯一并按此分组?我
问题内容: 我在firebase中执行查询时遇到错误,我的查询代码如下所示: 但是我收到以下错误: 异常java.lang.RuntimeException:无法启动活动ComponentInfo {ucarparceiro.ucarapp.com.ucarparceiro / ucarparceiro.ucarapp.com.ucarparceiro.Activity.ActivityPrinc