Exemplo n.º 1
0
    def __init__(
        self,
        edge_options: Options = None,
        desired_capabilities: dict = None,
        token: str = None,
        project_name: str = None,
        job_name: str = None,
        disable_reports: bool = False,
    ):
        # If no options or capabilities are specified at all, use default Options
        if edge_options is None and desired_capabilities is None:
            caps = Options().to_capabilities()
        else:
            # Specified EdgeOptions take precedence over desired capabilities but either can be used
            caps = (
                edge_options.to_capabilities()
                if edge_options is not None
                else desired_capabilities
            )

        super().__init__(
            capabilities=caps,
            token=token,
            project_name=project_name,
            job_name=job_name,
            disable_reports=disable_reports,
        )
Exemplo n.º 2
0
 def _build_capabilities(self, caps, browser_name):
     options = None
     if caps:
         _, value = caps.popitem()
         try:
             browser = value["browserName"]
         except Exception as e:
             logger.console("No browser name capability was set")
             raise e
         if browser in self.FIREFOX_NAMES:
             options = FirefoxOptions()
         elif browser in self.CHROME_NAMES:
             options = ChromeOptions()
         elif browser in self.IE_NAMES:
             options = IeOptions()
         elif browser == "edge":
             options = Options()
         elif browser == "safari":
             options = DesiredCapabilities.SAFARI.copy()
         for k, v in value.items():
             options.set_capability(k, v)
     else:
         if browser_name in self.FIREFOX_NAMES:
             caps = DesiredCapabilities.FIREFOX.copy()
             options = FirefoxOptions()
         elif browser_name in self.CHROME_NAMES:
             caps = DesiredCapabilities.CHROME.copy()
             options = ChromeOptions()
         elif browser_name in self.IE_NAMES:
             caps = DesiredCapabilities.INTERNETEXPLORER.copy()
             options = IeOptions()
         elif browser_name == "edge":
             caps = DesiredCapabilities.EDGE.copy()
             options = Options()
         elif browser_name == "safari":
             options = DesiredCapabilities.SAFARI.copy()
         for k, v in caps.items():
             options.set_capability(k, v)
     return options
Exemplo n.º 3
0
 def __init__(
     self,
     edge_options: Options = Options(),
     token: str = None,
     projectname: str = None,
     jobname: str = None,
     disable_reports: bool = False,
 ):
     super().__init__(
         capabilities=edge_options.to_capabilities(),
         token=token,
         projectname=projectname,
         jobname=jobname,
         disable_reports=disable_reports,
     )
Exemplo n.º 4
0
def build_options(browser, browser_options: List[str],
                  experimental_options: Optional[List[dict]],
                  extension_paths: Optional[List[str]]):
    """ Build the Options object for Chrome or Firefox.

    Args:
        browser: The name of the browser.
        browser_options: The list of options/arguments to include.
        experimental_options: The list of experimental options to include.
        extension_paths: The list of extensions to add to the browser session.

    Examples:
        WebDriverFactory().build_options('chrome', ['headless', 'incognito'], [{'useAutomationExtension', False}])
    """
    browser = browser.lower()
    if browser == Browser.CHROME:
        options = webdriver.ChromeOptions()
    elif browser == Browser.FIREFOX:
        options = webdriver.FirefoxOptions()
    elif browser == Browser.IE:
        options = webdriver.IeOptions()
    elif browser == Browser.OPERA:
        options = webdriver.ChromeOptions()
    elif browser == Browser.EDGE:
        options = Options()
    else:
        raise ValueError(
            f'{browser} is not supported. https://elsnoman.gitbook.io/pylenium/configuration/driver'
        )

    for option in browser_options:
        if option.startswith('--'):
            options.add_argument(option)
        else:
            options.add_argument(f'--{option}')

    if experimental_options:
        for exp_option in experimental_options:
            (name, value), = exp_option.items()
            options.add_experimental_option(name, value)

    if extension_paths:
        for path in extension_paths:
            options.add_extension(path)

    return options
Exemplo n.º 5
0
def test_use_webview():
    options = Options()
    options.use_webview = True
    caps = options.to_capabilities()
    assert caps['browserName'] == "webview2"
Exemplo n.º 6
0
def options():
    return Options()
Exemplo n.º 7
0
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.edge.options import Options
from urllib3.packages.six import b

opts = Options()

# opts.add_argument(
#     "user-agent=Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Ubuntu Chromium/71.0.3578.80 Chrome/71.0.3578.80 Safari/537.36"
# )

# driver=webdriver.Edge('Selenium_pract/msedgedriver.exe',edge_options=opts)
driver = webdriver.Edge('Selenium_pract/msedgedriver.exe')

driver.get(
    'https://listado.mercadolibre.com.ec/repuestos-autos-camionetas-bujias')

# Debemos darle click al boton de disclaimer para que no interrumpa nuestras acciones
try:  # Encerramos todo en un try catch para que si no aparece el discilamer, no se caiga el codigo
    disclaimer = driver.find_element(By.XPATH,
                                     '//button[@id="cookieDisclaimerButton"]')
    disclaimer.click()  # lo obtenemos y le damos click
except Exception as e:
    print(e)
    None

