2017-02-21 8 views
0
C:\apache-tomcat-8.0.27>python 
Python 2.7.13 (v2.7.13:a06454b1afa1, Dec 17 2016, 20:42:59) [MSC v.1500 32 bit  (
Intel)] on win32 
Type "help", "copyright", "credits" or "license" for more information. 
>>> from selenium import webdriver 
>>> webdriver.__version__ 
'3.0.2' 
>>> 

селен тестирование кода питон как следующее:Почему код selenium успешно выполняется только в режиме отладки, но не работает в режиме запуска?

driver.get("http://localhost:8080/") 
self.assertEqual("Cubiender", driver.title) 
driver.find_element_by_id("login_email").clear() 
driver.find_element_by_id("login_email").send_keys("[email protected]") 
driver.find_element_by_id("login_pwd").clear() 
driver.find_element_by_id("login_pwd").send_keys("pass") 
driver.find_element_by_css_selector("input[type=\"submit\"]").click() 

driver.find_element_by_link_text('Project List') 
sleep(0.05) 
driver.find_element_by_xpath("//input[@value='2588']").click() 

sleep(0.05) 
driver.find_element_by_css_selector("div.menu > #inquireProject").click() 

выше кода может успешно работать в режиме отладки, но будет провалена при работе на driver.find_element_by_xpath ("// ввода [@value . = '2588'] ") нажмите кнопку()

даже я добавил сон

StackTrace:

C:\Python27\python.exe "C:\Program Files (x86)\JetBrains\PyCharm Community Edition 2016.3.2\helpers\pycharm\utrunner.py" F:\python\sub_proj2.py true 

Тестирование началось в 10:53 ...

Error 
Traceback (most recent call last): 
File "F:\python\sub_proj2.py", line 41, in test_untitled 
driver.find_element_by_css_selector("span.triangle").click() 
File "C:\Python27\lib\site-packages\selenium\webdriver\remote\webdriver.py", line 437, in find_element_by_css_selector 
return self.find_element(by=By.CSS_SELECTOR, value=css_selector) 
File "C:\Python27\lib\site-packages\selenium\webdriver\remote\webdriver.py", line 752, in find_element 
'value': value})['value'] 
File "C:\Python27\lib\site-packages\selenium\webdriver\remote\webdriver.py", line 236, in execute 
self.error_handler.check_response(response) 
File "C:\Python27\lib\site-packages\selenium\webdriver\remote\errorhandler.py", line 192, in check_response 
raise exception_class(message, screen, stacktrace) 

NoSuchElementException: Сообщение: Не удается найти элемент: span.triangle

процесс завершится с кодом выхода 0

+0

Звучит как вопрос синхронизации, почему есть сон, прежде чем нажать на элемент? и как заполняется этот вход? – Corporalis

+0

Какое исключение выбрано? трассировки стека? –

+0

Попробуйте увеличить ожидание внутри 'sleep()' или использовать 'clear wait' –

ответ

0

Это, вероятно, потому, что в debug mode, у него есть больше времени, чтобы найти элемент. Попытайтесь увеличить время сна или другое решение, чтобы убедиться, что элемент загружен.

2

Просьба поделиться с stacktrace.

Мне кажется,

  • Либо ваш value='2588 является динамичным и меняется с каждой загрузке экземпляра.
  • Может быть sleep останавливает весь процесс. Почему бы вам не использовать wait, пример, упомянутый ниже.

from selenium.webdriver.support import expected_conditions as EC

wait = WebDriverWait(driver, 10) 
element = wait.until(EC.element_to_be_clickable((By.ID,'someid'))) 
Смежные вопросы