了解网页中发生的网络通话数

时间:2018-03-01 11:10:18

标签: javascript selenium selenium-webdriver

所以基本上我正在尝试使用selenium设计一个通用方法,它等待所有后台网络调用完成(包括任何Ajax,Angular,API调用)。我知道有一种方法可以使用 JQuery.active 获取活动ajax的数量,但只有在应用程序基于JQuery框架构建时才有效。此外,我想要一些等待所有网络调用完成的东西,而不是单独使用Ajax特有的东西。

所以我在这里尝试获取当前在后台发生的网络呼叫数量并等待它为零。

然而,这是我处理它的想法,欢迎任何新的想法或建议。

1 个答案:

答案 0 :(得分:4)

以下是使用Chrome等待没有待处理的Ajax请求的示例:

from selenium import webdriver
from selenium.webdriver.remote.webdriver import WebDriver
from selenium.webdriver.support.ui import WebDriverWait
import json


def send_chrome(driver, cmd, params={}) :
  resource = "/session/%s/chromium/send_command_and_get_result" % driver.session_id
  url = driver.command_executor._url + resource
  body = json.dumps({'cmd': cmd, 'params': params})
  response = driver.command_executor._request('POST', url, body)
  if response.get('status'):
    raise Exception(response.get('value'))
  return response.get('value')

def extend_xhr_chrome(driver) :
  send_chrome(driver, "Page.addScriptToEvaluateOnNewDocument", {\
      "source":
        "(function(){"
        "  var send = XMLHttpRequest.prototype.send;"
        "  var release = function(){ --XMLHttpRequest.active };"
        "  var onloadend = function(){ setTimeout(release, 1) };"
        "  XMLHttpRequest.active = 0;"
        "  XMLHttpRequest.prototype.send = function() {"
        "    ++XMLHttpRequest.active;"
        "    this.addEventListener('loadend', onloadend, true);"
        "    send.apply(this, arguments);"
        "  };"
        "})();"
    })

def is_xhr_idle_chrome(driver) :
    return send_chrome(driver, 'Runtime.evaluate', {\
      'returnByValue': True,\
      'expression': "XMLHttpRequest.active == 0"
    })['result']['value']


# launch Chrome
driver = webdriver.Chrome()

# extend XMLHttpRequest
extend_xhr_chrome(driver)

driver.get("https://stackoverflow.com")

# wait for no pending request
WebDriverWait(driver, 20, 0.08) \
  .until(is_xhr_idle_chrome)