获取 XHR 响应(网络流量)并在 Katalon Studio 中解析它

Get XHR response (network traffic) and parse it in Katalon Studio

如何在 Katalon Studio 中读取 XHR 响应并解析它?

我目前使用一种变通方法来测试我的应用程序的响应能力:我使用各种 waitForElement_*_()(*=可见、可点击、存在、不可见、不可点击、不存在)命令按顺序测量各种元素的加载时间。

我想更具体地测量网络请求的持续时间(可以在 DevTools - 网络流量中看到)。

可以做到吗?

我不确定是否可以使用 Katalon studio 完成。我正在回复您的 post,因为我使用网络流量信息来推导性能数字,并且我使用 browsermobproxy。

不用说,这个回复并没有回答你的问题,只是使用browsermobproxy的一种选择

How to access the values of Chrome's Dev tools Network tab's Request or summary using Selenium in python/java?

在 Katalon 7 和 Chrome DevTools Protocol Integration plugin, as was described here 中,您可以拦截网络请求。

以下示例展示了如何在维基百科中模拟搜索请求,以便结果始终为“Katalon Studio”。

import static com.kms.katalon.core.testobject.ObjectRepository.findTestObject
import com.github.kklisura.cdt.protocol.commands.Fetch as Fetch
import com.github.kklisura.cdt.protocol.commands.Page as Page
import com.github.kklisura.cdt.services.ChromeDevToolsService as ChromeDevToolsService
import com.katalon.cdp.CdpUtils as CdpUtils
import com.kms.katalon.core.util.internal.Base64 as Base64
import com.kms.katalon.core.webui.keyword.WebUiBuiltInKeywords as WebUI
import com.kms.katalon.core.testobject.ConditionType
import com.kms.katalon.core.testobject.TestObject as TestObject

WebUI.openBrowser('')
ChromeDevToolsService cdts = CdpUtils.getService()
Page page = cdts.getPage()
Fetch fetch = cdts.getFetch()
fetch.onRequestPaused({ def requestIntercepted ->
    String interceptionId = requestIntercepted.getRequestId()
    String url = requestIntercepted.getRequest().getUrl()
    boolean isMocked = url.contains('api.php')
    String response = '["Katalon Studio",["Katalon Studio"],["Katalon Studio is an automation testing solution developed by Katalon LLC."],["https://en.wikipedia.org/wiki/Katalon_Studio"]]'
    String rawResponse = Base64.encode(response)
    System.out.printf('%s - %s%s', isMocked ? 'MOCKED' : 'CONTINUE', url, System.lineSeparator())
    if (isMocked) {
        fetch.fulfillRequest(interceptionId, 200, new ArrayList(), rawResponse, null)
    } else {
        fetch.continueRequest(interceptionId)
    }
})

fetch.enable()
page.enable()
WebUI.navigateToUrl('https://en.wikipedia.org/wiki/Main_Page')
TestObject searchInput = new TestObject().addProperty('css', ConditionType.EQUALS, '#searchInput')
TestObject containing = new TestObject().addProperty('xpath', ConditionType.EQUALS, "//div[div[contains(.,'containing...')]]")
WebUI.setText(searchInput, 'Intercept request')
WebUI.waitForElementVisible(containing, 10)

备注:

Katalon 论坛上的原创 post:https://forum.katalon.com/t/intercepting-request-with-chrome-devtools-protocol/36081

本主题中使用的示例项目:https://github.com/katalon-studio-samples/katalon-studio-chrome-devtools-protocol-plugin-samples

该插件使用 https://github.com/kklisura/chrome-devtools-java-client 连接到 CDP。