0

Spock テストが実行されず、実行してもテスト結果がゼロになるのはなぜですか

./gradlew clean test

Openjdk 11を使用したTestFX Spock Gradle プロジェクトで?


ゼロテストの結果は次のとおりです。 ここに画像の説明を入力


Spock テスト クラスは正常にコンパイルされますが、実行されません。

これが私のコンソールです:

Working Directory: /home/~/EclipseProjects/gradleTestfxSpock
Gradle user home: /home/~/.gradle
Gradle Distribution: Gradle wrapper from target build
Gradle Version: 5.0
Java Home: /usr/lib/jvm/jdk-11.0.2+9
JVM Arguments: None
Program Arguments: None
Build Scans Enabled: false
Offline Mode Enabled: false
Gradle Tasks: clean test


> Configure project :
Found module name 'mtd'

> Task :clean
> Task :compileJava
> Task :compileGroovy NO-SOURCE
> Task :processResources
> Task :classes
> Task :compileTestJava NO-SOURCE
> Task :compileTestGroovy
> Task :processTestResources
> Task :testClasses
> Task :test

BUILD SUCCESSFUL in 6s
6 actionable tasks: 6 executed

これが私のbuild.gradleです:

plugins {    
    id 'org.openjfx.javafxplugin' version '0.0.7'   
    id 'application'
    id 'groovy'
}

mainClassName = 'mtd/gradleTestfxSpock.Main'

sourceCompatibility = 11
targetCompatibility = 11

repositories {  
    jcenter()   
}

dependencies {
    implementation 'org.testfx:testfx-spock:4.0.15-alpha'
    testCompile    'org.testfx:testfx-core:4.0.15-alpha'        

    testCompile (group: 'org.spockframework', name: 'spock-core', version: '1.3-groovy-2.5')
    testCompile ('org.codehaus.groovy:groovy-all:2.5.6')
    testRuntime(
        'com.athaydes:spock-reports:1.2.7',
        'cglib:cglib-nodep:3.2.4'
    )
}

javafx {
    version = "11.0.2"
    modules = [ 'javafx.controls',
            'javafx.fxml',
            'javafx.web'
          ]
}

compileJava {
    doFirst {
        options.compilerArgs = [
                '--module-path', classpath.asPath,
                '--add-modules', 'javafx.controls',
                '--add-modules', 'javafx.fxml',
                '--add-modules', 'javafx.web'
        ]
    }
}

test {
    doFirst {
        jvmArgs = [
            '--module-path', classpath.asPath,
            '--add-modules', 'ALL-MODULE-PATH',
            '--add-exports', 'javafx.graphics/com.sun.javafx.application=org.testfx'            
        ]
    }
}

ここに私のmodule-info.java があります:

module mtd {

requires javafx.controls;
requires javafx.fxml;
requires transitive javafx.graphics;
requires javafx.web;

requires org.testfx;
requires testfx.spock;  

opens gradleTestfxSpock to javafx.graphics;

exports gradleTestfxSpock;      
}

これが私のSpockテストコードです:

package gradleTestfxSpock;

import org.testfx.framework.spock.ApplicationSpec;
import javafx.stage.Stage


public class MainTest extends ApplicationSpec{


    def "Main Test 01"() {              
        expect:     
        println("you are in Main test 01");     
    }

    @Override
    public void start(Stage arg0) throws Exception {
        // TODO Auto-generated method stub      
    }


}

これが私のJavaFXコードです:

package gradleTestfxSpock;

import javafx.application.Application;
import javafx.fxml.FXMLLoader;
import javafx.scene.Parent;
import javafx.scene.Scene;
import javafx.stage.Stage;

public class Main extends Application {

    @Override
    public void start(Stage primaryStage) throws Exception{        
        Parent root = FXMLLoader.load(getClass().getResource("/fxml/sample.fxml"));        
        primaryStage.setTitle("Hello World");
    primaryStage.setScene(new Scene(root, 300, 275));
    primaryStage.show();
    }


    public static void main(String[] args) {
    launch(args);
    }
}

およびコントローラー

package gradleTestfxSpock;
public class Controller {
}

これが私のEclipse gradleプロジェクト構造です:

ここに画像の説明を入力


他の eclipse gradle プロジェクトでは、Spock なしでTestFX Junit4テストを正常に実行しました。

ここに画像の説明を入力


とは別に、TestFXJUnitを使用せずに同じ Spock Test を正常に実行しました。

ここに画像の説明を入力


この Spock テストでいくつかの警告に気付きました:

Working Directory: /home/~/EclipseProjects/gradleSpock
Gradle user home: /home/~/.gradle
Gradle Distribution: Gradle wrapper from target build
Gradle Version: 5.0
Java Home: /usr/lib/jvm/jdk-11.0.2+9
JVM Arguments: None
Program Arguments: None
Build Scans Enabled: false
Offline Mode Enabled: false
Gradle Tasks: clean test

> Task :clean
> Task :compileJava
> Task :compileGroovy NO-SOURCE
> Task :processResources NO-SOURCE
> Task :classes
> Task :compileTestJava NO-SOURCE
> Task :compileTestGroovy
> Task :processTestResources NO-SOURCE
> Task :testClasses

> Task :test
WARNING: An illegal reflective access operation has occurred
WARNING: Illegal reflective access by org.codehaus.groovy.vmplugin.v7.Java7$1 (file:/home/dm/.gradle/caches/modules-2/files-2.1/org.codehaus.groovy/groovy/2.5.6/6936e700f0fb1b50bac0698ada4347a769d40199/groovy-2.5.6.jar) to constructor java.lang.invoke.MethodHandles$Lookup(java.lang.Class,int)
WARNING: Please consider reporting this to the maintainers of org.codehaus.groovy.vmplugin.v7.Java7$1
WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
WARNING: All illegal access operations will be denied in a future release

