TestCase QML Type

ユニットテストケースを表します。詳細...

Import Statement: import QtTest
Inherits:

Item

プロパティ

メソッド

詳細説明

QML テストケース入門

テストケースは、JavaScript の関数として TestCase 型の中に記述します:

import QtQuick 2.0
import QtTest 1.2

TestCase {
    name: "MathTests"

    function test_math() {
        compare(2 + 2, 4, "2 + 2 = 4")
    }

    function test_fail() {
        compare(2 + 2, 5, "2 + 2 = 5")
    }
}

test_" で始まる名前の関数は、実行されるテストケースとして扱われます。name プロパティは、出力中の関数のプレフィックスとして使用されます:

********* Start testing of MathTests *********
Config: Using QTest library 4.7.2, Qt 4.7.2
PASS   : MathTests::initTestCase()
FAIL!  : MathTests::test_fail() 2 + 2 = 5
   Actual (): 4
   Expected (): 5
   Loc: [/home/.../tst_math.qml(12)]
PASS   : MathTests::test_math()
PASS   : MathTests::cleanupTestCase()
Totals: 3 passed, 1 failed, 0 skipped
********* Finished testing of MathTests *********

JavaScript のプロパティの仕組み上、テスト関数が見つかる順番は予測できません。予測しやすくするために、テストフレームワークは関数を名前の昇順に並べ替えます。これは、順番に実行しなければならないふたつのテストがある場合に役立ちます。

複数の TestCase 型を指定することができます。すべて完了すると、テストプログラムは終了します。(前提条件が失敗したので) テストケースを実行する必要がない場合は、optional を true に設定します。

データ駆動型テスト

テーブルデータは、"_data" で終わる関数名を使ってテストに与えることができます。あるいは、init_data() 関数を使用して、TestCase 型に "_data" 関数がないすべてのテスト関数に対してデフォルトのテストデータを提供することもできます:

import QtQuick 2.0
import QtTest 1.2

TestCase {
    name: "DataTests"

    function init_data() {
      return [
           {tag:"init_data_1", a:1, b:2, answer: 3},
           {tag:"init_data_2", a:2, b:4, answer: 6}
      ];
    }

    function test_table_data() {
        return [
            {tag: "2 + 2 = 4", a: 2, b: 2, answer: 4 },
            {tag: "2 + 6 = 8", a: 2, b: 6, answer: 8 },
        ]
    }

    function test_table(data) {
        //data comes from test_table_data
        compare(data.a + data.b, data.answer)
    }

    function test_default_table(data) {
        //data comes from init_data
        compare(data.a + data.b, data.answer)
    }
}

テストフレームワークは、テーブルのすべての行を繰り返し処理し、それぞれの行をテスト関数に渡します。このように、カラムを抽出してテストに使用することができます。tag このカラムは、行が失敗したときにテストフレームワークによって出力されます。

ベンチマーク

benchmark_" で始まる名前の関数は、Qt ベンチマークフレームワークで複数回実行されます。これは QTestLib の C++ 版でQBENCHMARK マクロを使うのと同じです。

TestCase {
    id: top
    name: "CreateBenchmark"

    function benchmark_create_component() {
        let component = Qt.createComponent("item.qml")
        let obj = component.createObject(top)
        obj.destroy()
        component.destroy()
    }
}

RESULT : CreateBenchmark::benchmark_create_component:
     0.23 msecs per iteration (total: 60, iterations: 256)
PASS   : CreateBenchmark::benchmark_create_component()

QBENCHMARK_ONCE マクロの効果を得るには、テスト関数名の前に "benchmark_once_" をつけます。

キーボードとマウスイベントのシミュレート

keyPress()、keyRelease()、keyClick() メソッドを使用すると、 ユニットテスト内でキーボードイベントをシミュレートすることができます。イベントは現在フォーカスされている QML アイテムに送られます。Qt.Key enum 値か latin1 char (長さ 1 の文字列) を渡すことができます。

Rectangle {
    width: 50; height: 50
    focus: true

    TestCase {
        name: "KeyClick"
        when: windowShown

        function test_key_click() {
            keyClick(Qt.Key_Left)
            keyClick("a")
            ...
        }
    }
}

