JavaFX测试在Windows中失败并在OSX和Linux中运行

时间:2017-09-03 18:41:59

标签: java linux windows macos javafx

我的JavaFX测试仅在Windows中失败,但在OSX和Linux中运行良好

这是stacktrace:

  

编辑:1

Running com.myproject.meditor.SLIVCodeAreaTest
Tests run: 17, Failures: 0, Errors: 17, Skipped: 0, Time elapsed: 6.656 sec <<< FAILURE! - in com.myproject.meditor.SLIVCodeAreaTest
testRHBlock(com.myproject.meditor.SLIVCodeAreaTest)  Time elapsed: 0 sec  <<< ERROR!
java.lang.ExceptionInInitializerError: null
    at com.sun.glass.ui.Screen.getScreens(Screen.java:70)
    at com.sun.glass.ui.Screen.getMainScreen(Screen.java:61)
    at com.sun.javafx.font.PrismFontFactory.getSystemFontSize(PrismFontFactory.java:1911)
    at com.sun.javafx.font.PrismFontLoader.getSystemFontSize(PrismFontLoader.java:240)
    at javafx.scene.text.Font.getDefaultSystemFontSize(Font.java:71)
    at javafx.scene.text.Font.getDefault(Font.java:86)
    at javafx.scene.text.Text.getFont(Text.java:478)
    at javafx.scene.text.Text.getFontInternal(Text.java:487)
    at javafx.scene.text.Text.access$100(Text.java:95)
    at javafx.scene.text.Text$1.getFont(Text.java:206)
    at com.sun.javafx.text.GlyphLayout.breakRuns(GlyphLayout.java:174)
    at com.sun.javafx.text.PrismTextLayout.buildRuns(PrismTextLayout.java:770)
    at com.sun.javafx.text.PrismTextLayout.layout(PrismTextLayout.java:1021)
    at com.sun.javafx.text.PrismTextLayout.ensureLayout(PrismTextLayout.java:223)
    at com.sun.javafx.text.PrismTextLayout.getBounds(PrismTextLayout.java:246)
    at javafx.scene.text.TextFlow.computePrefWidth(TextFlow.java:203)
    at javafx.scene.Parent.prefWidth(Parent.java:915)
    at javafx.scene.layout.Region.prefWidth(Region.java:1419)
    at org.fxmisc.richtext.ParagraphBox.computePrefWidth(ParagraphBox.java:199)
    at org.fxmisc.richtext.ParagraphBox.computeMinWidth(ParagraphBox.java:191)
    at javafx.scene.Parent.minWidth(Parent.java:943)
    at javafx.scene.layout.Region.minWidth(Region.java:1383)
    at org.fxmisc.flowless.VerticalHelper.minBreadth(OrientationHelper.java:234)
    at org.fxmisc.flowless.OrientationHelper.minBreadth(OrientationHelper.java:44)
    at org.reactfx.collection.MappedList.get(MappedList.java:27)
    at org.reactfx.collection.MemoizationListImpl.force(MemoizationList.java:121)
    at org.fxmisc.flowless.SizeTracker.breadthFor(SizeTracker.java:161)
    at org.fxmisc.flowless.CellPositioner.getSizedCell(CellPositioner.java:130)
    at org.fxmisc.flowless.CellPositioner.placeStartAt(CellPositioner.java:95)
    at org.fxmisc.flowless.Navigator.placeStartAtMayCrop(Navigator.java:183)
    at org.fxmisc.flowless.Navigator.visit(Navigator.java:111)
    at org.fxmisc.flowless.StartOffStart.accept(TargetPosition.java:49)
    at org.fxmisc.flowless.Navigator.layoutChildren(Navigator.java:67)
    at javafx.scene.Parent.layout(Parent.java:1087)
    at org.fxmisc.flowless.VirtualFlow.layoutChildren(VirtualFlow.java:165)
    at javafx.scene.Parent.layout(Parent.java:1087)
    at org.fxmisc.flowless.VirtualFlow.visibleCells(VirtualFlow.java:138)
    at com.myproject.util.javafx.codearea.SEditor.<init>(SEditor.java:659)
    at com.myproject.util.javafx.codearea.SEditor.<init>(SEditor.java:607)
    at com.myproject.util.javafx.codearea.SCodeArea.<init>(SCodeArea.java:122)
    at com.myproject.meditor.SLICodeArea.<init>(SLICodeArea.java:124)
    at com.myproject.meditor.SLICodeArea.<init>(SLICodeArea.java:114)
    at com.myproject.meditor.SLItemCodeArea.<init>(SLICodeArea.java:106)
    at com.myproject.meditor.SLItemCodeArea.<init>(SLICodeArea.java:103)
    at com.myproject.meditor.SLIVCodeAreaTest.<clinit>(SLIVCodeAreaTest.java:14)
  

编辑:2

从堆栈跟踪中,触发异常(SLIVCodeAreaTest.java:14)的代码部分位于代码部分的private static final SLIVCodeArea声明中:

import static org.junit.Assert.assertTrue;
import org.junit.Test;

public class SLIVCodeAreaTest {     
    private static final SLIVCodeArea sEditor = new SLIVCodeArea(new SLICodeArea()) {

        @Override protected void updateVisibleParagraphRange() {}   };

    private static final VEditorProblemList sProblemList = 
        new VEditorProblemList(sEditor, new SimpleObjectProperty<>(), false);

