我经常使用接受回调的方法,而回调似乎有点难以测试。让我们考虑以下场景,如果有一个方法接受单个方法的回调(为简单起见,我假设测试方法是同步的),可以编写以下样板文件以确保调用回调方法:@TestpublicvoidtestMethod(){finalboolean[]passed={false};method(newCallback(){@Overridepublicvoidhandle(booleanisSuccessful){passed[0]=isSuccessful;}});assertTrue(passed[0]);}它看起来像一个代理人。我想知道:是否有更优雅的方法来测试这样
Java8中的Stream类定义了一个max方法,它需要一个Comparator参数。这是方法签名:Optionalmax(Comparatorcomparator)Comparator是一个函数式接口(interface),具有带有此签名的抽象compare方法。注意compare需要2个参数。intcompare(To1,To2)Comparable接口(interface)有一个带有此签名的抽象compareTo方法。注意compareTo只需要1个参数。intcompareTo(To)在Java8中,以下代码可以完美运行。但是,我预计会出现编译错误,例如“Integer类未定义
ListmyclassList=(List)rs.get();TreeSetmyclassSet=newTreeSet(myclassList);我不明白为什么这段代码会生成这个:java.lang.ClassCastException:MyClasscannotbecasttojava.lang.ComparableMyClass没有实现Comparable。我只想使用Set来过滤List的唯一元素,因为我的List包含不必要的重复元素。 最佳答案 是否MyClassimplementsComparable或类似的东西?如果不是,
考虑这段代码:publicinterfaceFooextendsComparable{}publicenumFooImplimplementsFoo{}由于类型删除的限制,我收到以下错误:java.lang.Comparablecannotbeinheritedwithdifferentarguments:and我有以下要求:FooImpl需要是一个枚举,因为我需要将它用作注释中的默认值。我的接口(interface)约定是它需要具有可比性。我已经尝试在接口(interface)中使用通用边界,但这在Java中不受支持。 最佳答案
如果有一种方法可以在javadoc中放置一个指向驻留在src/main/resources或src/test/resources中的标准资源文件的链接,以便其他编码人员可以快速导航到资源文件,我会发现它非常有用(在本例中为JSON文件)在IntelliJ中。这些文件用于单元测试,需要随着架构的变化而经常修改。答案在这里Linktotextfile(resource)inJavadoc没有帮助,因为绝对路径太脆弱了。有没有办法用资源做与@see相同的事情?如果javadoc本身有不足之处,IntelliJ特有的东西会很棒。 最佳答案
我有一个添加关闭钩子(Hook)的方法。我需要测试(通过JUnit)钩子(Hook)中执行的代码是否被调用:publicvoidmyMethod(){Runtime.getRuntime().addShutdownHook(newThread(){@Overridepublicvoidrun(){...codetotest...}});}如何在单元测试中模拟关机? 最佳答案 我认为您无法测试它。相反,只需测试您的代码在调用时是否正确运行(通过单独对其进行单元测试)。然后,相信Java会在正确的时间调用您的代码。即将代码提取到扩展Th
我使用PentahoKettle已经有一段时间了,之前我所做的转换和工作(使用勺子)非常简单,从数据库加载,重命名等,输入到另一个数据库。但现在我一直在做一些更复杂的计算的转换,我现在想以某种方式进行测试。所以我想做的是:设置一些测试数据运行转换验证结果数据一个选择可能是制作一个Kettle测试作业来测试转换。但由于我的转换与Java项目相关,我更愿意从jUnit运行测试。所以我考虑过做一个jUnit测试:设置测试数据(使用dbunit)运行转换(从命令行使用kitchen.sh)验证结果数据(使用dbunit)然而,这种方法需要测试数据库,这些数据库并不总是可用(oracle等昂贵/
publicclassTest{publicstaticvoidmain(String[]args){List>list=newArrayList();list.add(newPair("1",8));list.add(newPair("3",2));list.add(newPair("2",15));list.stream().sorted(Comparator.comparingInt(p->p.v)).map(p->p.k).forEach(System.out::println);}}classPair{Kk;Vv;publicPair(Kk,Vv){this.k=k;this
我正在设置持续集成服务器(Hudson)来构建Java项目并运行相关的单元/集成测试。大多数这些测试访问数据库,测试数据保存在DbUnitXML文件中。我正在寻找一种自动使测试数据库架构保持最新的方法。目前,特定版本的SQL脚本存储在以版本命名的目录中:└───scripts├───0.1.0├───0.1.1├───0.1.2├───0.1.4例如0.1.4版本的SQL脚本为scripts\0.1.4\script-0.1.4.sql问题是这些脚本混合了模式更改(例如ALTERTABLE...)和对静态表的更改(例如向USER_TYPE表添加新角色)。在单元测试的情况下,我只想应用模
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭6年前。Improvethisquestion我有在jUnit中检查异常的代码。我想知道以下哪一项是良好的jUnit实践?首先@RulepublicExpectedExceptionexception=ExpectedException.none();@TestpublicvoidcheckNullObject()throwsCustomException{exception.expect(CustomException.class)