mousePress(),mouseRelease(),mouseClick(),mouseDoubleClickSequence(),mouseMove() メソッドも同様の方法でマウスイベントをシミュレートすることができます。

テストで他のウィンドウを作成すると、それらのウィンドウがアクティブになり、 TestCase のウィンドウからフォーカスが奪われてしまう可能性があります。TestCase のウィンドウがアクティブであることを確認するには、次のコードを使用します:

testCase.Window.window.requestActivate()
tryCompare(testCase.Window.window, "active", true)

注意:キーボードとマウスのイベントは、メインウィンドウが表示された後でなければ配信できません。それ以前にイベントを配信しようとすると、失敗します。whenwindowShown プロパティを使用して、メインウィンドウがいつ表示されたかを追跡します。

動的に作成されるテストオブジェクトの管理

QML のテストの典型的なパターンは、動的に項目を作成し、テスト関数の最後でそれを破棄するというものです:

TestCase {
    id: testCase
    name: "MyTest"
    when: windowShown

    function test_click() {
        let item = Qt.createQmlObject("import QtQuick 2.0; Item {}", testCase);
        verify(item);

        // Test item...

        item.destroy();
    }
}

このパターンの問題点は、テスト関数の中で何らかの失敗があった場合、item.destroy() への呼び出しがスキップされ、テストケースが終了するまでアイテムがシーンにぶら下がったままになってしまうことです。例えば、入力イベントをブロックしてしまったり、関係のないデバッグ出力を生成してしまったりして、コードの実行を追跡するのが難しくなります。

代わりにcreateTemporaryQmlObject() をコールすることで、テスト関数の終了時にオブジェクトが破棄されることが保証されます:

TestCase {
    id: testCase
    name: "MyTest"
    when: windowShown

    function test_click() {
        let item = createTemporaryQmlObject("import QtQuick 2.0; Item {}", testCase);
        verify(item);

        // Test item...

        // Don't need to worry about destroying "item" here.
    }
}

ComponentcreateObject() 関数によって生成されたオブジェクトについては、createTemporaryObject() 関数を使用することができます。

アプリケーションロジックからテストを分離する

たいていの場合、テストをアプリケーションロジックから切り離したいと思うでしょう。

たとえば、次のようなプロジェクト構造が考えられます:

.
| — CMakeLists.txt
| — main.cpp
| - main.qml
| — MyModule
    | — MyButton.qml
    | — CMakeLists.txt
| — tests
    | — tst_testqml.qml
    | — main.cpp
    | — setup.cpp
    | — setup.h

MyModule/MyButton.qml をテストするために、MyModule/CMakeLists.txtMyModule 用のライブラリを作成し、テストプロジェクトtests/UnitQMLTests/CMakeLists.txt にリンクします:

.
    ...
qt_add_library(MyModule STATIC)

qt6_add_qml_module(MyModule
    URI MyModule
    QML_FILES MyButton.qml
)
    ...
#include <QtQuickTest/quicktest.h>
#include "setup.h"

QUICK_TEST_MAIN_WITH_SETUP(TestQML, Setup)
#include "setup.h"

void Setup::applicationAvailable()
{
    // custom code that doesn't require QQmlEngine
}

void Setup::qmlEngineAvailable(QQmlEngine *engine)
{
    // add import paths
}

void Setup::cleanupTestCase()
{
    // custom code to clean up before destruction starts
}
#ifndef SETUP_H
#define SETUP_H

#include <QObject>
#include <QQmlEngine>

class Setup : public QObject
{
    Q_OBJECT
public:
    Setup() = default;

public slots:
    void applicationAvailable();
    void qmlEngineAvailable(QQmlEngine *engine);
    void cleanupTestCase();
};

#endif // SETUP_H
    ...
add_subdirectory(MyModule)
add_subdirectory(tests)

qt_add_executable(MyApplication
    src/main.cpp
)

qt_add_qml_module(MyApplication
    URI MyApplication
    QML_FILES main.qml
)
    ...

次に、tests/tst_testqml.qml で、MyModule/MyButton.qml をインポートします:

です。
import QtQuick
import QtQuick.Controls

import QtTest
import MyModule

