mirror of
https://github.com/nextcloud/docker.git
synced 2025-03-15 19:05:09 +01:00
Fixes for docs scenario
This commit is contained in:
parent
d9b87d7d16
commit
1c614073c2
4 changed files with 170 additions and 107 deletions
|
@ -1,43 +1,65 @@
|
||||||
from time import time_ns
|
import contextlib
|
||||||
|
import sys
|
||||||
|
from time import sleep, time_ns
|
||||||
|
|
||||||
from playwright.sync_api import Playwright, sync_playwright
|
from playwright.sync_api import Playwright, sync_playwright, Error
|
||||||
|
|
||||||
def log_note(message: str) -> None:
|
def log_note(message: str) -> None:
|
||||||
timestamp = str(time_ns())[:16]
|
timestamp = str(time_ns())[:16]
|
||||||
print(f"{timestamp} {message}")
|
print(f"{timestamp} {message}")
|
||||||
|
|
||||||
def run(playwright: Playwright) -> None:
|
def run(playwright: Playwright, browser_name: str) -> None:
|
||||||
log_note("Launch browser")
|
log_note(f"Launch browser {browser_name}")
|
||||||
browser = playwright.chromium.launch(headless=True)
|
if browser_name == "firefox":
|
||||||
|
browser_type = playwright.firefox
|
||||||
|
else:
|
||||||
|
browser_type = playwright.chromium
|
||||||
|
browser = browser_type.launch(headless=True)
|
||||||
context = browser.new_context()
|
context = browser.new_context()
|
||||||
page = context.new_page()
|
page = context.new_page()
|
||||||
log_note("Login")
|
try:
|
||||||
page.goto("http://nc/")
|
log_note("Login")
|
||||||
page.get_by_label("Account name or email").click()
|
page.goto("http://nc/")
|
||||||
page.get_by_label("Account name or email").fill("Crash")
|
page.get_by_label("Account name or email").click()
|
||||||
page.get_by_label("Account name or email").press("Tab")
|
page.get_by_label("Account name or email").fill("Crash")
|
||||||
page.get_by_label("Password", exact=True).fill("Override")
|
page.get_by_label("Account name or email").press("Tab")
|
||||||
page.get_by_label("Password", exact=True).press("Enter")
|
page.get_by_label("Password", exact=True).fill("Override")
|
||||||
log_note("Create new text file")
|
page.get_by_label("Password", exact=True).press("Enter")
|
||||||
page.get_by_role("link", name="Files").click()
|
log_note("Create new text file")
|
||||||
page.get_by_role("link", name="New file/folder menu").click()
|
page.get_by_role("link", name="Files").click()
|
||||||
page.get_by_role("link", name="New text file").click()
|
page.get_by_role("link", name="New file/folder menu").click()
|
||||||
page.locator("#view9-input-file").fill("colab_meeting.md")
|
page.get_by_role("link", name="New text file").click()
|
||||||
page.locator("#view9-input-file").press("Enter")
|
page.locator("#view9-input-file").fill("colab_meeting.md")
|
||||||
page.get_by_role("button", name="Create a new file with the selected template").click()
|
page.locator("#view9-input-file").press("Enter")
|
||||||
page.get_by_role("button", name="Close modal").click()
|
page.get_by_role("button", name="Create a new file with the selected template").click()
|
||||||
log_note("Share file with other user")
|
sleep(5)
|
||||||
page.get_by_role("link", name="colab_meeting .md").get_by_role("link", name="Share").click()
|
with contextlib.suppress(Exception):
|
||||||
page.get_by_placeholder("Name, email, or Federated Cloud ID …").click()
|
page.get_by_role("button", name="Close modal").click(timeout=15_000)
|
||||||
page.get_by_placeholder("Name, email, or Federated Cloud ID …").fill("docs")
|
page.keyboard.press("Escape")
|
||||||
page.get_by_text("docs_dude").first.click()
|
log_note("Share file with other user")
|
||||||
log_note("Close browser")
|
page.get_by_role("link", name="colab_meeting .md").get_by_role("link", name="Share").click()
|
||||||
page.close()
|
page.get_by_placeholder("Name, email, or Federated Cloud ID …").click()
|
||||||
|
page.get_by_placeholder("Name, email, or Federated Cloud ID …").fill("docs")
|
||||||
|
page.get_by_text("docs_dude").first.click()
|
||||||
|
log_note("Close browser")
|
||||||
|
page.close()
|
||||||
|
|
||||||
# ---------------------
|
# ---------------------
|
||||||
context.close()
|
context.close()
|
||||||
browser.close()
|
browser.close()
|
||||||
|
except Error as e:
|
||||||
|
log_note(f"Exception occurred: {e.message}")
|
||||||
|
log_note(f"Page content was: {page.content()}")
|
||||||
|
raise e
|
||||||
|
|
||||||
|
|
||||||
with sync_playwright() as playwright:
|
with sync_playwright() as playwright:
|
||||||
run(playwright)
|
if len(sys.argv) > 1:
|
||||||
|
browser_name = sys.argv[1].lower()
|
||||||
|
if browser_name not in ["chromium", "firefox"]:
|
||||||
|
print("Invalid browser name. Please choose either 'chromium' or 'firefox'.")
|
||||||
|
sys.exit(1)
|
||||||
|
else:
|
||||||
|
browser_name = "chromium"
|
||||||
|
|
||||||
|
run(playwright, browser_name)
|
||||||
|
|
|
@ -1,43 +1,61 @@
|
||||||
|
import sys
|
||||||
import contextlib
|
import contextlib
|
||||||
from time import time_ns
|
from time import time_ns
|
||||||
|
|
||||||
from playwright.sync_api import Playwright, sync_playwright
|
from playwright.sync_api import Playwright, sync_playwright, Error
|
||||||
|
|
||||||
def log_note(message: str) -> None:
|
def log_note(message: str) -> None:
|
||||||
timestamp = str(time_ns())[:16]
|
timestamp = str(time_ns())[:16]
|
||||||
print(f"{timestamp} {message}")
|
print(f"{timestamp} {message}")
|
||||||
|
|
||||||
def create_user(playwright: Playwright, username: str, password: str) -> None:
|
def create_user(playwright: Playwright, browser_name: str, username: str, password: str) -> None:
|
||||||
log_note("Launch browser")
|
log_note(f"Launch browser {browser_name}")
|
||||||
browser = playwright.chromium.launch(headless=True)
|
if browser_name == "firefox":
|
||||||
|
browser_type = playwright.firefox
|
||||||
|
else:
|
||||||
|
browser_type = playwright.chromium
|
||||||
|
browser = browser_type.launch(headless=True)
|
||||||
context = browser.new_context()
|
context = browser.new_context()
|
||||||
page = context.new_page()
|
try:
|
||||||
log_note("Login")
|
page = context.new_page()
|
||||||
page.goto("http://nc/")
|
log_note("Login")
|
||||||
page.get_by_label("Account name or email").click()
|
page.goto("http://nc/")
|
||||||
page.get_by_label("Account name or email").fill("Crash")
|
page.get_by_label("Account name or email").click()
|
||||||
page.get_by_label("Account name or email").press("Tab")
|
page.get_by_label("Account name or email").fill("Crash")
|
||||||
page.get_by_label("Password", exact=True).fill("Override")
|
page.get_by_label("Account name or email").press("Tab")
|
||||||
page.get_by_label("Password", exact=True).press("Enter")
|
page.get_by_label("Password", exact=True).fill("Override")
|
||||||
with contextlib.suppress(Exception):
|
page.get_by_label("Password", exact=True).press("Enter")
|
||||||
page.get_by_role("button", name="Close modal").click(timeout=15_000)
|
with contextlib.suppress(Exception):
|
||||||
log_note("Create user")
|
page.get_by_role("button", name="Close modal").click(timeout=15_000)
|
||||||
page.get_by_role("link", name="Open settings menu").click()
|
log_note("Create user")
|
||||||
page.get_by_role("link", name="Users").click()
|
page.get_by_role("link", name="Open settings menu").click()
|
||||||
page.get_by_role("button", name="New user").click()
|
page.get_by_role("link", name="Users").click()
|
||||||
page.get_by_placeholder("Username").click()
|
page.get_by_role("button", name="New user").click()
|
||||||
page.get_by_placeholder("Username").fill(username)
|
page.get_by_placeholder("Username").click()
|
||||||
page.get_by_placeholder("Username").press("Tab")
|
page.get_by_placeholder("Username").fill(username)
|
||||||
page.get_by_placeholder("Display name").press("Tab")
|
page.get_by_placeholder("Username").press("Tab")
|
||||||
page.get_by_placeholder("Password", exact=True).fill(password)
|
page.get_by_placeholder("Display name").press("Tab")
|
||||||
page.get_by_role("button", name="Add a new user").click()
|
page.get_by_placeholder("Password", exact=True).fill(password)
|
||||||
log_note("Close browser")
|
page.get_by_role("button", name="Add a new user").click()
|
||||||
|
log_note("Close browser")
|
||||||
|
|
||||||
# ---------------------
|
# ---------------------
|
||||||
page.close()
|
page.close()
|
||||||
context.close()
|
context.close()
|
||||||
browser.close()
|
browser.close()
|
||||||
|
except Error as e:
|
||||||
|
log_note(f"Exception occurred: {e.message}")
|
||||||
|
log_note(f"Page content was: {page.content()}")
|
||||||
|
raise e
|
||||||
|
|
||||||
|
|
||||||
with sync_playwright() as playwright:
|
with sync_playwright() as playwright:
|
||||||
create_user(playwright, username="docs_dude", password="docsrule!12")
|
if len(sys.argv) > 1:
|
||||||
|
browser_name = sys.argv[1].lower()
|
||||||
|
if browser_name not in ["chromium", "firefox"]:
|
||||||
|
print("Invalid browser name. Please choose either 'chromium' or 'firefox'.")
|
||||||
|
sys.exit(1)
|
||||||
|
else:
|
||||||
|
browser_name = "chromium"
|
||||||
|
|
||||||
|
create_user(playwright, browser_name, username="docs_dude", password="docsrule!12")
|
||||||
|
|
|
@ -1,8 +1,10 @@
|
||||||
|
import contextlib
|
||||||
import random
|
import random
|
||||||
import string
|
import string
|
||||||
|
import sys
|
||||||
from time import time_ns, sleep
|
from time import time_ns, sleep
|
||||||
|
|
||||||
from playwright.sync_api import Playwright, sync_playwright, expect
|
from playwright.sync_api import Playwright, sync_playwright, expect, Error
|
||||||
|
|
||||||
|
|
||||||
def get_random_text() -> str:
|
def get_random_text() -> str:
|
||||||
|
@ -14,58 +16,72 @@ def log_note(message: str) -> None:
|
||||||
timestamp = str(time_ns())[:16]
|
timestamp = str(time_ns())[:16]
|
||||||
print(f"{timestamp} {message}")
|
print(f"{timestamp} {message}")
|
||||||
|
|
||||||
def collaborate(playwright: Playwright) -> None:
|
def collaborate(playwright: Playwright, browser_name: str) -> None:
|
||||||
log_note("Launching browsers")
|
log_note(f"Launch two {browser_name} browsers")
|
||||||
browser = playwright.chromium.launch(headless=True)
|
if browser_name == "firefox":
|
||||||
|
browser_type = playwright.firefox
|
||||||
|
else:
|
||||||
|
browser_type = playwright.chromium
|
||||||
|
|
||||||
|
browser = browser_type.launch(headless=True)
|
||||||
context = browser.new_context()
|
context = browser.new_context()
|
||||||
admin_user = context.new_page()
|
admin_user = context.new_page()
|
||||||
|
|
||||||
browser_two = playwright.chromium.launch(headless=True)
|
browser_two = browser_type.launch(headless=True)
|
||||||
context_two = browser_two.new_context()
|
context_two = browser_two.new_context()
|
||||||
docs_user = context_two.new_page()
|
docs_user = context_two.new_page()
|
||||||
|
|
||||||
# Login and open the file for both users
|
try:
|
||||||
log_note("Logging in with users")
|
# Login and open the file for both users
|
||||||
login(admin_user, "Crash", "Override")
|
log_note("Logging in with users")
|
||||||
login(docs_user, "docs_dude", "docsrule!12")
|
login(admin_user, "Crash", "Override")
|
||||||
log_note("Opening document with both users")
|
login(docs_user, "docs_dude", "docsrule!12")
|
||||||
docs_user.get_by_role("button", name="Close modal").click(timeout=15_000)
|
log_note("Opening document with both users")
|
||||||
admin_user.get_by_role("link", name="Files").click()
|
with contextlib.suppress(Exception):
|
||||||
docs_user.get_by_role("link", name="Files").click()
|
sleep(5)
|
||||||
admin_user.get_by_role("link", name="Shares").click()
|
docs_user.get_by_role("button", name="Close modal").click(timeout=15_000)
|
||||||
docs_user.get_by_role("link", name="Shares").click()
|
admin_user.get_by_role("link", name="Files").click()
|
||||||
admin_user.get_by_role("link", name="colab_meeting .md").click()
|
docs_user.get_by_role("link", name="Files").click()
|
||||||
docs_user.get_by_role("link", name="colab_meeting .md").click()
|
admin_user.get_by_role("link", name="Shares").click()
|
||||||
|
docs_user.get_by_role("link", name="Shares").click()
|
||||||
|
admin_user.get_by_role("link", name="colab_meeting .md").click()
|
||||||
|
docs_user.get_by_role("link", name="colab_meeting .md").click()
|
||||||
|
|
||||||
# Write the first message and assert it's visible for the other user
|
# Write the first message and assert it's visible for the other user
|
||||||
log_note("Sending first validation message")
|
log_note("Sending first validation message")
|
||||||
first_message = "FIRST_VALIDATION_MESSAGE"
|
first_message = "FIRST_VALIDATION_MESSAGE"
|
||||||
admin_user.get_by_role("dialog", name="colab_meeting.md").get_by_role("document").locator("div").first.type(first_message)
|
admin_user.get_by_role("dialog", name="colab_meeting.md").get_by_role("document").locator("div").first.type(first_message)
|
||||||
expect(docs_user.get_by_text(first_message)).to_be_visible()
|
expect(docs_user.get_by_text(first_message)).to_be_visible()
|
||||||
|
|
||||||
for x in range(1, 7):
|
for x in range(1, 7):
|
||||||
random_message = get_random_text()
|
random_message = get_random_text()
|
||||||
# Admin sends on even, docs_dude on odd
|
# Admin sends on even, docs_dude on odd
|
||||||
if x % 2 == 0:
|
if x % 2 == 0:
|
||||||
log_note("Admin adding text")
|
log_note("Admin adding text")
|
||||||
admin_user.get_by_role("dialog", name="colab_meeting.md").get_by_role("document").locator("div").first.type(random_message)
|
admin_user.get_by_role("dialog", name="colab_meeting.md").get_by_role("document").locator("div").first.type(random_message)
|
||||||
expect(docs_user.get_by_text(random_message)).to_be_visible()
|
expect(docs_user.get_by_text(random_message)).to_be_visible()
|
||||||
else:
|
else:
|
||||||
log_note("User adding text")
|
log_note("User adding text")
|
||||||
docs_user.get_by_role("dialog", name="colab_meeting.md").get_by_role("document").locator("div").first.type(random_message)
|
docs_user.get_by_role("dialog", name="colab_meeting.md").get_by_role("document").locator("div").first.type(random_message)
|
||||||
expect(admin_user.get_by_text(random_message)).to_be_visible()
|
expect(admin_user.get_by_text(random_message)).to_be_visible()
|
||||||
|
|
||||||
log_note("Sleeping for 10 seconds")
|
log_note("Sleeping for 10 seconds")
|
||||||
sleep(10)
|
sleep(10)
|
||||||
|
|
||||||
log_note("Closing browsers")
|
log_note("Closing browsers")
|
||||||
# ---------------------
|
# ---------------------
|
||||||
admin_user.close()
|
admin_user.close()
|
||||||
docs_user.close()
|
docs_user.close()
|
||||||
context.close()
|
context.close()
|
||||||
context_two.close()
|
context_two.close()
|
||||||
browser.close()
|
browser.close()
|
||||||
browser_two.close()
|
browser_two.close()
|
||||||
|
|
||||||
|
except Error as e:
|
||||||
|
log_note(f"Exception occurred: {e.message}")
|
||||||
|
log_note(f"Page content was: {docs_user.content()}")
|
||||||
|
log_note(f"Page content was: {admin_user.content()}")
|
||||||
|
raise e
|
||||||
|
|
||||||
def login(page, username, password):
|
def login(page, username, password):
|
||||||
page.goto("http://nc/login")
|
page.goto("http://nc/login")
|
||||||
|
@ -77,4 +93,12 @@ def login(page, username, password):
|
||||||
|
|
||||||
|
|
||||||
with sync_playwright() as playwright:
|
with sync_playwright() as playwright:
|
||||||
collaborate(playwright)
|
if len(sys.argv) > 1:
|
||||||
|
browser_name = sys.argv[1].lower()
|
||||||
|
if browser_name not in ["chromium", "firefox"]:
|
||||||
|
print("Invalid browser name. Please choose either 'chromium' or 'firefox'.")
|
||||||
|
sys.exit(1)
|
||||||
|
else:
|
||||||
|
browser_name = "chromium"
|
||||||
|
|
||||||
|
collaborate(playwright, browser_name)
|
||||||
|
|
|
@ -36,14 +36,13 @@ def main(browser_name: str = "chromium"):
|
||||||
# 3. Dashboard
|
# 3. Dashboard
|
||||||
page.wait_for_selector('.app-dashboard')
|
page.wait_for_selector('.app-dashboard')
|
||||||
log_note("Installation complete")
|
log_note("Installation complete")
|
||||||
|
browser.close()
|
||||||
|
|
||||||
except Error as e:
|
except Error as e:
|
||||||
log_note(f"Exception occurred: {e.message}")
|
log_note(f"Exception occurred: {e.message}")
|
||||||
log_note(f"Page content was: {page.content()}")
|
log_note(f"Page content was: {page.content()}")
|
||||||
raise e
|
raise e
|
||||||
|
|
||||||
browser.close()
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
if len(sys.argv) > 1:
|
if len(sys.argv) > 1:
|
||||||
|
|
Loading…
Add table
Reference in a new issue