Como clicar no botão habilitado para ember.js usando Selenium e Python

Nov 21 2020

Tenho tentado tornar isso clicável e simplesmente não consigo entender o que estou fazendo de errado. Também estou tentando induzir webdriverwait, para que seja clicado quando aparecer.

Este é o meu código até agora:

def order(k):
    driver = webdriver.Chrome(os.getcwd()+"\\webdriver\\chromedriver.exe") 
    driver.get("website.com/login-to-checkout")
    driver.find_element_by_id('i0116').send_keys(k["email"])
    driver.find_element_by_id('i0118').send_keys(k["password"])
    driver.find_element_by_id('idSIButton9').click()
    delay()
    #sign in button
    driver.find_element_by_id('idSIButton9').click()
    #Button below I cant get to be clicked
    with webdriver.Chrome() as driver:
        wait = WebDriverWait(driver, 7)
        wait.until(presence_of_element_located((By.CSS_SELECTOR, "#ember1053")))
        driver.find_element(By.id, "ember1053").click()

este é o código-fonte do botão que estou tentando tornar clicável:

<div id="ember1037" class="btn-group m-b-lg m-t-lg order-call-to-action ember-view"><!---->        <!--biBehavior 80 means place order Place Order-->

<button aria-live="polite" type="button" tabindex="0" data-m="{&quot;aN&quot;:&quot;shoppingCart&quot;,&quot;cN&quot;:&quot;PlaceOrder&quot;,&quot;bhvr&quot;:80}" id="ember1053" class="btn theme-default btn-primary cli-purchase ember-view"><!---->            Place order

</button></div>

Respostas

DebanjanB Nov 22 2020 at 20:59

O elemento desejado é um elemento Ember.js e o valor do idatributo do <button>continuará mudando dinamicamente, toda vez que você acessar o AUT (Aplicativo em Teste) . Portanto, click()no elemento, você deve induzir WebDriverWait para o element_to_be_clickable()e pode usar qualquer uma das seguintes estratégias de localizador :

  • Usando CSS_SELECTOR:

    WebDriverWait(driver, 20).until(EC.element_to_be_clickable((By.CSS_SELECTOR, "button.btn.theme-default.btn-primary.cli-purchase.ember-view[id^='ember'][type='button'][aria-live='polite']"))).click()
    
  • Usando XPATH:

    WebDriverWait(driver, 20).until(EC.element_to_be_clickable((By.XPATH, "//button[@class='btn theme-default btn-primary cli-purchase ember-view' and starts-with(@id,'ember')][contains(., 'Place order') and @aria-live='polite']"))).click()
    
  • Nota : Você deve adicionar as seguintes importações:

    from selenium.webdriver.support.ui import WebDriverWait
    from selenium.webdriver.common.by import By
    from selenium.webdriver.support import expected_conditions as EC
    

Referências

Você pode encontrar algumas discussões detalhadas relevantes em:

  • Selênio - Encontrando elemento com base em brasa
  • Ember dropdown selenium xpath
ImCrimson Nov 22 2020 at 05:17

Isso pode ajudar, mas eu tive problemas com o webdriver não clicar em um botão quando uso o id para encontrá-lo. A solução que encontrei está usando o xpath em vez do id. Assim, vale a pena tentar.

driver.find_element_by_xpath("""//*[@id="submit-button"]""").click()