替换变量时,Oracle OpenScript“读取文件时出错”

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (62)

我正在使用Oracle OpenScript编写Web脚本。

我记录了要执行的动作

  • 打开链接
  • 选择下拉菜单
  • 从下拉菜单中选择字段
  • 保存

我现在试图用我在资产中创建的.csv中的变量替换要打开的链接,但是我得到一个“错误读取文件”消息。

屏幕截图

这是完整的代码:

import oracle.oats.scripting.modules.basic.api.*;
import oracle.oats.scripting.modules.browser.api.*;
import oracle.oats.scripting.modules.functionalTest.api.*;
import oracle.oats.scripting.modules.utilities.api.*;
import oracle.oats.scripting.modules.utilities.api.sql.*;
import oracle.oats.scripting.modules.utilities.api.xml.*;
import oracle.oats.scripting.modules.utilities.api.file.*;
import oracle.oats.scripting.modules.webdom.api.*;

public class script extends IteratingVUserScript {
@ScriptService oracle.oats.scripting.modules.utilities.api.UtilitiesService 
utilities;
@ScriptService oracle.oats.scripting.modules.browser.api.BrowserService 
browser;
@ScriptService 
oracle.oats.scripting.modules.functionalTest.api.FunctionalTestService ft;
@ScriptService oracle.oats.scripting.modules.webdom.api.WebDomService web;

public void initialize() throws Exception {
    browser.launch();
}

/**
 * Add code to be executed each iteration for this virtual user.
 */
public void run() throws Exception {
    beginStep("[1] No Title (/hotelconfig.html)", 0);
    {
        web.window(2, "/web:window[@index='0' or @title='about:blank']")
                .navigate(
                        "URL");
        {
            think(0.093);
        }
    }
    endStep();
    beginStep("[2] Working... (/wia)", 0);
    {
        web.window(4, "/web:window[@index='0' or @title='about:blank']")
                .navigate(
                        "URL");
        web.window(
                5,
                "/web:window[@index='0']")
                .waitForPage(null);
        {
            think(6.198);
        }
        web.selectBox(
                6,
                "/web:window[@index='0']/web:document[@index='0']/web:form[@index='0']/web:select[(@id='office_id' or @name='office_id' or @index='10') and multiple mod 'False']")
                .selectOptionByText(
                        "Office");
        {
            think(2.636);
        }
        web.button(
                7,
                "/web:window[@index='0']/web:document[@index='0']/web:form[@index='0']/web:input_submit[@name='save' or @value='Save' or @index='0']")
                .click();
    }
    endStep();
    beginStep(
            "[3] Intranet - Property info - *Hotel Settings - *Hotel configuration (/hotelconfig.html)",
            0);
    {
        web.window(
                8,
                "/web:window[@index='0']")
                .waitForPage(null);
    }
    endStep();

}

public void finish() throws Exception {
}
}

我查看了在线和Oracle的社区,但我找不到修复程序。我也尝试运行OpenScript诊断工具,但没有运气。

任何人都有任何想法?

提问于
用户回答回答于

我发现使用数据库作为数据提供者更容易。

通过添加带有必要变量的CSV文件,您将能够执行以下替换:

public void run() throws Exception {    
    getDatabank("databank").getNextDatabankRecord();
    String v_dataFilename = "{{db.databank.filename}}";
}
用户回答回答于

Oracle Application Testing Suite(OATS)最好支持csv数据表读取。您粘贴的代码只是录制您执行的内容而没有看到任何问题。和屏幕截图显示错误消息,创建csv时可能出错。

我可以建议外部的Excel阅读器,这是在OATS本身内置的 http://www.testinghive.com/category/oracle-application-testing-suite-tips/

//Define Sheet name to be read, and provide comma seperated to read multiple sheets
String sheetName = "Sheet1";
//Mention excel sheet path
String strFile= "C:\\Demo\\test.xls";

//Defined array list to add Sheets to read
List sheetList = new ArrayList();
sheetList.add(sheetName);
// Iports Sheet1
datatable.importSheets(strFile, sheetList, true, true);
//get rowcount
info("Total rows :"+datatable.getRowCount());
int rowcount=datatable.getRowCount();
//Loop to read all rows
for (int i=0;i<rowcount;i++)
{
//Set current row fromw here you need to start reading, in this case start from first row
datatable.setCurrentRow(sheetName, i);
String strCompany=(String) datatable.getValue(sheetName,i,"Company");
String strEmpFName=(String) datatable.getValue(sheetName,i,"FirstName");
String strEmpLName=(String) datatable.getValue(sheetName,i,"LastName");
String strEmpID=(String) datatable.getValue(sheetName,i,"EmpID");
String strLocation=(String) datatable.getValue(sheetName,i,"Location");

//prints first name and last name
System.out.println("First Name : "+strEmpFName+", Last Name : "+strEmpLName);

//Sets ACTIVE column in excel sheet to Y
String strActive="Y";
datatable.setValue(sheetName, i, datatable.getColumn(sheetName, datatable.getColumnIndex("Active")), strActive);

}

//Updates sheet with updated values ie ACTIVE column sets to Y
datatable.exportToExcel("C:\\Demo\\test1.xlsx");

}

public void finish() throws Exception {
}
}

扫码关注云+社区

领取腾讯云代金券