|
1 | 1 | import { createNode } from '#src/createNode' |
2 | | -import { page } from '@vitest/browser/context' |
| 2 | +import { page, server } from '@vitest/browser/context' |
3 | 3 | import { afterAll, beforeEach, describe, expect, test } from 'vitest' |
4 | 4 | import '../src/button.css' |
5 | 5 |
|
@@ -115,6 +115,25 @@ describe('dom related activity', () => { |
115 | 115 | /__screenshots__\/dom.test.ts\/dom-related-activity-svg-screenshot-1.png/, |
116 | 116 | ) |
117 | 117 | }) |
| 118 | + |
| 119 | + test.runIf(server.provider === 'webdriverio')('shadow dom works with multiple elements', async () => { |
| 120 | + const wrapper = createWrapper() |
| 121 | + const div = createNode() |
| 122 | + wrapper.appendChild(div) |
| 123 | + |
| 124 | + const shadow = div.attachShadow({ mode: 'open' }) |
| 125 | + const shadowDiv1 = createNode() |
| 126 | + shadowDiv1.role = 'tab' |
| 127 | + const shadowDiv2 = createNode() |
| 128 | + shadowDiv2.role = 'tab' |
| 129 | + shadow.appendChild(shadowDiv1) |
| 130 | + shadow.appendChild(shadowDiv2) |
| 131 | + |
| 132 | + expect( |
| 133 | + page.getByRole('tab').selector, |
| 134 | + 'there is only a single >>> in the selector', |
| 135 | + ).toBe('>>>html > body > div > div > div, html > body > div > div > div') |
| 136 | + }) |
118 | 137 | }) |
119 | 138 |
|
120 | 139 | function createWrapper() { |
|
0 commit comments