我想编写数据驱动的测试,传递从外部文件(csv)读取的动态值。 能够从 csv 传递动态值作为简单字符串(下面的帐号和会员 ID)。但是,使用嵌入式表达式,如何从 csv 文件传递下面的“DealerReportFormats”json 数组的动态值?
非常感谢任何帮助!
Scenario Outline: Dealer dynamic requests
Given path '/dealer-reports/retrieval'
And request read('../DealerTemplate.json')
When method POST
Then status 200
Examples:
| read('../DealerData.csv') |
DealerTemplate.json is below
{
"DealerId": "FIXED",
"DealerName": "FIXED",
"DealerType": "FIXED",
"DealerCredentials": {
"accountNumber": "#(DealerCredentials_AccountNumber)",
"affiliateId": "#(DealerCredentials_AffiliateId)"
},
"DealerReportFormats": [
{
"name": "SalesReport",
"format": "xml"
},
{
"name": "CustomerReport",
"format": "txt"
}
]
}
DealerData.csv:
DealerCredentials_AccountNumber,DealerCredentials_AffiliateId
testaccount1,123
testaccount2,12345
testaccount3,123456
CSV 仅适用于“平面”结构,因此在我看来,尝试将其与 JSON 混合过于雄心勃勃。如果需要,请寻找另一个框架:)
也就是说我看到了 2 个选项:
a) 在 CSV 中使用正确的引用和转义
b) 参考 JSON 文件
这是一个例子:
Scenario Outline:
* json foo = foo
* print foo
Examples:
| read('test.csv') |
并且
test.csv
是:
foo,bar
"{ a: 'a1', b: 'b1' }",test1
"{ a: 'a2', b: 'b2' }",test2
如果您想转义双引号,我将其作为练习留给您。这是可能的。
选项 (b) 是您可以引用独立的 JSON 文件并读取它们:
foo,bar
j1.json,test1
j2.json,test2
您可以在您的功能中执行
* def foo = read(foo)
。
您可以使用
嵌入式表达式将变量从
Scenario Outline
传递到JSON“模板”中。参考:https://stackoverflow.com/a/47674975/143475