Python webdriver: driver.get(URL) 在unittest中无法打开 - 通过控制台正常工作

1 投票
1 回答
3304 浏览
提问于 2025-04-17 05:49

就像标题说的,我在svn仓库里安装了一个Selenium的副本。

当我在控制台里导入并运行代码时,一切都正常。但是,当我尝试运行一个单元测试,甚至是直接从Selenium IDE导出的测试时,

它会打开浏览器,但却卡住了,连网址都不尝试打开。

附加信息

  • 操作系统:Ubuntu 11.04
  • Python版本:2.7
  • 浏览器:Firefox 7.0.1
    • 我尝试过用HTTPUNIT,但总是出现非法字符的错误。

代码

import unittest
#import time
import re

from selenium import webdriver
#from selenium.webdriver.common.by import By
from selenium.common.exceptions import NoSuchElementException

#from local_config import BASE_URL, BASE_FOLDER, DRIVER
BASE_URL = 'http://localhost'
BASE_FOLDER = '/dir/to/site/'
DRIVER = 'FIREFOX'


class CheckSitemap(unittest.TestCase):

    def setUp(self):
        global BASE_URL
        global DRIVER
        if DRIVER == 'FIREFOX':
            self.driver = webdriver.Firefox()
        elif DRIVER == 'HTTPUNIT':
            self.driver = webdriver.Remote(desired_capabilities=webdriver.DesiredCapabilities.HTMLUNIT)
        else:
            raise Exception('DRIVER not set')
        self.driver.implicitly_wait(30)
        self.base_url = BASE_URL
#        print self.base_url
        self.verificationErrors = []

    def getSitemap(self):
        global BASE_FOLDER
        global DRIVER
#        print BASE_FOLDER
        driver = self.driver
        op1 = '%ssitemap.xml' % BASE_FOLDER
        if DRIVER == 'HTTPUNIT':
            op1 = '%s%s' % (self.base_url, op1[1:len(op1)])
#        print op1
        driver.get(op1.replace('//', '/'))
#        print 'HELLO WORLD!!'
        urls = []
#        print driver.page_source
        r = re.compile(r'<a href="(.*?)"')
        for match in r.finditer(driver.page_source):
            urls.append(match.group(1))
        if len(urls) == 0:
            r = re.compile(r'<loc>(.*?)</loc>', re.DOTALL)
            for match in r.finditer(driver.page_source):
                urls.append(match.group(1).strip())
        return urls

    def test_check_sitemap(self):
        global DRIVER
        driver = self.driver
        urls = self.getSitemap()
#        print urls
        for url in urls:
            if DRIVER == 'HTTPUNIT':
                driver.get(url)
            else:
                driver.get(url.replace(self.base_url, ''))

            if re.search(r"\.php on line [0-9]+", driver.page_source):
                self.verificationErrors.append('php error on %s' % url)

    def is_element_present(self, how, what):
        try:
            self.driver.find_element(by=how, value=what)
        except NoSuchElementException:
            return False
        return True

    def tearDown(self):
        self.driver.quit()
#        print self.verificationErrors
        self.assertEqual([], self.verificationErrors)

if __name__ == "__main__":
    unittest.main()

有什么想法吗?

1 个回答

2

我在IRC上和AutomatedTester聊天时找到了我的解决办法。

现在,Python的webdriver实现忽略了self.base_url这个值。

所以当你用.get()方法访问一个网址时,需要使用完整的网址。

已经提交了一个错误报告,可能很快会有更新。

Webdriver版本是2.11.1。

撰写回答