while True:
    links_productos = driver.find_elements(
        By.XPATH,
Exemplo n.º 8
0
 def create_options(self) -> Options:
     return Options()
Exemplo n.º 9
0
def test_custom_browser_name():
    options = Options(is_legacy=False)
    options.custom_browser_name = "testbrowsername"
    caps = options.to_capabilities()
    assert caps['browserName'] == "testbrowsername"
Exemplo n.º 10
0
def driver():
    driver = webdriver.Edge(edge_options=Options(), project_name="Examples", job_name=None)
    yield driver
    driver.quit()
Exemplo n.º 11
0
def test_use_chromium():
    options = Options()
    options.use_chromium = True
    caps = options.to_capabilities()
    assert caps['ms:edgeChromium'] is True
Exemplo n.º 12
0
def open_browser(executable_path="msedgedriver",
                 edge_args=None,
                 desired_capabilities=None,
                 **kwargs):
    """Open Edge browser instance and cache the driver.

    Parameters
    ----------
    executable_path : str (Default "msedgedriver")
        path to the executable. If the default is used it assumes the
        executable is in the $PATH.
    port : int (Default 0)
        port you would like the service to run, if left as 0, a free port will
        be found.
    desired_capabilities : dict (Default None)
        Dictionary object with non-browser specific capabilities only, such as
        "proxy" or "loggingPref".
    chrome_args : Optional arguments to modify browser settings
    """
    options = Options()
    options.use_chromium = True

    # Gets rid of Devtools listening .... printing
    # other non-sensical error messages
    options.add_experimental_option('excludeSwitches', ['enable-logging'])

    if platform.system().lower() == "windows":
        options.set_capability("platform", "WINDOWS")

    if platform.system().lower() == "linux":
        options.set_capability("platform", "LINUX")

    if platform.system().lower() == "darwin":
        options.set_capability("platform", "MAC")

    # If user wants to re-use existing browser session then
    # he/she has to set variable BROWSER_REUSE_ENABLED to True.
    # If enabled, then web driver connection details are written
    # to an argument file. This file enables re-use of the current
    # chrome session.
    #
    # When variables BROWSER_SESSION_ID and BROWSER_EXECUTOR_URL are
    # set from argument file, then OpenBrowser will use those
    # parameters instead of opening new chrome session.
    # New Remote Web Driver is created in headless mode.
    edge_path = kwargs.get(
        'edge_path', None) or BuiltIn().get_variable_value('${EDGE_PATH}')
    if edge_path:
        options.binary_location = edge_path

    if user.is_root() or user.is_docker():
        options.add_argument("no-sandbox")
    if edge_args:
        if any('--headless' in _.lower() for _ in edge_args):
            CONFIG.set_value('Headless', True)
        for item in edge_args:
            options.add_argument(item.lstrip())
    options.add_argument("start-maximized")
    options.add_argument("--disable-notifications")
    if 'headless' in kwargs:
        CONFIG.set_value('Headless', True)
        options.add_argument("--headless")
    if 'prefs' in kwargs:
        if isinstance(kwargs.get('prefs'), dict):
            prefs = kwargs.get('prefs')
        else:
            prefs = util.prefs_to_dict(kwargs.get('prefs').strip())
        options.add_experimental_option('prefs', prefs)
        logger.warn("prefs: {}".format(prefs))
    driver = Edge(BuiltIn().get_variable_value('${EDGEDRIVER_PATH}')
                  or executable_path,
                  options=options,
                  capabilities=desired_capabilities)
    browser.cache_browser(driver)
    return driver
Exemplo n.º 13
0
def edge_options():
    return Options()
Exemplo n.º 14
0
import time
from selenium import webdriver
from selenium.webdriver.common import service
from selenium.webdriver.edge.service import Service
from selenium.webdriver.edge.options import Options
from bs4 import BeautifulSoup
import xlsxwriter

edge_options = Options()
edge_service = Service("C:\Program Files (x86)\Microsoft\Edge\Application\msedgedriver.exe")
edge_options.add_argument("headless")
driver = webdriver.Edge(service=edge_service)
driver.get("https://store.steampowered.com/search/?sort_by=_ASC&ignore_preferences=1&filter=topsellers")
time.sleep(2)
scroll_pause_time = 1
screen_height = driver.execute_script("return window.screen.height;")
i = 1

workbook = xlsxwriter.Workbook('SteamGames.xlsx')
worksheet = workbook.add_worksheet()
bold = workbook.add_format({'bold':True})

worksheet.write('A1', 'Name', bold)
worksheet.write('B1', 'Price', bold)
worksheet.write('C1', 'Release Date', bold)
worksheet.write('D1', 'Publisher', bold)
worksheet.write('E1', 'Developer', bold)
worksheet.write('F1', '% Positive Reviews (30 days)', bold)
worksheet.write('G1', 'Total Number Reviews (30 days)', bold)
worksheet.write('H1', '% Positive Reviews (All Time)', bold)
worksheet.write('I1', 'Total Number Reviews (All Time)', bold)
Exemplo n.º 15
0
URL = "http://orteil.dashnet.org/experiments/cookie/"

STORE_ITEMS = [
    "buyCursor",
    "buyGrandma",
    "buyFactory",
    "buyMine",
    "buyShipment",
    "buyAlchemy lab",
    "buyPortal",
    "buyTime machine",
]
store = []

options = Options()
options.add_argument("window-size=1920,1080")

driver = webdriver.Edge(options=options)
driver.get(URL)

cps = driver.find_element(By.ID, "cps")
money = driver.find_element(By.ID, "money")
cookie = driver.find_element(By.ID, "cookie")

begin = before = now = time.time()

while now - begin < 120:

    while now - before < 5: