窗口原生键输入在javascript中用于挤压自动化工具



谁能帮我解释这个问题?


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

var Forename

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

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


测试数据:名字值为"ABCD"

但它在应用程序中只输入 A,而不是全文。

仅输入输入数据的第一个字符的原因可能是什么?

"

type"方法一次只输入/考虑一个值。忽略其余部分

尝试一次输入一个字母

type(waitForObject(":Address Book - Unnamed.File_QTableWidget"), 'A');
type(waitForObject(":Address Book - Unnamed.File_QTableWidget"), 'B');
type(waitForObject(":Address Book - Unnamed.File_QTableWidget"), 'C');

其他候补是

nativeType("Hello")

button = findObject("Addressbook.ABCentralWidget1.AddButton")
button.setText("ABCD") 
类型

值 parementer 中指定的完整字符串应输入到 :通讯簿 - Unnamed.File_QTableWidget字段中。

关于:地址簿 - Unnamed.File_QTableWidget有什么具体内容吗?它似乎是来自Squish示例地址簿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();
}

最新更新