Item {
    width: 800
    height: 600

    MyButton {
        id: myButton
        anchors.centerIn: parent
    }

    TestCase {
        name: "MyButton"
        when: windowShown

        function test_clickToExpand() {
            const widthBeforeClick = myButton.width;
            mouseClick(myButton);
            const widthAfterClick = myButton.width;
            verify(widthBeforeClick < widthAfterClick);
        }
    }
}
import QtQuick
import QtQuick.Controls

Button {
    width: 50
    height: 50
    onClicked: width = 100
}

SignalSpyQt Quick Testも参照して ください。

プロパティのドキュメント

completed : bool

このプロパティは、テストケースの実行が完了すると true に設定されます。テストケースは一度しか実行されません。初期値は false です。

running およびwhenも参照してください


name : string

このプロパティは、結果報告用のテストケースの名前を定義します。デフォルト値は空文字列です。

TestCase {
    name: "ButtonTests"
    ...
}

optional : bool

テスト アプリケーションでは、複数のTestCase タイプを指定できます。すべて完了すると、アプリケーションは終了します。前提条件が失敗したため)テストケースを実行する必要がない場合は、このプロパティを true に設定できます。デフォルト値は false です。

TestCase {
    when: false
    optional: true
    function test_not_run() {
        verify(false)
    }
}

when およびcompletedも参照のこと


running : bool

このプロパティは、テストケースの実行中に true に設定されます。初期値は false で、テストケースが完了すると、値は再び false になります。

completed およびwhen参照して ください。


when : bool

このプロパティは、アプリケーションがテストケースの実行を希望するときに true に設定します。デフォルト値は true です。次の例では、ユーザーがマウスボタンを押したときにテストが実行されます:

Rectangle {
    id: foo
    width: 640; height: 480
    color: "cyan"

    MouseArea {
        id: area
        anchors.fill: parent
    }

    property bool bar: true

    TestCase {
        name: "ItemTests"
        when: area.pressed
        id: test1

        function test_bar() {
            verify(bar)
        }
    }
}

すべてのTestCase タイプがトリガされ、実行されると、テストアプリケーションは終了します。optional プロパティを使用して、TestCase タイプを除外することができます。

optional およびcompletedも参照して ください。


windowShown : bool

このプロパティは、QML 表示ウィンドウが表示された後、true に設定されます。通常、テスト ケースは、テスト アプリケーションがロードされ、ウィンドウが表示される前に実行されます。テストケースに視覚的な型や動作が含まれる場合は、ウィンドウが表示された後まで実行を遅らせる必要があるかもしれません。

Button {
    id: button
    onClicked: text = "Clicked"
    TestCase {
        name: "ClickTest"
        when: windowShown
        function test_click() {
            button.clicked();
            compare(button.text, "Clicked");
        }
    }
}

メソッド ドキュメント

cleanup()

この関数は、TestCase 型で実行される各テスト関数の後に呼び出されます。デフォルトの実装は何もしません。アプリケーションは、各テスト関数の後にクリーンアップを実行する独自の実装を提供できます。

init() およびcleanupTestCase()も参照


cleanupTestCase()

この関数は、TestCase 型の他のすべてのテスト関数が完了した後に呼び出されます。デフォルトの実装では何も行いません。アプリケーションは、テストケースのクリーンアップを実行するための独自の実装を提供することができます。

initTestCase() およびcleanup()も参照


compare(actual, expected, message = "")

actualexpected と同じでない場合、現在のテストケースに失敗し、オプションのmessage を表示します。C++ のQCOMPARE(actual, expected) に似ています。

tryCompare() およびfuzzyCompareも参照


object createTemporaryObject(Component component, object parent, object properties)

この関数は、指定されたcomponent とオプションのparent およびproperties から QML オブジェクトを動的に生成します。返されたオブジェクトはcleanup() の実行終了後に破棄されます(まだ破棄されていない場合)。 つまり、この関数で作成されたオブジェクトは、テストの失敗の有無にかかわらず、 テストが終わるたびに破棄されることが保証されています。

オブジェクトの作成中にエラーがあった場合は、null が返されます。

この関数は内部的にcomponent.createObject() を呼び出す。

Managing Dynamically Created Test Objectsも参照してください


object createTemporaryQmlObject(string qml, object parent, string filePath)

