Автоматизация тестов с помощью Selenium WD + Python

automation
python
webdriver
Теги: #<Tag:0x00007fedbafd1bc8> #<Tag:0x00007fedbafd1a88> #<Tag:0x00007fedbafd1920>

(Mikhail Barinov) #1

Всем добрый день! Вопрос в том, что не могу заставить Селениум обратиться к всплывающему окну. В консоли пусто, тем самым не могу получить xPath или ID объекта.

У меня получается только открыть браузер. Далее всё останавливается из за всплывающего окна.

Кусок кода:

import unittest
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
from selenium.webdriver.support.ui import Select

class Select_service(unittest.TestCase):

def setUp(self):
	self.driver = webdriver.Chrome(executable_path="C:\Python36\chromedriver.exe")
	driver = self.driver
	driver.get("http://(здесь название сайта, не могу опубликовать, так как ИБ)/Process/ServiceSelect")
	driver.send_Keys("логин", Keys.TAB)
	driver.send_Keys("пароль", Keys.RETURN)
	driver.find_element_by_xpath("//span[@class='next_arrow-text']").click

def test_selecting_service(self):
	driver = self.driver
	service_select = driver.find_element_by_xpath("//a[@href='название сайта/Process/ServiceSelect']").click
	
	looking_for = driver.find_element_by_xpath("//input[@id='srch']").click
	looking_for.send_keys("название объекта на сайте")
	looking_for.send_keys(Keys.TAB)
	looking_for.send_keys(Keys.RETURN)

Логи и ошибка (после ввода логина и пароля вручную (если логин и пароль не вводить руками, то тест останавливается на странице с тем всплывающим окном)):

DevTools listening on ws://127.0.0.1:12080/devtools/browser/647aae81-dd7f-4c76-a019-be50207f7ef0
E

ERROR: test_selecting_service (main.Select_service)

Traceback (most recent call last):
File “c:\python36\tes5.py”, line 16, in setUp
driver.send_Keys(“логин”, Keys.TAB)
AttributeError: ‘WebDriver’ object has no attribute ‘send_Keys’


Ran 1 test in 13.935s

FAILED (errors=1)

Операционная система Windows 10, Python 3.6, Selenium WD 2.


(Mikhail Barinov) #2

Скриншот окна


(Maxim Andryushchenkov) #3

Это нативное окно Basic authentication и к нему у вас через Selenium и не будет доступа. Решается эта задача заранее установленным расширением с автоматическим вводом логина/пароля на профиль браузера и явным указанием расширения при инициализации веб драйвера:

ch_opts = webdriver.ChromeOptions()
ch_opts.add_argument(f"--load-extension={ui_config['pages_config']['chrome_extension']}")
driver = webdriver.Chrome(executable_path=driver_path,
                          service_log_path=log_path,
                          chrome_options=ch_opts)

(Mikhail Barinov) #4

Спасибо большое за помощь! Можно только ещё один вопрос - как мне можно найти log_path у установленного расширения? Или тут берётся лог от стандартного запоминания паролей браузером?

П.С. Не судите строго, я только в начале пути) Читаю много литературы и прохожу онлайн курсы. Самоучка.


(Maxim Andryushchenkov) #5

Это лог драйвера, укажите любой путь к файлу для этого. Туда пишется каждая операция драйвера будь то поиск элемента или заполнение полей.


(Serge D.) #6

а если попробовать так:
driver.get(“http://Логин:Пароль@ВашСекретныйСайт.com”);

Сработает?


(Mikhail Barinov) #7

Ребята спасибо Вам за помощь. Удалось реализовать свою задачу иным способом. Вот пример кода, который мне помог.

from selenium import webdriver
from selenium.webdriver.chrome.options import Options
import zipfile

manifest_json = “”"
{
“version”: “1.0.0”,
“manifest_version”: 2,
“name”: “Chrome Proxy”,
“permissions”: [
“proxy”,
“tabs”,
“unlimitedStorage”,
“storage”,
“<all_urls>”,
“webRequest”,
“webRequestBlocking”
],
“background”: {
“scripts”: [“background.js”]
},
“minimum_chrome_version”:“22.0.0”
}
“”"

background_js = “”"
var config = {
mode: “fixed_servers”,
rules: {
singleProxy: {
scheme: “http”,
host: “здесь мой прокси”,
port: parseInt(порт прокси)
},
bypassList: [“foobar.com”]
}
};

chrome.proxy.settings.set({value: config, scope: “regular”}, function() {});

function callbackFn(details) {
return {
authCredentials: {
username: “логин”,
password: “пароль”
}
};
}

chrome.webRequest.onAuthRequired.addListener(
callbackFn,
{urls: ["<all_urls>"]},
[‘blocking’]
);
“”"

pluginfile = ‘proxy_auth_plugin.zip’

with zipfile.ZipFile(pluginfile, ‘w’) as zp:
zp.writestr(“manifest.json”, manifest_json)
zp.writestr(“background.js”, background_js)

co = Options()
co.add_argument("–start-maximized")
co.add_extension(pluginfile)

driver = webdriver.Chrome(executable_path = r"C:\Python36\chromedriver.exe", chrome_options=co)
driver.get(“http://мой секретный сайт”)

Действительно помогло. Но в любом случае, когда у меня будет больше опыта, обязательно разберусь в примерах Вашего кода (мне не удалось с их помощью решить свой вопрос :frowning: ), и с вышеуказанным.