我是selenium python的新手。现在我试图运行已经从selenium Ide转换的python代码。当我运行代码时,我收到了这个错误。我使用eclipse来运行代码
ERROR: test_isnin2 (__main__.Isnin2)
======================================================================
ERROR: test_isnin2 (__main__.Isnin2)
----------------------------------------------------------------------
Traceback (most recent call last):
File "C:\EclipseWorkspaces\csse120\python\src\Isnin2.py", line 20, in test_isnin2
driver.get("/search?q=google&ie=utf-8&oe=utf-8&aq=t&rls=org.mozilla:en-US:official&client=firefox-a")
File "C:\Program Files\Python27\lib\site-packages\selenium-2.4.0-py2.7.egg\selenium\webdriver\remote\webdriver.py", line 154, in get
self.execute(Command.GET, {'url': url})
File "C:\Program Files\Python27\lib\site-packages\selenium-2.4.0-py2.7.egg\selenium\webdriver\remote\webdriver.py", line 144, in execute
self.error_handler.check_response(response)
File "C:\Program Files\Python27\lib\site-packages\selenium-2.4.0-py2.7.egg\selenium\webdriver\remote\errorhandler.py", line 111, in check_response
zeroeth = value['stackTrace'][0]
IndexError: list index out of range
----------------------------------------------------------------------
Ran 1 test in 35.406s
FAILED (errors=1)
我的编码如下:
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.common.exceptions import NoSuchElementException
import unittest, time, re
class Isnin2(unittest.TestCase):
def setUp(self):
self.driver = webdriver.Firefox()
self.driver.implicitly_wait(30)
self.base_url = "http://www.google.com.my/"
self.verificationErrors = []
def test_isnin2(self):
driver = self.driver
driver.get("/search?q=google&ie=utf-8&oe=utf-8&aq=t&rls=org.mozilla:en-US:official&client=firefox-a")
driver.find_element_by_css_selector("em").click()
driver.find_element_by_id("lst-ib").click()
driver.find_element_by_id("lst-ib").clear()
driver.find_element_by_id("lst-ib").send_keys("selenium python")
driver.find_element_by_link_text("Setting Up Selenium with Python").click()
driver.find_element_by_link_text("selenium.py").click()
def is_element_present(self, how, what):
try: self.driver.find_element(by=how, value=what)
except NoSuchElementException, e: return False
return True
def tearDown(self):
self.driver.quit()
self.assertEqual([], self.verificationErrors)
if __name__ == "__main__":
unittest.main()
我真的希望有人可以帮助我,因为我是硒蟒的新手。
答案 0 :(得分:1)
您似乎没有向base_url
提供driver
。也许你应该替换这一行:
driver.get("/search?q=google&ie=utf-8&oe=utf-8&aq=t&rls=org.mozilla:en-US:official&client=firefox-a")
有这样的事情:
driver.get(self.base_url + "/search?q=google&ie=utf-8&oe=utf-8&aq=t&rls=org.mozilla:en-US:official&client=firefox-a")
修改强>:
另外:你想用is_element_present
方法测试一下吗?使用Python unittest框架,方法名称必须以test
开头。因此,如果您希望将其作为测试重命名为test_is_element_present
。
此外:如果您计划对响应进行多次测试,则应将driver.get()
调用放在setUp
方法中,因为测试的顺序不一定必须与您拥有的相同写了测试。另一方面,setUp
保证在调用任何测试之前运行。
答案 1 :(得分:1)
如果可以的话,我会评论Constantinius的答案,但我没有代表。 。 。
我用这个问题作为调查IDE的借口 - 看起来上面的代码几乎是对Python Webdriver的直接导出,在我的测试用例中,它会导致相同的格式错误.get(其中base_url是未提供)。
Constantinius提到的其他问题是IDE能力有限的结果。 is_element_present方法看起来像是IDE中正在进行的工作的一部分,我猜它是实际检查的占位符。