この関数は、与えられたqml 文字列から、指定されたparent を持つ QML オブジェクトを動的に生成します。返されたオブジェクトはcleanup() の実行終了後に破棄されます(破棄されていない場合)。 つまり、この関数で作成されたオブジェクトは、テストの失敗の有無にかかわらず、 テストが終わるたびに破棄されることが保証されています。

オブジェクトの作成中にエラーがあった場合は、null が返される。

filePath が指定された場合、作成されたオブジェクトのエラー報告に使用されます。

この関数は、内部的にQt.createQmlObject() を呼び出します。

Managing Dynamically Created Test Objectsも参照してください


expectFail(tag, message)

データ駆動型テストでは、tag に関連付けられている行を失敗すると予想される行としてマークします。失敗が発生すると、message を表示し、テストを中止して、テストに合格のマークを付けます。C++のQEXPECT_FAIL(tag, message, Abort)

テストがデータ駆動型でない場合は、tag を空文字列に設定する必要があります。

expectFailContinue()も参照


expectFailContinue(tag, message)

データ駆動型テストでは、tag に関連付けられた行を失敗とマークします。失敗が発生したら、message を表示し、テストを続行します。C++のQEXPECT_FAIL(tag, message, Continue)

テストがデータ駆動型でない場合は、tag を空文字列に設定する必要があります。

expectFail()も参照


fail(message = "")

オプションのmessage を指定して、現在のテスト・ケースを失敗させます。C++ のQFAIL(message) に似ています。


[since 6.3] failOnWarning(message)

message にマッチする警告ごとに、テストの失敗をテストログに追加します。失敗が追加されると、テスト関数は実行を続行します。

message には文字列か、メッセージのパターンを示す正規表現を指定します。後者の場合、遭遇した警告ごとに、最初にマッチしたパターンが失敗の原因となり、残りのパターンは無視されます。

すべてのパターンは、各テスト関数の最後でクリアされます。

例えば、以下のスニペットは、"Something bad happened" というテキストを含む警告が発生した場合、テストに失敗します:

failOnWarning("Something bad happened")

次のスニペットは、指定されたパターンにマッチする警告が発生した場合、テストに失敗します:

failOnWarning(/[0-9]+ bad things happened/)

指定した警告をトリガーするすべてのテストを失敗させるには、init() でこの関数に適切な正規表現を渡します:

function init() {
    failOnWarning(/.?/)
}

注意: JavaScript の RegExp オブジェクトであるにもかかわらず、それはそのように解釈されません; 代わりに、パターンはQRegularExpression に渡されます。

注意: ignoreMessage() はこの関数よりも優先されるので、ignoreMessage()failOnWarning() の両方に与えられたパターンにマッチする警告は無視されます。

このメソッドは Qt 6.3 で導入されました。

QTest::failOnWarning() およびwarn()も参照してください


QtObject findChild(parent, objectName)

objectName を持つparent の最初の子、またはそのような項目が存在しない場合はnull を返します。視覚的な子と非視覚的な子の両方が再帰的に検索され、視覚的な子が最初に検索されます。

compare(findChild(item, "childObject"), expectedChildObject);

fuzzyCompare(actual, expected, delta, message = "")

actualexpected の差がdelta より大きい場合、現在のテストケースは失敗し、オプションのmessage を表示します。C++のqFuzzyCompare(actual, expected) に似ていますが、delta の値が必要です。

この関数は、actualexpected の両方の値がカラー値に変換できる場合、カラー比較にも使用できます。RGBA チ ャ ン ネル値の差のいずれかがdelta を超え る と き は、 テ ス ト は失敗 し ます。

tryCompare() およびcompare()も参照


object grabImage(item)

与えられたitem のスナップショット画像オブジェクトを返します。

返される画像オブジェクトは、以下のプロパティを持ちます:

  • width 基礎となる画像の幅を返します(5.10以降)。
  • height 基礎となる画像の高さを返します(5.10以降)。
  • size 基礎となる画像のサイズを返します(5.10以降)。

