well, it should be really more robust as it doesn't rely on XPATH everywhere anymore

This commit is contained in:
piair 2023-04-06 23:04:57 +02:00
parent f862af8699
commit 31426a1dfd
3 changed files with 25 additions and 19 deletions

1
.gitignore vendored
View File

@ -12,3 +12,4 @@ data
install.sh install.sh
nohup.out nohup.out
test.py test.py
points.csv

41
V5.py
View File

@ -221,9 +221,10 @@ def all_cards(): # return to the main page and closes all other tabs
if len(driver.window_handles) == 1: if len(driver.window_handles) == 1:
driver.get("https://www.bing.com/rewardsapp/flyout") driver.get("https://www.bing.com/rewardsapp/flyout")
if part2: if part2:
driver.find_element( row_element = driver.find_elements(By.CSS_SELECTOR, f'[class="i-h rw-sh fp_row"]')[1]
By.XPATH, "/html/body/div/div/div[3]/div[2]/div[2]/div[2]/div[1]" expanded = row_element.get_attribute("aria-expanded")
).click() if expanded != "true":
row_element.click()
else: else:
driver.switch_to.window(driver.window_handles[1]) driver.switch_to.window(driver.window_handles[1])
printf(f"fermeture : {driver.current_url}") printf(f"fermeture : {driver.current_url}")
@ -236,7 +237,7 @@ def all_cards(): # return to the main page and closes all other tabs
def daily_cards(): # cartes de la premiere partie (renouvelées chaque jours). def daily_cards(): # cartes de la premiere partie (renouvelées chaque jours).
try: try:
# make sure that the daily area is expanded # make sure that the daily area is expanded
row_element = driver.find_element(By.XPATH, "/html/body/div/div/div[3]/div[2]/div[1]/div[1]") row_element = driver.find_elements(By.CSS_SELECTOR, f'[class="i-h rw-sh fp_row"]')[0]
expanded = row_element.get_attribute("aria-expanded") expanded = row_element.get_attribute("aria-expanded")
if expanded != "true": if expanded != "true":
row_element.click() row_element.click()
@ -244,9 +245,8 @@ def all_cards(): # return to the main page and closes all other tabs
custom_sleep(uniform(3, 5)) custom_sleep(uniform(3, 5))
try: try:
titre = "Placeholder" titre = "Placeholder"
driver.find_element( elm = driver.find_elements(By.CLASS_NAME, 'promo_cont')
By.XPATH,f"/html/body/div/div/div[3]/div[2]/div[1]/div[2]/div/div[{i+1}]/a", elm[i].click()
).click()
sleep(1) sleep(1)
titre = driver.title titre = driver.title
try_play(titre) try_play(titre)
@ -255,7 +255,7 @@ def all_cards(): # return to the main page and closes all other tabs
printf(f"DailyCard {titre} ok") printf(f"DailyCard {titre} ok")
except Exception as e: except Exception as e:
log_error(f"all_cards card {titre} error ({format_error(e)})") log_error(f"all_cards card {titre} error ({format_error(e)})")
"""
try : # devrait renvoyer vrai si la carte i est faite ou pas, a l'aide su symbole en haut a droite de la carte try : # devrait renvoyer vrai si la carte i est faite ou pas, a l'aide su symbole en haut a droite de la carte
elm = driver.find_element(By.XPATH, f"/html/body/div/div/div[3]/div[2]/div[1]/div[2]/div/div[{i+1}]/a/div/div[2]/div[1]/div[2]/div") elm = driver.find_element(By.XPATH, f"/html/body/div/div/div[3]/div[2]/div[1]/div[2]/div/div[{i+1}]/a/div/div[2]/div[1]/div[2]/div")
if not ("correctCircle" in elm.get_attribute("innerHTML")): if not ("correctCircle" in elm.get_attribute("innerHTML")):
@ -266,23 +266,25 @@ def all_cards(): # return to the main page and closes all other tabs
except Exception as e : except Exception as e :
printf(format_error(e) + "probablement ok - check card") printf(format_error(e) + "probablement ok - check card")
# if it fail, it's probably okay -> when all three card are done, the pannel fold # if it fail, it's probably okay -> when all three card are done, the pannel fold
"""
except Exception as e: except Exception as e:
log_error(e) log_error(e)
def weekly_cards(): def weekly_cards():
# make sure that the weekly area is expanded # make sure that the weekly area is expanded
row_element = driver.find_element(By.XPATH, "/html/body/div/div/div[3]/div[2]/div[2]/div[2]") row_element = driver.find_elements(By.CSS_SELECTOR, f'[class="i-h rw-sh fp_row"]')[1]
expanded = row_element.get_attribute("aria-expanded") expanded = row_element.get_attribute("aria-expanded")
if expanded != "true": if expanded != "true":
row_element.click() row_element.click()
for i in range(20): # Should raise an error whene there is no card left for i in range(20): # Should raise an error whene there is no card left
printf("début de l'une des cartes") printf("début de l'une des cartes")
driver.find_element( elm = driver.find_elements(By.CLASS_NAME, 'promo_cont')
By.XPATH, try :
"/html/body/div/div/div[3]/div[2]/div[2]/div[3]/div/div[1]/a/div/div[2]", elm[0].click()
).click() except Exception as e :
print(f"{e} + {driver.current_url}")
break
driver.switch_to.window(driver.window_handles[len(driver.window_handles) - 1]) driver.switch_to.window(driver.window_handles[len(driver.window_handles) - 1])
sleep(1) sleep(1)
titre = driver.title titre = driver.title
@ -290,10 +292,10 @@ def all_cards(): # return to the main page and closes all other tabs
try_play(titre) try_play(titre)
reset(True) reset(True)
sleep(1) sleep(1)
try: #try:
findall('href="([^<]+)" title=""', driver.page_source)[3] # return error if there is no cards left to do # findall('href="([^<]+)" title=""', driver.page_source)[3] # return error if there is no cards left to do
except: #except:
break # break
def top_cards(): def top_cards():
for _ in range(10): for _ in range(10):
@ -306,16 +308,19 @@ def all_cards(): # return to the main page and closes all other tabs
try : try :
top_cards() top_cards()
print("top card")
except Exception as e: except Exception as e:
log_error(e) log_error(e)
try: try:
daily_cards() daily_cards()
print("daily card")
except Exception as e: except Exception as e:
log_error(e) log_error(e)
try : try :
weekly_cards() weekly_cards()
print("weekly card")
except Exception as e: except Exception as e:
log_error(e) log_error(e)

View File

@ -1 +1 @@
v5.2.3 v5.2.4