0

誰でも問題の理由を説明するのを手伝ってもらえますか?


type(waitForObject(":アドレス帳 - 無名.File_QTableWidget"), "");

var Forename = testData.field(record, "Forename");

type(waitForObject(":Address Book - Named.File_QTableWidget"), Forename);


テストデータ: 名の値は「ABCD」です

しかし、それは申請書にAだけを記入しており、全文ではありません。

入力データの最初の文字だけを入力する理由は何ですか?

4

2 に答える 2

0

タイプ値パラメーターで指定された完全な文字列は、:Address Book - Named.File_QTableWidget フィールドに入力する必要があります。

:Address Book - Named.File_QTableWidget について具体的なことはありますか? Squish サンプル AddressBook AUT のウィジェットのようです。

type() および testData.field 関数を使用したサンプル スクリプト:

function invokeMenuItem(menu, item)
{
    activateItem(waitForObjectItem("{type='QMenuBar' visible='true'}", menu));
    activateItem(waitForObjectItem("{type='QMenu' title='" + menu + "'}", item));
}


function addNameAndAddress(oneNameAndAddress)
{
    invokeMenuItem("Edit", "Add...");
    var fieldNames = new Array("Forename", "Surname", "Email", "Phone");
    for (var i = 0; i < oneNameAndAddress.length; ++i) {
        var fieldName = fieldNames[i];
        var text = oneNameAndAddress[i];
        type(waitForObject(":" + fieldName + ":_QLineEdit"), text);
    }
    clickButton(waitForObject(":Address Book - Add.OK_QPushButton"));
}


function checkNameAndAddress(table, record)
{
    waitForObject(table);
    for (var column = 0; column < testData.fieldNames(record).length; ++column)
        test.compare(table.item(0, column).text(), // New addresses are inserted at the start
                     testData.field(record, column));
}


function closeWithoutSaving()
{
    invokeMenuItem("File", "Quit");
    clickButton(waitForObject(":Address Book.Cancel_QPushButton"));
}


function main()
{
    startApplication("addressbook");
    var table = waitForObject(":Address Book_QTableWidget");
    invokeMenuItem("File", "New");
    test.verify(table.rowCount == 0);
    var limit = 10; // To avoid testing 100s of rows since that would be boring
    var records = testData.dataset("MyAddresses.tsv");
    for (var row = 0; row < records.length; ++row) {
        var record = records[row];
        var forename = testData.field(record, "Forename");
        var surname = testData.field(record, "Surname");
        var email = testData.field(record, "Email");
        var phone = testData.field(record, "Phone");
        table.setCurrentCell(0, 0); // always insert at the start
        addNameAndAddress(new Array(forename, surname, email, phone));
        checkNameAndAddress(table, record);
        if (row > limit)
            break;
    }
    test.verify(table.rowCount == row + 1);
    closeWithoutSaving();
}
于 2015-02-05T03:56:32.773 に答える