さらに、返される image オブジェクトには以下のメソッドがあります:

  • red(x, y) x,y位置のピクセルの赤チャンネルの値を返します。
  • green(x, y) x,y位置のピクセルの緑チャンネル値を返します。
  • blue(x, y) x,y位置のピクセルの青チャンネル値を返します。
  • alpha(x, y) x,y位置の画素のアルファチャンネル値を返します。
  • pixel(x, y) x,y位置の画素の色値を返します。
  • equals(image) この画像がimageと同一の場合は を返します - を参照(5.6以降)。true QImage::operator==

    例えば

    let image = grabImage(rect);
    compare(image.red(10, 10), 255);
    compare(image.pixel(20, 20), Qt.rgba(255, 0, 0, 255));
    
    rect.width += 10;
    let newImage = grabImage(rect);
    verify(!newImage.equals(image));
  • save(path) 画像を与えられたパスに保存します。画像を保存できない場合は例外がスローされます。(5.10 以降)

    これは、失敗したテストの事後分析を行うときなどに便利です:

    let image = grabImage(rect);
    try {
        compare(image.width, 100);
    } catch (ex) {
        image.save("debug.png");
        throw ex;
    }

ignoreWarning(message)

message を無視された警告メッセージとしてマークします。このメッセージが発生すると、警告は表示されずテストはパスします。このメッセージが表示されなければ、テストは失敗します。C++ のQTest::ignoreMessage(QtWarningMsg, message) に似ています。

Qt 5.12 以降、message は文字列か、無視するメッセージのパターンを指定する正規表現にすることができます。

例えば、以下のスニペットは文字列の警告メッセージを無視します:

ignoreWarning("Something sort of bad happened")

また、次のスニペットは、いくつかの警告メッセージにマッチする正規表現を無視します:

ignoreWarning(new RegExp("[0-9]+ bad things happened"))

注: JavaScriptのRegExpオブジェクトであるにもかかわらず、それはそのように解釈されません。代わりに、パターンはQRegularExpression に渡されます。

warn()も参照


init()

この関数は、TestCase 型で実行される各テスト関数の前に呼び出されます。デフォルトの実装は何もしません。アプリケーションは、各テスト関数の前に初期化を行う独自の実装を提供することができます。

cleanup() およびinitTestCase()も参照


initTestCase()

この関数は、TestCase 型の他のテスト関数の前に呼び出されます。デフォルトの実装では何もしません。アプリケーションは、テストケースの初期化を行うための独自の実装を提供することができます。

cleanupTestCase() およびinit()も参照


bool isPolishScheduled(object itemOrWindow)

itemOrWindowItem の場合、この関数は、最後にpolish() が呼び出されてからupdatePolish() が呼び出されていなければtrue を返し、そうでなければfalse を返します。

Qt 6.5 以降では、itemOrWindowWindow である場合、この関数は、updatePolish() が最後にpolish() を呼び出したとき以降に、管理しているアイテムに対して呼び出されていなければtrue を返し、そうでなければfalse を返します。

QMLでプロパティに値を代入する場合、代入の結果としてアイテムが行わなけれ ばならないレイアウトは、すぐに反映されないかもしれません。このような場合、この関数を使用することで、テストの実行が続行される前に項目が磨かれたことを確認することができます。たとえば、次のようになります:

verify(isPolishScheduled(item))
verify(waitForItemPolished(item))

上記のisPolishScheduled() への呼び出しがない場合、waitForItemPolished() への呼び出しは、磨きが予定されていないことがわかり、そのため項目はすでに磨かれていると仮定して即座にパスするかもしれません。この関数を使用することで、なぜアイテムが磨かれなかったのかが明らかになり、そのような状況下でテストが早期に失敗するようになります。

waitForPolish(),QQuickItem::polish(),QQuickItem::updatePolish()も参照


keyClick(key, modifiers = Qt.NoModifier, delay = -1)

現在フォーカスされているアイテムに対して、オプションのmodifierskey をクリックすることをシミュレートします。delay が 0 より大きい場合、テストはdelay ミリ秒待ちます。

イベントは、TestCase ウィンドウか、複数のウィンドウの場合は、現在のアクティブなウィンドウに送られます。詳細はQGuiApplication::focusWindow ()を参照。

keyPress() およびkeyRelease()も参照の こと。


keyPress(key, modifiers = Qt.NoModifier, delay = -1)

現在フォーカスされているアイテムに対して、オプションでmodifiers を指定してkey を押すことをシミュレートする。delay が 0 より大きい場合、テストはdelay ミリ秒待ちます。