    static { sEditor.aggregatedTextChanges().setAggregationEnabled(false); }
  

编辑:3

如果我从上面的初始化部分删除关键字 静态 ,则错误的堆栈跟踪将变为:

Running com.myproject.meditor.SLIVCodeAreaTest
Tests run: 17, Failures: 0, Errors: 17, Skipped: 0, Time elapsed: 1.124 sec <<< FAILURE! - in Running com.myproject.meditor.SLIVCodeAreaTest
testRHBlock(com.myproject.meditor.SLIVCodeAreaTest)  Time elapsed: 0 sec  <<< ERROR!
java.lang.RuntimeException: Internal graphics not initialized yet
    at com.sun.glass.ui.Screen.getScreens(Screen.java:70)
    at com.sun.glass.ui.Screen.getMainScreen(Screen.java:61)
    at com.sun.javafx.font.PrismFontFactory.getSystemFontSize(PrismFontFactory.java:1911)
    at com.sun.javafx.font.PrismFontLoader.getSystemFontSize(PrismFontLoader.java:240)
    at javafx.scene.text.Font.getDefaultSystemFontSize(Font.java:71)
    at javafx.scene.text.Font.getDefault(Font.java:86)
    at javafx.scene.text.Text.getFont(Text.java:478)
    at javafx.scene.text.Text.getFontInternal(Text.java:487)
    at javafx.scene.text.Text.access$100(Text.java:95)
    at javafx.scene.text.Text$1.getFont(Text.java:206)
    at com.sun.javafx.text.GlyphLayout.breakRuns(GlyphLayout.java:174)
    at com.sun.javafx.text.PrismTextLayout.buildRuns(PrismTextLayout.java:770)
    at com.sun.javafx.text.PrismTextLayout.layout(PrismTextLayout.java:1021)
    at com.sun.javafx.text.PrismTextLayout.ensureLayout(PrismTextLayout.java:223)
    at com.sun.javafx.text.PrismTextLayout.getBounds(PrismTextLayout.java:246)
    at javafx.scene.text.TextFlow.computePrefWidth(TextFlow.java:203)
    at javafx.scene.Parent.prefWidth(Parent.java:915)
    at javafx.scene.layout.Region.prefWidth(Region.java:1419)
    at org.fxmisc.richtext.ParagraphBox.computePrefWidth(ParagraphBox.java:199)
    at org.fxmisc.richtext.ParagraphBox.computeMinWidth(ParagraphBox.java:191)
    at javafx.scene.Parent.minWidth(Parent.java:943)
    at javafx.scene.layout.Region.minWidth(Region.java:1383)
    at org.fxmisc.flowless.VerticalHelper.minBreadth(OrientationHelper.java:234)
    at org.fxmisc.flowless.OrientationHelper.minBreadth(OrientationHelper.java:44)
    at org.reactfx.collection.MappedList.get(MappedList.java:27)
    at org.reactfx.collection.MemoizationListImpl.force(MemoizationList.java:121)
    at org.fxmisc.flowless.SizeTracker.breadthFor(SizeTracker.java:161)
    at org.fxmisc.flowless.CellPositioner.getSizedCell(CellPositioner.java:130)
    at org.fxmisc.flowless.CellPositioner.placeStartAt(CellPositioner.java:95)
    at org.fxmisc.flowless.Navigator.placeStartAtMayCrop(Navigator.java:183)
    at org.fxmisc.flowless.Navigator.visit(Navigator.java:111)
    at org.fxmisc.flowless.StartOffStart.accept(TargetPosition.java:49)
    at org.fxmisc.flowless.Navigator.layoutChildren(Navigator.java:67)
    at javafx.scene.Parent.layout(Parent.java:1087)
    at org.fxmisc.flowless.VirtualFlow.layoutChildren(VirtualFlow.java:165)
    at javafx.scene.Parent.layout(Parent.java:1087)
    at org.fxmisc.flowless.VirtualFlow.visibleCells(VirtualFlow.java:138)
    at com.myproject.util.javafx.codearea.SEditor.<init>(SEditor.java:659)
    at com.myproject.util.javafx.codearea.SEditor.<init>(SEditor.java:607)
    at com.myproject.util.javafx.codearea.SCodeArea.<init>(SCodeArea.java:122)
    at com.myproject.meditor.SLICodeArea.<init>(SLICodeArea.java:124)
    at com.myproject.meditor.SLICodeArea.<init>(SLICodeArea.java:114)
    at com.myproject.meditor.SLICodeArea.<init>(SLICodeArea.java:106)
    at com.myproject.meditor.SLICodeArea.<init>(SLICodeArea.java:103)
    at com.myproject.meditor.SLIVCodeAreaTest.<init>(SLIVCodeAreaTest.java:14)
  

PS:测试在OSX中有和没有 静态 关键字。

相同的代码在Linux和MacOS中运行良好,但在Windows中失败。 有谁知道为什么?

2 个答案:

答案 0 :(得分:0)

JavaFXJUnit和任何java.lang.ExceptionInInitializerError的组合是异常Toolkit not initialized被抑制发生的指示。

要初始化JavaFX,您可以在运行单元测试之前等待new JFXPanel()完成。

请参阅:

答案 1 :(得分:0)

根据Matlab FEATool Nonlinear Time dependent Heat Transfer Solution

  

公共类ExceptionInInitializerError扩展了LinkageError信号   静态初始化程序中发生意外异常。一个   抛出ExceptionInInitializerError以指示异常   在评估静态初始化程序或初始化程序期间发生   对于静态变量。

因为您没有发布Class ExceptionInInitializerError 我认为因为 newscreens 不是静态或是由 null 初始化,并且您尝试将null变量转移到数组。