无法使用selenium webdriver在Safari(mac)上单击隐藏的AirPlay按钮元素

时间:2017-10-17 12:19:30

标签: python selenium selenium-webdriver safari

作为使用Python和Selenium进行测试的一部分,我打算使用selenium打开youtube链接,并希望点击“AirPlay”按钮,以便将其发送到Apple TV。 最初我遇到了隐藏元素的问题,但是使用了ActionChains。该脚本执行但我没有看到在播放的视频上执行点击,我可以看到AppleTv名称显示。

以下是代码:

from selenium import webdriver
from selenium.common.exceptions import NoSuchElementException
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.common.desired_capabilities import DesiredCapabilities
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.common.by import By
from selenium.webdriver import ActionChains
from selenium.webdriver.support.wait import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
import os , sys

server_url = "http://10.0.10.4:4444/wd/hub"
capabilities = DesiredCapabilities.SAFARI
driver = webdriver.Remote(desired_capabilities=capabilities, 
command_executor=server_url)
driver.get("https://www.youtube.com/watch?v=_YhrCp9m14k")

#air_play = WebDriverWait(driver, 20).until(EC.presence_of_element_located((By.XPATH, '//*[@id="move_player"]/div[28]/div[2]/div[2]/button[6]')))
air_play = WebDriverWait(driver, 20).until(EC.presence_of_element_located((By.CLASS_NAME, 'ytp-airplay-button')))
#air_play = WebDriverWait(driver, 20).until(EC.presence_of_element_located((By.XPATH, '//*[@id="text"]')))

#air_play = driver.find_element_by_css_selector('button.ytp-ariplay-button')
hover = ActionChains(driver).move_to_element(air_play)
hover.perform()

hover1 = ActionChains(driver).click_and_hold(air_play).perform()

html元素如下:

<button class="ytp-airplay-button ytp-button" title="AirPlay" style=""><svg 
height="100%" version="1.1" viewBox="0 0 36 36" width="100%"><use 
class="ytp-svg-shadow" NS1:href="#ytp-id-27"></use><path class="ytp-svg-
fill" d="M12,28 L24,28 L18,22 L12,28 Z M27,9 L9,9 C7.9,9 7,9.9 7,11 L7,23 
C7,24.1 7.9,25 9,25 L13,25 L13,23 L9,23 L9,11 L27,11 L27,23 L23,23 L23,25 
L27,25 C28.1,25 29,24.1 29,23 L29,11 C29,9.9 28.1,9 27,9 L27,9 Z" id="ytp-
id-27"></path></svg></ button>

XPATH如下:

//*[@id="movie_player"]/div[28]/div[2]/div[2]/button[6]

CSS选择器如下:

#movie_player > div.ytp-chrome-bottom > div.ytp-chrome-controls > div.ytp-
right- controls > button.ytp-airplay-button.ytp-button

有人可以帮助解释为什么按钮没有被点击并显示可用的Airplay选项吗?

将鼠标悬停在视频上之前。

Before hovering over the video

将鼠标悬停在视频上并单击AirPlay按钮。

After hovering over the video and clicking on the AirPlay button

1 个答案:

答案 0 :(得分:1)

我没有在Mac上安装Safari,所以我不能自己重复这个问题,但我猜测问题(来自你的截图)是在视频区域悬停之前图标不可见。按照设计,Selenium不会与用户看不到的元素进行交互。有几种方法可以做到这一点。

  1. 用户方式...将视频悬停,将鼠标悬停在图标上,然后点击图标。如果您尝试模拟用户,则这是您要使用的方法。

    from selenium import webdriver
    from selenium.webdriver.common.action_chains import ActionChains
    from selenium.webdriver.support import expected_conditions as EC
    
    video = driver.find_element_by_css_selector("video")
    ActionChains(driver).move_to_element(video).perform()
    WebDriverWait(driver, 10).until(EC.element_to_be_clickable((By.CSS_SELECTOR, "button[title='AirPlay']")).click()
    
  2. 非用户方式...用JSE点击它。使用JSE,我们可以单击任何元素,可见或不可见。没有用户可以单击不可见的元素,因此如果您尝试模拟用户,请不要使用此...使用#1。

    airplayButton = driver.find_element_by_css_selector("button[title='AirPlay']")
    driver.execute_script("arguments[0].click();", airplayButton);