1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
from six.moves.urllib.parse import quote
from marionette_driver.by import By
from marionette_driver.errors import (
DetachedShadowRootException,
NoSuchElementException,
NoSuchShadowRootException,
)
from marionette_driver.marionette import HTMLElement, ShadowRoot
from marionette_harness import MarionetteTestCase
def inline(doc):
return "data:text/html;charset=utf-8,{}".format(quote(doc))
page_shadow_dom = inline(
"""
<custom-element></custom-element>
<script>
customElements.define('custom-element',
class extends HTMLElement {
constructor() {
super();
this.attachShadow({mode: 'open'}).innerHTML = `
<div><a href=# id=foo>full link text</a><a href=# id=bar>another link text</a></div>
`;
}
});
</script>"""
)
class TestShadowDOMFindElement(MarionetteTestCase):
def setUp(self):
MarionetteTestCase.setUp(self)
self.marionette.timeout.implicit = 0
def test_find_element_from_shadow_root(self):
self.marionette.navigate(page_shadow_dom)
custom_element = self.marionette.find_element(By.CSS_SELECTOR, "custom-element")
shadow_root = custom_element.shadow_root
found = shadow_root.find_element(By.CSS_SELECTOR, "a")
self.assertIsInstance(found, HTMLElement)
el = self.marionette.execute_script(
"""
return arguments[0].shadowRoot.querySelector('a')
""",
[custom_element],
)
self.assertEqual(found, el)
def test_unknown_element_from_shadow_root(self):
self.marionette.navigate(page_shadow_dom)
shadow_root = self.marionette.find_element(
By.CSS_SELECTOR, "custom-element"
).shadow_root
with self.assertRaises(NoSuchElementException):
shadow_root.find_element(By.CSS_SELECTOR, "does not exist")
def test_detached_shadow_root(self):
self.marionette.navigate(page_shadow_dom)
shadow_root = self.marionette.find_element(
By.CSS_SELECTOR, "custom-element"
).shadow_root
self.marionette.refresh()
with self.assertRaises(DetachedShadowRootException):
shadow_root.find_element(By.CSS_SELECTOR, "a")
def test_no_such_shadow_root(self):
not_existing_shadow_root = ShadowRoot(self.marionette, "foo")
with self.assertRaises(NoSuchShadowRootException):
not_existing_shadow_root.find_element(By.CSS_SELECTOR, "a")
class TestShadowDOMFindElements(MarionetteTestCase):
def setUp(self):
MarionetteTestCase.setUp(self)
self.marionette.timeout.implicit = 0
def test_find_elements_from_shadow_root(self):
self.marionette.navigate(page_shadow_dom)
custom_element = self.marionette.find_element(By.CSS_SELECTOR, "custom-element")
shadow_root = custom_element.shadow_root
found = shadow_root.find_elements(By.CSS_SELECTOR, "a")
self.assertEqual(len(found), 2)
els = self.marionette.execute_script(
"""
return arguments[0].shadowRoot.querySelectorAll('a')
""",
[custom_element],
)
for i in range(len(found)):
self.assertIsInstance(found[i], HTMLElement)
self.assertEqual(found[i], els[i])
def test_detached_shadow_root(self):
self.marionette.navigate(page_shadow_dom)
shadow_root = self.marionette.find_element(
By.CSS_SELECTOR, "custom-element"
).shadow_root
self.marionette.refresh()
with self.assertRaises(DetachedShadowRootException):
shadow_root.find_elements(By.CSS_SELECTOR, "a")
def test_no_such_shadow_root(self):
not_existing_shadow_root = ShadowRoot(self.marionette, "foo")
with self.assertRaises(NoSuchShadowRootException):
not_existing_shadow_root.find_elements(By.CSS_SELECTOR, "a")
|