- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果必须在 JavaFX 线程中调用某个方法,那么我似乎必须在 when
block 中执行以下操作:
... setup ...
// def throwable
when:
Platform.runLater( new Runnable(){
@Override
void run() {
// try {
log.debug "in runnable, calling run method ..."
someObject.methodWhichMustRunInJavaFXThread()
log.debug "... run method finished normally"
// }catch( Throwable t ){
// log.error( t.message, t )
// throwable = t
// }
}
})
WaitForAsyncUtils.waitForFxEvents()
log.debug "waitForFXEvents ended..."
// if throwable != null
// throw throwable
/* NB it appears that re-throwing the Throwable like this after waitForFxEvents
is probably the only way to bring it to the developer's attention!
PS I added this re-throwing idea only a few hours after submitting the question. I am
currently monitoring things to find whether this in fact solves the problem */
then:
// throwable == null
/* in fact this seems to be a rather naive check: from my experimentation,
regardless of whether caught in the above catch clause, it appears that if a throwable
is thrown in `run`, although "invocation counting tests" are performed in the "then"
block, this sort of "static" equality check will never be performed in the "then" block
*/
... other verifications...
但我间歇性地发现,如果在 run
方法中抛出异常,这种技术可能会导致后续测试失败的可怕泄漏。我认为 try catch 任何此类 throwables(如上面的代码所示,如果取消注释所有注释行)可能会解决问题,但实际上不能:在 run
中抛出一个 throwable,并由catch
子句,仍然可以归因于后面的方法!
这是一种误导性 Spock 失败输出的示例:尽管此 NPE 是在之前的测试方法中的 Platform.runLater( ... )
中抛出的(实际上是在完全不同的测试方法中)文件initial_load_testing.groovy中的规范
),此失败实际上归因于恰好在其之后某个任意时间进行的测试。
注意提到“延迟异常”...
java.lang.RuntimeException: java.lang.NullPointerException: Cannot invoke method setRoot() on null object
at org.testfx.util.WaitForAsyncUtils.---- Delayed Exception: (See Trace Below) ----(WaitForAsyncUtils.java:0)
Caused by: java.lang.NullPointerException: Cannot invoke method setRoot() on null object
at core.FileHandlingFramework.tryToLoadFile(filehandlingframework.groovy:83)
at core.StdFileHandlingFrameworkTemplate.tryToOpenFile(stdfilehandlingframeworktemplate.groovy:97)
at core.App.start(main.groovy:120)
at core.AppStdSpec2$1.run(initial_load_testing.groovy:92)
at com.sun.javafx.application.PlatformImpl.lambda$runLater$10(PlatformImpl.java:428)
at com.sun.javafx.application.PlatformImpl.lambda$runLater$11(PlatformImpl.java:427)
at com.sun.glass.ui.InvokeLaterDispatcher$Future.run(InvokeLaterDispatcher.java:96)
at com.sun.glass.ui.gtk.GtkApplication.lambda$runLoop$11(GtkApplication.java:277)
at java.base/java.lang.Thread.run(Thread.java:834)
我觉得奇怪的是,准确地说,我允许 JavaFX 线程事件通过 WaitForAsyncUtils.waitForFxEvents()
“冒泡”...但似乎以某种方式抛出可抛出的有时可以在 waitForFXEvents()
方法结束后被 Spock 框架检测到。
这个问题有解决办法吗?这种现象的间歇性是一个真正的问题。
最佳答案
暂时,以下解决方案似乎可以工作,方法是在 when
block 结束之前重新抛出 FX 线程中捕获的任何异常:
void executeInFXThreadAndWait( def closure, def ... params ){
Throwable fXThrowable
Platform.runLater({
try {
closure(params)
}catch( Throwable t ){
if( t.message != 'exit' ) {
log.error(t.message, t)
fXThrowable = t
}
}
})
WaitForAsyncUtils.waitForFxEvents()
if( fXThrowable != null ){
// add calling trace so fail trace identifies Specification line concerned
fXThrowable.stackTrace += Thread.currentThread().stackTrace
throw fXThrowable
}
}
用法(App
扩展Application
):
...
def myClosure = { args ->
App.instance.start( args[ 0 ] )
}
...
when:
TestUtilities.instance.executeInFXThreadAndWait( myClosure, mockStage )
then:
...
注意,关于测试“退出”的问题是,有时我会故意在测试中抛出异常,以从需要验证的内容已经验证过的方法中“弹出”。如果 Throwable
的消息是“退出”,它将被忽略。
假设:我在不知道的情况下猜测 Spock 框架能够检测异常是否已被“处理”,并且如果像这样重新抛出异常,框架将不会跟进“延迟异常” ”。欢迎 Spock 专家提出意见。
稍后
几天后:结论似乎是这有所改善。然而,在没有任何明显的可预测性或一致性的情况下,仍然可能会发生由于一个规范和功能在另一规范和功能下报告而失败的情况。每次发生这种情况时,都会再次运行相同的测试,而不会出现此类虚假错误。
我相信 Spock 并没有声称能够处理并发编程。很高兴知道其他人在 when
block 中执行 Platform.runLater
时是否经历过这种现象。
关于java - Spock 在 "when" block 中运行 Platform.runLater() 时出现计时问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61484450/
我在将 Firebase 调用函数的返回值分配给全局变量时遇到问题。这是我的功能: function getThePushNameById( path , id ){ path.once(
我正在尝试使用 javascript 创建倒计时。我从 here 得到了一些代码并略作修改。 var c=10, t; function timedCount() { document.getE
我想使用java脚本计算点击两个按钮之间的时间差 最佳答案 这里有一个提示 - 使用: var t = Date.now(); 以毫秒分辨率获取当前时间(自 1970 年 1 月 1 日 00:00:
我试图在单击按钮时显示时钟,但并调用设置超时事件来连续显示当前时间。但每当我单击按钮时,它只会鞋一次。如果我在一段时间后单击,那么它也可以工作,但不会显示连续变化的时间。 脚本 function sh
我有一种情况,在模型的 afterSave 中回调,我正在尝试从远程关联访问数据(这是一个具有非常不稳定的关联链接的遗留数据模型)。我发现的是,在回调中我可以对模型执行查找调用,但如果我此时退出,则记
我这里有这段代码,它从数据库中获取一些运动统计数据,并对其进行更新 - 我正试图在检测到变化时发出警报(#scorealert div)。如果只有一个分数发生了变化,这就可以正常工作。当有多个更改时,
我正在制作一个测验应用程序,我想在其中显示用户在玩游戏时所用的时间。它应该采用 HH:MM:SS 格式,从 00:00:00 开始,直到他选择答案。当用户每秒播放时,计时器应该每秒更新一次。另外,我想
我想知道在 Postgres 中执行查询所需的时间,我看到很多建议使用\timing 的响应,但我是 Postgres 的新手,我不知道如何使用它,谁能帮忙 提前谢谢你 最佳答案 您只能将 \timi
作为我大学论文的一部分,我试图测试几种不同类型的数字输入键盘界面的可用性。为此,我需要记录参与者按下的每个按键以及每个按键的时间。仅仅记录他们在表单上提交的内容是不够的,因为我需要监控他们看到并纠正了
我需要在我的网站上制作一些简短的“新闻快讯”...淡入和淡出一些 `s 并需要它们循环... 到目前为止我有这样的东西: $('.text01').hide().fadeIn('slow').dela
我希望有人能帮我解决这个问题。我想测量排序算法。这是我目前的做法: M = 1000 # number of executions N = [1000, 2000, 4000, 16000] # si
我的项目有个小问题:我在我的程序中使用 C++ chrono 库来处理时间。但是当我在调试计时时钟继续运行时到达断点并且当我继续程序时,与计时器一起工作的东西中有疯狂的值。 现在我的问题:是否有库或方
我正在开发一个 C++ 应用程序,它需要精确到毫秒级的详细计时信息。 我们打算使用标准 time() 收集精确到秒的时间在 中发挥作用.我们还想收集自 time() 给出的最后一秒以来经过的毫秒数。
我试图在敲击之间保持节奏。但是,我随机获得巨大的值(value),我不确定为什么。 @implementation GameScene { CFTimeInterval previousFram
我正在通过几个操作解析一个文件,我想测量执行这些操作所花费的时间。 执行此操作并打印时间的最佳方法是什么? 最佳答案 更新:如果您不反对使用外部库并且您使用的是 JDK 5+,Google Guava
我想收集与网络请求的每个阶段所花费的时间相关的统计信息。 httplib 提供: def run(self): conn = httplib.HTTPConnection('www.examp
我正在制作一款 Android 游戏,其中一些图形元素移动速度很快。我打算使用 Canvas,但担心 onDraw 方法会以不规则的间隔调用,从而使快速元素以不规则的速度移动。有没有办法确保定期调用
我正在制作一个按时间间隔执行的应用程序。更新之间我可以等待的绝对最长时间是30秒,介于0和0之间的任何值都是可以接受的,但是我希望15秒是一个很好的衡量标准。但是,它并不像听起来那样容易。我尝试了4种
我的桌面应用程序有一个恼人的问题,我无法弄清楚。我已将问题隔离到以下示例中。我正在尝试做什么...... 我有一个jframe和5个jpanels,每个面板都有不同的图片。启动后,用户将看到面板 A,
是否有一种标准的方法来记录 Quartz 执行任务所花费的时间?我也对基于 Spring 的解决方案持开放态度,因为我正在使用两者。 最佳答案 您可以使用通用计时库,例如 ERMA .它与 sprin
我是一名优秀的程序员,十分优秀!