在最短的时间内进行多次 API 调用并返回组合响应



我有 10 个运行状况检查 URL,它们只是获取服务 我像下面这样循环击中它们

for(int i=0;i<10;i++){
Response response = given().when().relaxedHttpsValidation().get(url[i]);
list.add(response);
}
return list;

现在的问题是它串联命中 API 并等待所有响应,我只想并行命中所有 API,但合并结果,我尝试使用线程,但无法了解如何在多线程的情况下组合响应

如果我没看错你的问题,我相信你想进行并行调用并组合结果,在这种情况下,我建议你使用 TestNG。我过去有类似的要求,这个链接帮助了我

下面是一个示例代码

public class Parallel {
@DataProvider(parallel = true)
public Object[] getURL() {
return new Object[] { "https://reqres.in/api/users/1", "https://reqres.in/api/users/2",
"https://reqres.in/api/users/3", "https://reqres.in/api/users/4", "https://reqres.in/api/users/5",
"https://reqres.in/api/users/6" };
}
ArrayList<String> original = new ArrayList<String>();
@Test(dataProvider = "getURL")
public void stack(String url) {
Response response = given().when().get(url);
JsonPath js = response.jsonPath();
String email = js.getString("data.email");
original.add(js.getString("data.email"));
}
@AfterTest
public void simple() {
System.out.println("List : " + original);
}
}

只需删除(parallel = true)即可查看其顺序工作方式。我已经使用 JSONPath 从响应中提取了电子邮件字段并添加到列表中

不要忘记更新 POM

感谢您的快速回复,我现在只想分享我是如何实现的

List responseList = new ArrayList();
ExecutorService exec = Executors.newFixedThreadPool(10);
for (int i = 0; i < 10; i++) {
exec.submit(new Runnable() {
public void run() {
String response = executeServiceCall(urlArray[i]);
responseList.add(response);
}
});
} exec.shutdown();
try {
exec.awaitTermination(Long.MAX_VALUE, TimeUnit.DAYS);
} catch (InterruptedException e) {
LOGGER.error(e.toString());
}
LOGGER.info("response list is " + responseList)

相关内容

  • 没有找到相关文章

最新更新