イベントは、TestCase ウィンドウか、複数のウィンドウの場合は、現在のアクティブなウィンドウに送られます。詳細はQGuiApplication::focusWindow() を参照。

注意:ある時点で、keyRelease ()を使ってキーを離す必要がある。

keyRelease() およびkeyClick()も参照


keyRelease(key, modifiers = Qt.NoModifier, delay = -1)

現在フォーカスされているアイテムに対して、オプションのmodifierskey を解放することをシミュレートする。delay が 0 より大きい場合、テストはdelay ミリ秒待ちます。

イベントは、TestCase ウィンドウか、複数のウィンドウの場合は、現在のアクティブなウィンドウに送られます。詳細はQGuiApplication::focusWindow ()を参照。

keyPress() およびkeyClick()も参照の こと。


keySequence(keySequence)

keySequence のタイピングをシミュレートする。 キーシーケンスは、standard keyboard shortcuts のいずれかに設定するか、最大4つのキー押下シーケンスを含む文字列で記述することができる。

各イベントは、TestCase ウィンドウに送信され、複数のウィンドウがある場合は、現在のアクティブなウィンドウに送信される。詳細はQGuiApplication::focusWindow() を参照のこと。

keyPress()、keyRelease()、GNU Emacs Style Key SequencesShortcut.sequenceも参照の こと。


mouseClick(item, x = item.width / 2, y = item.height / 2, button = Qt.LeftButton, modifiers = Qt.NoModifier, delay = -1)

button modifiers itemクリックの位置はxy で定義される。xy が定義されていない場合、位置はitem の中心となる。delay が指定されている場合、テストはボタンを押す前とボタンを離す前に、指定されたミリ秒の間待つ。

xy で指定された位置は、item の座標系からウィンドウ座標系に変換され、配信される。item が他のアイテムで隠されていたり、item の子アイテムがその位置を占めている場合、イベントは代わりに他のアイテムに配信されます。

mousePress(),mouseRelease(),mouseDoubleClickSequence(),mouseMove(),mouseDrag(),mouseWheel()も参照のこと


mouseDoubleClickSequence(item, x = item.width / 2, y = item.height / 2, button = Qt.LeftButton, modifiers = Qt.NoModifier, delay = -1)

マウスのダブルクリックによって生成されるイベントの完全なシーケンスをシミュレートしますbutton modifiers オプション付きitem

このメソッドは、ユーザがダブルクリックしたときに発生する一連のマウスイベントを再現します:Press-Release-Press-DoubleClick-Release。

クリックの位置はxy で定義されます。xy が定義されていない場合、位置はitem の中心になります。delay が指定されている場合、テストはボタンを押す前と離す前に指定されたミリ秒の間待機します。

xy で指定された位置は、item の座標系からウィンドウ座標系に変換され、配信される。もし、item が他のアイテムで隠されていたり、item の子アイテムがその位置を占めていたりすると、イベントは代わりに他のアイテムに配信されます。

この QML メソッドは Qt 5.5 で導入されました。

mousePress(),mouseRelease(),mouseClick(),mouseMove(),mouseDrag(),mouseWheel()も参照してください


mouseDrag(item, x, y, dx, dy, button = Qt.LeftButton, modifiers = Qt.NoModifier, delay = -1)

button が押され、オプションでmodifiers が指定された状態で、item 上でマウスをドラッグすることをシミュレートします。 最初のドラッグ位置はxy で定義され、ドラッグ距離はdxdy で定義されます。delay が指定された場合、このテストはボタンを離す前に指定されたミリ秒の間待機します。

xy で指定された位置は、item の座標系からウィンドウ座標系に変換され、配信されます。item が他のアイテムで隠されていたり、item の子がその位置を占有している場合、イベントは代わりに他のアイテムに配信されます。

mousePress()、mouseClick()、mouseDoubleClickSequence()、mouseMove()、mouseRelease()、mouseWheel()も参照のこと


mouseMove(item, x = item.width / 2, y = item.height / 2, delay = -1, buttons = Qt.NoButton)

buttons マウスポインタをitem 内のxy で指定された位置に移動します。Qt 6.0 以降、xy が定義されていない場合、その位置はitem の中心となります。

