如何导入数据文件进行 UFT API 测试?

How to import data file for UFT API testing?(如何导入数据文件进行 UFT API 测试?)
本文介绍了如何导入数据文件进行 UFT API 测试?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在做一个项目,需要在运行时动态导入测试数据并运行与测试数据对应的API测试.

I am working on a project which requires to dynamically import the test data on run time and run the API test corresponding to the test data.

我尝试使用直接从 xml 请求加载的 XMLload.这似乎工作正常.

I tried using XMLload which I directly load from the xml request. This seems to be working fine.

但与导入测试数据的 GUI 测试一样,我希望对 API 测试进行相同的测试 - 我可以从外部源动态导入 excel 并将值提供给请求.

But like GUI testing, where we import the test data, I want the same for API testing - where I can import a excel from an external source dynamically and give the values to the request.

我该怎么做?

推荐答案

据我了解您的问题,您想从 Excel 文件加载测试数据.这就是我在之前的项目中所做的,但略有不同,所以我希望这对你有用.

As far as I understand your question, you want to load test data from Excel file. And that is what I have done in my previous project but little differently, so I hope this will be some what useful to you.

这些步骤将帮助您从 Excel 文件驱动测试,您将在其中提供请求 XML 文件和其他测试数据的位置,例如:

These steps will help you drive your test from Excel file where you will provide the location of request XML files and other test data, for example:

  • 执行标志
  • WSDL
  • 终点地址
  • 环境
  • 等等……

===========================================================================
从 Excel 文件导入数据的步骤:

=========================================================================
Steps to import data from Excel file:

打开 数据 窗格(查看 -> 数据)
点击新数据源

Open Data pane (View -> Data)
Click on New Data Source

选择 Database(别担心我们会使用 Excel 作为数据库)
Set Database Connection
将出现新窗口点击建立连接字符串图标

Select Database (Don't worry we'll be using Excel as Database)
New window will appear to Set Database Connection
Click on Build Connection String icon


如果未选中,请单击 Provider 标签
选择 Microsoft Office 12.0 Access Database Engine OLE DB Provider
点击下一步
Data Source 部分,提供 Excel (.XLSX) 文件的路径,并将所有内容保留为默认值此(连接)选项卡
点击高级标签
访问权限部分
中选择Read Write转到全部标签
选择Extended Properties并点击Edit Value
Property Value 字段中输入 Excel 12.0 Xml 并点击 OK
现在返回 Connection 选项卡并点击 Test Connection 按钮
它应该显示 Test connection succeeded 消息,如果不是,请返回并再次执行所有步骤
点击确定
点击下一步
Data Source name 字段中提供工作表名称(您要导入的)
例如:[TEST_DATA$],其中 TEST_DATA 是工作表名称
Check SQL Statement 按钮上方的大框中输入您的 SQL 查询
例如:
我想从 TEST_DATA 表中导入 Execution_Flag 列具有 Y 值的所有行.我使用的 SQL 语句:


Click on Provider tab if not selected
Select Microsoft Office 12.0 Access Database Engine OLE DB Provider
Click Next
In Data Source section, provide the path to your Excel (.XLSX) file and leave everything to default on this (Connection) tab
Click on Advanced tab
Select Read Write from Access permissions section
Go to All tab
Select Extended Properties and click on Edit Value
Type Excel 12.0 Xml in Property Value field and hit OK
Now go back to Connection tab and click on Test Connection button
It should show Test connection succeeded message, if NOT than go back and follow all the steps again
Click on OK
Click Next
Provide the sheet name (that you want to import) in Data Source name field
For example: [TEST_DATA$] where TEST_DATA is a sheet name
Type in your SQL query in big box just above Check SQL Statement button
For example:
I want to import all the rows from TEST_DATA sheet where Execution_Flag column is having Y value. And SQL statement for that I've used:

SELECT * FROM [TEST_DATA$] WHERE Execution_Flag = 'Y'  

点击Check SQL Statement按钮,它应该会在新的Query Preview窗口中显示结果行
关闭 Query Preview 窗口并点击 Set SQL Statement 窗口上的 Finish
现在您应该在数据窗格中看到结果行
* 我喜欢这种方法的地方是,如果您在 Excel 文件中进行更改并刷新数据窗格,它会自动更新 Data 窗格中的数据

Click on Check SQL Statement button and it should to show the resulted rows in new Query Preview window
Close Query Preview window and click on Finish on Set SQL Statement window
Now you should see resulted rows in Data pane
* What I like about this approach is if you'll make changes in Excel file and refresh the Data pane, it will automatically update the data in Data pane

===========================================================================
现在从 Excel 文件中读取数据:
假设我想从 Excel 文件(我们已导入)中指定的位置读取我的请求 XML 文件
我正在使用 Read From File 活动

注意:这只是一个给出想法的例子

=========================================================================
Now to read the data from Excel file:
Let's say I want to read my request XML file from location specified in Excel file (which we have imported)
I am using Read From File activity

Note: This is just an example to give an idea

从文件读取活动拖放到您的工作区
这将抱怨没有为在 Errors 窗格中读取的文件指定路径
双击此消息,它将在 Properties 窗格中为您突出显示该字段
将鼠标悬停在文件路径旁边的值字段上,然后单击最后一个图标 Link to data source,这将打开 Select Link Source for 'File path' 窗口
点击 Data source column 单选按钮,然后点击 TEST_DATA from Select a data来源部分
Select data部分选择对应的列名,然后点击OK,如图所示

Drag and drop Read From File activity in your work area
This will complain that path is not specified for the file from which to read in Errors pane
Double click this message and it will highlight the field for you in Properties pane
Hover your mouse on Value field next to File path and click on last icon Link to data source and this will open Select Link Source for 'File path' window
Click on Data source column radio button and then click on TEST_DATA from Select a data source section
Select the corresponding column name from Select data section and click OK, like shown in image

===========================================================================
同样,您可以通过数据窗格将值/s 从 Excel 文件传递​​给自定义代码,方法是链接数据源并将其作为输入传递,在自定义代码中,您可以通过这种方式检索值:

=========================================================================
Similarly you can pass value/s to Custom Code from Excel file through Data pane by linking data source and passing it as input and in custom code you can retrieve the value this way:

string environmentName = CodeActivity18.Input.Environment_Name;  

同样的方式,您可以将自定义代码的输出写入 Excel 文件:

And same way you can write to Excel file as an output from custom code:

string finalResponseXMLPath = "some path";
CodeActivity18.Output.ResponseXML_FinalPath = finalResponseXMLPath;

这篇关于如何导入数据文件进行 UFT API 测试?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)