40 lines
1.7 KiB
Python
40 lines
1.7 KiB
Python
import re
|
|
from seleniumbase import BaseCase
|
|
BaseCase.main(__name__, __file__)
|
|
|
|
|
|
class SoupParsingTests(BaseCase):
|
|
def click_menu_item(self, text):
|
|
# Use BeautifulSoup to parse the selector ID from element text.
|
|
# Then click on the element with the ID.
|
|
# (This is useful when the selector ID is auto-generated.)
|
|
pattern = re.compile(text)
|
|
soup = self.get_beautiful_soup()
|
|
the_id = soup.find(string=pattern).parent.parent.attrs["id"]
|
|
self.click("#%s" % the_id)
|
|
|
|
def test_beautiful_soup_parsing(self):
|
|
if self.headless:
|
|
self.open_if_not_url("about:blank")
|
|
self.skip("Skip this test in headless mode!")
|
|
self.open("https://seleniumbase.io/tinymce/")
|
|
self.wait_for_element("div.mce-container-body")
|
|
self.click_menu_item("File")
|
|
self.click_menu_item("New document")
|
|
self.click_menu_item("Paragraph")
|
|
self.click_menu_item("Heading 2")
|
|
self.switch_to_frame("iframe")
|
|
self.add_text("#tinymce", "Automate anything with SeleniumBase!\n")
|
|
self.switch_to_default_content()
|
|
self.click("button i.mce-i-image")
|
|
self.type('input[aria-label="Width"].mce-textbox', "300")
|
|
image_url = "https://seleniumbase.github.io/img/sb_logo_10.png"
|
|
self.type("input.mce-textbox", image_url + "\n")
|
|
with self.frame_switch("iframe"):
|
|
self.click("h2")
|
|
self.post_message("Automate anything with SeleniumBase!")
|
|
self.click_menu_item("File")
|
|
self.click_menu_item("Preview")
|
|
with self.frame_switch('iframe[sandbox="allow-scripts"]'):
|
|
self.post_message("Learn SeleniumBase Today!")
|