delay (ミリ秒単位)が与えられると、テストはマウスポインタを動かす前に待機します。

xy で与えられた位置は、item の座標系からウィンドウ座標系に変換され、配信される。item が他のアイテムによって隠されていたり、item の子アイテムがその位置を占めている場合、イベントは代わりに他のアイテムに送られます。

mousePress(),mouseRelease(),mouseClick(),mouseDoubleClickSequence(),mouseDrag(),mouseWheel()も参照


mousePress(item, x = item.width / 2, y = item.height / 2, button = Qt.LeftButton, modifiers = Qt.NoModifier, delay = -1)

item の上で、オプションのmodifiers でマウスbutton を押すことをシミュレートする。 位置はxy で定義される。x またはy が定義されていない場合、位置はitem の中心となる。delay が指定されている場合、テストは押す前に指定されたミリ秒の間待つ。

xy で指定された位置は、item の座標系からウィンドウ座標系に変換され、配信される。item が他のアイテムで隠されていたり、item の子がその位置を占めていたりすると、イベントは代わりに他のアイテムに配信されます。

mouseRelease(),mouseClick(),mouseDoubleClickSequence(),mouseMove(),mouseDrag(),mouseWheel()も参照


mouseRelease(item, x = item.width / 2, y = item.height / 2, button = Qt.LeftButton, modifiers = Qt.NoModifier, delay = -1)

item にオプションのmodifiers を指定して、マウスbutton を離すことをシミュレートする。離す位置はxy で定義される。x またはy が定義されていない場合、位置はitem の中心となる。delay が指定されている場合、テストはボタンを離す前に指定されたミリ秒の間待つ。

xy で指定された位置は、item の座標系からウィンドウ座標系に変換され、配信される。item が他のアイテムで隠されていたり、item の子がその位置を占有している場合、イベントは代わりに他のアイテムに配信されます。

mousePress(),mouseClick(),mouseDoubleClickSequence(),mouseMove(),mouseDrag(),mouseWheel()も参照


mouseWheel(item, x, y, xDelta, yDelta, button = Qt.LeftButton, modifiers = Qt.NoModifier, delay = -1)

button が押され、オプションでmodifiers が押されたitem 上でマウスホイールを回転させることをシミュレートする。ホイールイベントの位置はxy で定義されます。delay が指定された場合、テストはボタンを離す前に指定されたミリ秒の間待機します。

xy で指定された位置は、item の座標系からウィンドウ座標系に変換され、配信されます。item が他のアイテムで隠されていたり、item の子アイテムがその位置を占めている場合、イベントは代わりに他のアイテムに配信されます。

xDeltayDelta には、車輪の回転距離が8分の1度単位で格納されている。詳しくはQWheelEvent::angleDelta() を参照。

mousePress()、mouseClick()、mouseDoubleClickSequence()、mouseMove()、mouseRelease()、mouseDrag()、QWheelEvent::angleDelta()も参照の こと。


skip(message = "")

現在のテストケースをスキップし、オプションのmessage を表示します。これがデータ駆動型テストの場合は、現在の行のみがスキップされます。C++ のQSKIP(message) に似ています。


sleep(ms)

Qt イベントを処理せずにms ミリ秒スリープします。

wait() およびwaitForRendering()も参照してください


TouchEventSequence touchEvent(object item)

シミュレートされたタッチスクリーン (QPointingDevice) を通して、一連のタッチイベントを開始します。イベントはitem を含むウィンドウに送られます。

返されたオブジェクトは、単一のQTouchEvent を通して配信されるイベントを列挙するために使用されます。タッチは、特に指定がない限り、TestCase を含むウィンドウに配信される。

Rectangle {
    width: 640; height: 480

    MultiPointTouchArea {
        id: area
        anchors.fill: parent

        property bool touched: false

        onPressed: touched = true
    }

    TestCase {
        name: "ItemTests"
        when: windowShown
        id: test1

        function test_touch() {
            let touch = touchEvent(area);
            touch.press(0, area, 10, 10);
            touch.commit();
            verify(area.touched);
        }
    }
}

TouchEventSequence::press()、TouchEventSequence::move()、TouchEventSequence::release()、TouchEventSequence::stationary()、TouchEventSequence::commit()、QInputDevice::DeviceTypeも参照のこと