BUILD SUCCESSFUL in 9s
4 actionable tasks: 4 executed

結論

JUnit を使用した TestFX が機能し、Spock のみが機能するが、Spock を使用した TestFX が機能しない場合、構成に何か問題がありますか?

'org.testfx:testfx-spock:4.0.15-alpha'

どんなアイデアや助けも大歓迎です。

ps Eclipseプロジェクトを複製するNetbeansでTestFX/Spockプロジェクトも作成したことを忘れていましたが、同じ結果が得られました!


その他のテスト

残念ながら、以下のコメントで Leonard Bruenings の非常に良い提案に従ってテストの組み合わせを増やしましたが、うまくいきませんでした。

私の修正された module-info.java は次のようになります。

module mtd {

requires javafx.controls;
requires javafx.fxml;
requires transitive javafx.graphics;
requires javafx.web;

requires org.testfx.junit;
requires org.testfx;
requires testfx.spock;
requires spock.core;
requires junit;

opens gradleTestfxSpock to javafx.graphics, org.testfx, testfx.spock, spock.core, junit, org.testfx.junit;

exports gradleTestfxSpock;      
}

念のため、これを gradle.build の依存関係に追加しました。

implementation 'org.testfx:testfx-junit:4.0.15-alpha'

まだ喜びはありません...

4

2 に答える 2

0

私はこれについての専門家ではありません。おそらく、この点に到達するのに何年もかかったのでしょうが、FWIW 私はそれを機能させることができたと言いたいと思いました:「それ」とは、つまり: Java 11、JavaFX、TestFX-Spock、および javafxplugin の使用。私を助けてくれた José Pereda は、可能であればそれを使用することを勧めているようです。だから、ファイルを最小限に抑えたものを見せようと思っただけです。module-info.java はなく、Spock と Gradle だけでなく、アプリ コードにも Groovy を使用しています。

(簡素化) build.gradle:

plugins {
    id 'java-library'
    id 'groovy'
    id 'eclipse'
    id 'application'
    id 'org.openjfx.javafxplugin' version '0.0.8'
}
repositories {
    mavenCentral()
}
dependencies {
    api 'org.apache.commons:commons-math3:3.6.1'
    implementation 'com.google.guava:guava:27.0.1-jre'
    // although not using JUnit I think it's best to leave this line
    // (included at start by Gradle):
    testImplementation 'junit:junit:4.12'
    implementation 'org.codehaus.groovy:groovy-all:2.5.8'
    testImplementation 'org.spockframework:spock-core:1.2-groovy-2.5'
    testImplementation 'org.testfx:testfx-spock:4.0.15-alpha'
}
mainClassName = 'core.App'
group 'Project'
version '1.0'
sourceCompatibility = 11
javafx {
    version = "13"
    modules = [ "javafx.controls", "javafx.fxml" ]
}

ソース/メイン/groovy/コア/main.groovy:

package core
// (imports omitted)
public class App extends Application {
    void start(Stage primaryStage) throws Exception{
        Parent root = FXMLLoader.load(getClass().getResource("sample.fxml"))
        primaryStage.title = "Hello World"
        primaryStage.scene = new Scene(root, 300, 275)
        primaryStage.show()
    }
    def main(String[] args) {
        launch( App.class, args)
    }
}

class Controller {
    @FXML
    TextField inputField
    @FXML
    Label label
    @FXML
    Button applyButton
    public void applyButtonClicked () {
        label.text = inputField.text
    }
}

ソース/テスト/groovy/コア/test.groovy:

package core
// (imports omitted)
class FuncSpec extends ApplicationSpec {
    void init() throws Exception {
        FxToolkit.registerStage { new Stage() }
    }
    def cleanup() {
        FxToolkit.hideStage()
        // as explained for org.testfx.robot.KeyboardRobot, passing an
        // empty array of the appropriate type releases all keys/mouse buttons
        // NB this is how you create an empty typed array in Groovy
        release(new KeyCode[0])
        release(new MouseButton[0])
    }
    @Override
    public void start(Stage stage) throws Exception {
        Parent mainNode = FXMLLoader.load( App.class.getResource("sample.fxml"))
        stage.scene = new Scene(mainNode)
        stage.show()
        stage.toFront()
    }
    def "test English input"(){
        when: 
        Label label = lookup("#label").query()
        clickOn("#inputField")
        write("This is a test!")
        clickOn("#applyButton")

        then:
        label.text == "This is a test!"
    }
}

src/main/resources/core/sample.fxml // 注意: "core" (パッケージ名) の包含

<?xml version="1.0" encoding="UTF-8"?>
<?import javafx.scene.control.Button?>
<?import javafx.scene.control.Label?>
<?import javafx.scene.control.TextField?>
<?import javafx.scene.layout.AnchorPane?>
<?import javafx.scene.layout.ColumnConstraints?>
<?import javafx.scene.layout.GridPane?>
<?import javafx.scene.layout.RowConstraints?>
<GridPane alignment="center" hgap="10" vgap="10"
    xmlns:fx="http://javafx.com/fxml/1"
    xmlns="http://javafx.com/javafx/8.0.111"
    fx:controller="core.Controller">
    <children>
        <TextField layoutX="15.0" layoutY="25.0" fx:id="inputField" />
        <Label layoutX="15.0" layoutY="84.0" text="TEXT GOES HERE"
            fx:id="label" />
        <Button layoutX="124.0" layoutY="160.0" mnemonicParsing="false"
            text="Apply" onAction="#applyButtonClicked" fx:id="applyButton" />
    </children>
</GridPane>
于 2019-09-29T01:11:11.993 に答える