issues/377/user_tool.py (99 lines of code) (raw):
import sys, os
base_path = os.path.abspath(os.path.join(os.path.dirname(__file__), '..'))
sys.path.insert(0, base_path)
from playwright.sync_api import sync_playwright, expect
import re, time
from datetime import datetime, timezone
from email.header import decode_header
import imaplib, pytest
import email
import re
import random
from utils.trace_cleaner import trace_cleaner
NEWDOT_URL = "http://localhost:8082/"
EMAIL = "f2139887@gmail.com"
PASSWORD = ""
def generate_random_email():
return f"f2139887+46784@gmail.com"
def get_magic_code(user_email, password, since=None, retries=5, delay=10):
if since is None:
since = datetime.now(timezone.utc).replace(second=0, microsecond=0)
imap = imaplib.IMAP4_SSL("imap.gmail.com")
imap.login(user_email, password)
for _ in range(retries):
imap.select("inbox")
status, messages = imap.search(None, '(UNSEEN SUBJECT "Expensify magic sign-in code:")')
if status == "OK":
email_ids = messages[0].split()
if email_ids:
latest_email_id = email_ids[-1]
status, msg_data = imap.fetch(latest_email_id, "(RFC822)")
for response_part in msg_data:
if isinstance(response_part, tuple):
msg = email.message_from_bytes(response_part[1])
subject, encoding = decode_header(msg["Subject"])[0]
if isinstance(subject, bytes):
subject = subject.decode(encoding or "utf-8")
match = re.search(r"Expensify magic sign-in code: (\d+)", subject)
email_date = email.utils.parsedate_to_datetime(msg["Date"])
if match and email_date >= since:
code = match.group(1)
imap.logout()
return code
print("Email doesn't match conditions. Retrying...")
else:
print("No unread emails found with the subject. Retrying...")
else:
print("Failed to retrieve emails. Retrying...")
time.sleep(delay)
imap.logout()
print("Max retries reached. Email not found.")
return None
def login_user_ND_with_magiccode(user_email, password, page):
page.goto(NEWDOT_URL)
page.locator('input[type="email"]').fill(user_email)
page.locator("div:nth-child(3) > div:nth-child(2) > div > div > div > .css-view-175oi2r").click()
page.wait_for_timeout(5000)
magic_code = "123456"
page.locator('input[autocomplete="one-time-code"]').fill(magic_code)
page.wait_for_timeout(500)
def test_issue_24642():
with sync_playwright() as p:
browser = p.chromium.launch(
channel="chrome",
headless=True,
args=[
"--ignore-certificate-errors",
"--disable-web-security",
"--disable-features=IsolateOrigins,site-per-process"
],
proxy={"server": "http://localhost:8080"},
slow_mo=500
)
context_args = {}
context_args["geolocation"] = {"latitude": 37.7749, "longitude": -122.4194}
context_args["permissions"] = ["geolocation"]
context_args["ignore_https_errors"] = True
context = browser.new_context(**context_args)
# Start tracing with screenshots, snapshots and sources
context.tracing.start(screenshots=True, snapshots=True, sources=True)
page = context.new_page()
first_user_email = generate_random_email()
try:
login_user_ND_with_magiccode(first_user_email, PASSWORD, page)
page.wait_for_timeout(2000)
context.set_offline(True)
page.get_by_label("My settings").click()
page.get_by_text("Profile").click()
page.get_by_text("Personal details").click()
try:
page.get_by_role("button", name="Back").click(timeout=10000)
except Exception as e:
pytest.fail("Test failed due to an exception")
finally:
trace_path = "/app/expensify/user_tool/output_browser1.zip"
context.tracing.stop(path=trace_path)
trace_cleaner(trace_path)
context.close()
browser.close()
if __name__ == "__main__":
test_issue_24642()