tryCompare(obj, property, expected, timeout = 5000, message = "")

obj で指定されたpropertyexpected と同じでない場合、現在のテストケースに失敗し、オプションのmessage を表示します。テストは、timeout (ミリ秒単位)に達するまで複数回再試行されます。

この関数は、プロパティが非同期イベントに基づいて値を変更するアプリケーションをテストするためのものです。同期的なプロパティ変更のテストには、compare() を使用してください。

tryCompare(img, "status", BorderImage.Ready)
compare(img.width, 120)
compare(img.height, 120)
compare(img.horizontalTileMode, BorderImage.Stretch)
compare(img.verticalTileMode, BorderImage.Stretch)

SignalSpy::wait() は、シグナルが発せられるのを待つための代替方法を提供します。

compare() およびSignalSpy::wait()も参照


tryVerify(function, timeout = 5000, message = "")

指定されたtimeout (ミリ秒単位)が経過する前にfunctiontrue に評価されない場合、現在のテストケースは失敗となる。この関数は、タイムアウトに達するまで複数回評価されます。失敗すると、オプションでmessage が表示される。

この関数は、非同期イベントに基づいて条件が変化するアプリケーションをテストするためのものです。同期的な条件変更のテストにはverify() を使用し、非同期的なプロパティ変更のテストにはtryCompare() を使用します。

たとえば、以下のコードでは、tryCompare ()を使用することはできません。なぜなら、currentItem プロパティが短期間だけnull になる可能性があるからです:

tryCompare(listView.currentItem, "text", "Hello");

その代わりに、tryVerify() を使用して、まずcurrentItemnull でないことをチェックし、その後に通常の比較を使用することができます:

tryVerify(function(){ return listView.currentItem })
compare(listView.currentItem.text, "Hello")

verify()、compare()、tryCompare()、SignalSpy::wait()も参照のこと


verify(condition, message = "")

condition が偽の場合、現在のテストケースに失敗し、オプションのmessage を表示します。C++ のQVERIFY(condition) またはQVERIFY2(condition, message) に似ています。


wait(ms)

Qt イベントを処理している間、ms ミリ秒待機します。

注意: このメソッドは、正確なタイマーを使って実際の待機を行います。待機しているイベントが発生するとは限りません。特に、アニメーションやTimer QMLタイプは、様々な要因によって、正確なタイマーと粗いタイマーのどちらかを使うことができます。粗いタイマーの場合、TestCase::wait() で使用される正確なタイマーに対して、5%程度のドリフトを期待する必要があります。しかし、オペレーティングシステムは通常、タイマーの厳密な保証を提供しないため、Qtはドリフトについて厳密な保証をすることはできません。

sleep(),waitForRendering(),Qt::TimerTypeも参照してください


[since 6.5] bool waitForPolish(object windowOrItem, int timeout = 5000)

windowOrItem がItemの場合、この関数はtimeout ミリ秒またはisPolishScheduled(windowOrItem)false を返すまで待つ。isPolishScheduled(windowOrItem)timeout ミリ秒以内にfalse を返した場合はtrue を返し、そうでない場合はfalse を返します。

windowOrItem がウィンドウの場合、この関数はウィンドウが管理するすべてのアイテムについて、timeout ミリ秒またはisPolishScheduled()false を返すまで待ちます。isPolishScheduled()timeout ミリ秒以内にすべてのアイテムについてfalse を返す場合はtrue を返し、そうでない場合はfalse を返します。

このメソッドは Qt 6.5 で導入されました。

isPolishScheduled(),QQuickItem::polish(),QQuickItem::updatePolish()も参照してください


waitForRendering(item, timeout = 5000)

timeout ミリ秒またはレンダラーによってitem がレンダリングされるまで待ちます。timeout ミリ秒以内にitem がレンダリングされた場合は true を返し、そうでない場合は false を返します。デフォルトのtimeout の値は 5000 です。

sleep() およびwait()も参照のこと


warn(message)

警告メッセージとしてmessage を表示する。C++ のqWarning(message) に似ています。

ignoreWarning()も参照して ください。


本ドキュメントに含まれる文書の著作権は、それぞれの所有者に帰属します 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。