Skip to content

Commit

Permalink
Update all content-* tests
Browse files Browse the repository at this point in the history
  • Loading branch information
cezaraugusto committed Dec 4, 2024
1 parent af86a02 commit ce94eff
Show file tree
Hide file tree
Showing 18 changed files with 655 additions and 318 deletions.
56 changes: 43 additions & 13 deletions examples/content-css-modules/template.spec.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
import path from 'path'
import {execSync} from 'child_process'
import {extensionFixtures, takeScreenshot} from '../extension-fixtures'
import {
extensionFixtures,
getShadowRootElement,
takeScreenshot
} from '../extension-fixtures'

const exampleDir = 'examples/content-css-modules'
const pathToExtension = path.join(__dirname, `dist/chrome`)
Expand All @@ -16,30 +20,56 @@ test('should exist an element with the class name content_script', async ({
page
}) => {
await page.goto('https://extension.js.org/')
const div = page.locator('body > div.content_script')
await test.expect(div).toBeVisible()
const div = await getShadowRootElement(
page,
'#extension-root',
'div.content_script'
)
if (!div) {
throw new Error('div with class content_script not found in Shadow DOM')
}
test.expect(div).not.toBeNull()
})

test('should exist an h1 element with specified content', async ({page}) => {
await page.goto('https://extension.js.org/')
const h1 = page.locator('body > div.content_script > h1')
await test.expect(h1).toContainText('Welcome to your')
const h1 = await getShadowRootElement(
page,
'#extension-root',
'div.content_script > h1'
)
if (!h1) {
throw new Error('h1 element not found in Shadow DOM')
}
const textContent = await h1.evaluate((node) => node.textContent)
test.expect(textContent).toContain('Welcome to your')
})

test('should exist a default color value', async ({page}) => {
await page.goto('https://extension.js.org/')
const h1 = page.locator('body > div.content_script > h1')
const color = await page.evaluate(
(locator) => {
return window.getComputedStyle(locator!).getPropertyValue('color')
},
await h1.elementHandle()
const h1 = await getShadowRootElement(
page,
'#extension-root',
'div.content_script > h1'
)
await test.expect(color).toEqual('rgb(201, 201, 201)')
if (!h1) {
throw new Error('h1 element not found in Shadow DOM')
}
const color = await h1.evaluate((node) =>
window.getComputedStyle(node as HTMLElement).getPropertyValue('color')
)
test.expect(color).toEqual('rgb(201, 201, 201)')
})

test.skip('takes a screenshot of the page', async ({page}) => {
await page.goto('https://extension.js.org/')
await page.waitForSelector('body > div.content_script')
const contentScriptDiv = await getShadowRootElement(
page,
'#extension-root',
'div.content_script'
)
if (!contentScriptDiv) {
throw new Error('div.content_script not found in Shadow DOM for screenshot')
}
await takeScreenshot(page, path.join(__dirname, 'screenshot.png'))
})
58 changes: 44 additions & 14 deletions examples/content-env/template.spec.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,12 @@
import path from 'path'
import {execSync} from 'child_process'
import {extensionFixtures, takeScreenshot} from '../extension-fixtures'
import {
extensionFixtures,
getShadowRootElement,
takeScreenshot
} from '../extension-fixtures'

const exampleDir = 'examples/content-env'
const exampleDir = 'examples/content-css-modules'
const pathToExtension = path.join(__dirname, `dist/chrome`)
const test = extensionFixtures(pathToExtension, true)

Expand All @@ -16,30 +20,56 @@ test('should exist an element with the class name content_script', async ({
page
}) => {
await page.goto('https://extension.js.org/')
const div = page.locator('body > div.content_script')
await test.expect(div).toBeVisible()
const div = await getShadowRootElement(
page,
'#extension-root',
'div.content_script'
)
if (!div) {
throw new Error('div with class content_script not found in Shadow DOM')
}
test.expect(div).not.toBeNull()
})

test('should exist an h1 element with specified content', async ({page}) => {
await page.goto('https://extension.js.org/')
const h1 = page.locator('body > div.content_script > h1')
await test.expect(h1).toContainText('Welcome to your')
const h1 = await getShadowRootElement(
page,
'#extension-root',
'div.content_script > h1'
)
if (!h1) {
throw new Error('h1 element not found in Shadow DOM')
}
const textContent = await h1.evaluate((node) => node.textContent)
test.expect(textContent).toContain('Welcome to your')
})

test('should exist a default color value', async ({page}) => {
await page.goto('https://extension.js.org/')
const h1 = page.locator('body > div.content_script > h1')
const color = await page.evaluate(
(locator) => {
return window.getComputedStyle(locator!).getPropertyValue('color')
},
await h1.elementHandle()
const h1 = await getShadowRootElement(
page,
'#extension-root',
'div.content_script > h1'
)
await test.expect(color).toEqual('rgb(201, 201, 201)')
if (!h1) {
throw new Error('h1 element not found in Shadow DOM')
}
const color = await h1.evaluate((node) =>
window.getComputedStyle(node as HTMLElement).getPropertyValue('color')
)
test.expect(color).toEqual('rgb(201, 201, 201)')
})

test.skip('takes a screenshot of the page', async ({page}) => {
await page.goto('https://extension.js.org/')
await page.waitForSelector('body > div.content_script')
const contentScriptDiv = await getShadowRootElement(
page,
'#extension-root',
'div.content_script'
)
if (!contentScriptDiv) {
throw new Error('div.content_script not found in Shadow DOM for screenshot')
}
await takeScreenshot(page, path.join(__dirname, 'screenshot.png'))
})
62 changes: 45 additions & 17 deletions examples/content-esm/template.spec.mjs
Original file line number Diff line number Diff line change
@@ -1,15 +1,17 @@
import path from 'path'
import {fileURLToPath} from 'url'
import {execSync} from 'child_process'
import {extensionFixtures} from '../extension-fixtures.mjs'
import {takeScreenshot} from '../extension-fixtures.mjs'
import {
getShadowRootElement,
extensionFixtures,
takeScreenshot
} from '../extension-fixtures.mjs'

const __filename = fileURLToPath(import.meta.url)
const __dirname = path.dirname(__filename)

const exampleDir = 'examples/content-esm'
const exampleDir = 'examples/content-css-modules'
const pathToExtension = path.join(__dirname, `dist/chrome`)

const test = extensionFixtures(pathToExtension, true)

test.beforeAll(async () => {
Expand All @@ -18,34 +20,60 @@ test.beforeAll(async () => {
})
})

test('should exist an element with the class name .content_script', async ({
test('should exist an element with the class name content_script', async ({
page
}) => {
await page.goto('https://extension.js.org/')
const div = page.locator('body > div.content_script')
await test.expect(div).toBeVisible()
const div = await getShadowRootElement(
page,
'#extension-root',
'div.content_script'
)
if (!div) {
throw new Error('div with class content_script not found in Shadow DOM')
}
test.expect(div).not.toBeNull()
})

test('should exist an h1 element with specified content', async ({page}) => {
await page.goto('https://extension.js.org/')
const h1 = page.locator('body > div.content_script > h1')
await test.expect(h1).toContainText('Welcome to your')
const h1 = await getShadowRootElement(
page,
'#extension-root',
'div.content_script > h1'
)
if (!h1) {
throw new Error('h1 element not found in Shadow DOM')
}
const textContent = await h1.evaluate((node) => node.textContent)
test.expect(textContent).toContain('Welcome to your')
})

test('should exist a default color value', async ({page}) => {
await page.goto('https://extension.js.org/')
const h1 = page.locator('body > div.content_script > h1')
const color = await page.evaluate(
(locator) => {
return window.getComputedStyle(locator).getPropertyValue('color')
},
await h1.elementHandle()
const h1 = await getShadowRootElement(
page,
'#extension-root',
'div.content_script > h1'
)
await test.expect(color).toEqual('rgb(201, 201, 201)')
if (!h1) {
throw new Error('h1 element not found in Shadow DOM')
}
const color = await h1.evaluate((node) =>
window.getComputedStyle(node).getPropertyValue('color')
)
test.expect(color).toEqual('rgb(201, 201, 201)')
})

test.skip('takes a screenshot of the page', async ({page}) => {
await page.goto('https://extension.js.org/')
await page.waitForSelector('body > div.content_script')
const contentScriptDiv = await getShadowRootElement(
page,
'#extension-root',
'div.content_script'
)
if (!contentScriptDiv) {
throw new Error('div.content_script not found in Shadow DOM for screenshot')
}
await takeScreenshot(page, path.join(__dirname, 'screenshot.png'))
})
4 changes: 1 addition & 3 deletions examples/content-extension-config/manifest.json
Original file line number Diff line number Diff line change
Expand Up @@ -10,9 +10,7 @@
},
"content_scripts": [
{
"matches": [
"<all_urls>"
],
"matches": ["<all_urls>"],
"js": ["./content/scripts.tsx"]
}
],
Expand Down
81 changes: 52 additions & 29 deletions examples/content-extension-config/template.spec.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
import path from 'path'
import {execSync} from 'child_process'
import {extensionFixtures, takeScreenshot} from '../extension-fixtures'
import {
extensionFixtures,
getShadowRootElement,
takeScreenshot
} from '../extension-fixtures'

const exampleDir = 'examples/content-extension-config'
const pathToExtension = path.join(__dirname, `dist/chrome`)
Expand All @@ -16,59 +20,78 @@ test('should exist an element with the class name extension-root', async ({
page
}) => {
await page.goto('https://extension.js.org/')
const div = page.locator('#extension-root')
await test.expect(div).toBeVisible()
const shadowRootHandle = await page
.locator('#extension-root')
.evaluateHandle((host: HTMLElement) => host.shadowRoot)

// Check that the Shadow DOM exists
test.expect(shadowRootHandle).not.toBeNull()

// Verify if the Shadow DOM contains children
const shadowChildrenCount = await shadowRootHandle.evaluate(
(shadowRoot: ShadowRoot) => shadowRoot.children.length
)
test.expect(shadowChildrenCount).toBeGreaterThan(0)
})

test('should exist an h2 element with specified content', async ({page}) => {
await page.goto('https://extension.js.org/')
const h2 = page.locator('#extension-root h2')
await test.expect(h2).toContainText('This is a content script')
const h2 = await getShadowRootElement(page, '#extension-root', 'h2')
if (!h2) {
throw new Error('h2 element not found in Shadow DOM')
}
const textContent = await h2.evaluate((node) => node.textContent)
test.expect(textContent).toContain('This is a content script')
})

test('should exist a default color value', async ({page}) => {
await page.goto('https://extension.js.org/')
const h2 = page.locator('#extension-root h2')
const color = await page.evaluate(
(locator) => {
return window.getComputedStyle(locator!).getPropertyValue('color')
},
await h2.elementHandle()
const h2 = await getShadowRootElement(page, '#extension-root', 'h2')
if (!h2) {
throw new Error('h2 element not found in Shadow DOM')
}
const color = await h2.evaluate((node) =>
window.getComputedStyle(node as HTMLElement).getPropertyValue('color')
)
await test.expect(color).toEqual('rgb(255, 255, 255)')
test.expect(color).toEqual('rgb(255, 255, 255)')
})

test('should load all images successfully', async ({page}) => {
await page.goto('https://extension.js.org/')
const images = page.locator('#extension-root img')
const imageElements = await images.all()
const shadowRootHandle = await page
.locator('#extension-root')
.evaluateHandle((host: HTMLElement) => host.shadowRoot)

const imagesHandle = await shadowRootHandle.evaluateHandle(
(shadow: ShadowRoot) => Array.from(shadow.querySelectorAll('img'))
)

const imageHandles = await imagesHandle.getProperties()
const results: boolean[] = []

for (const image of imageElements) {
const naturalWidth = await page.evaluate(
(img) => {
return img ? (img as HTMLImageElement).naturalWidth : 0
},
await image.elementHandle()
for (const [, imageHandle] of imageHandles) {
const naturalWidth = await imageHandle.evaluate(
(img) => (img as HTMLImageElement).naturalWidth
)

const naturalHeight = await page.evaluate(
(img) => {
return img ? (img as HTMLImageElement).naturalHeight : 0
},
await image.elementHandle()
const naturalHeight = await imageHandle.evaluate(
(img) => (img as HTMLImageElement).naturalHeight
)

const loadedSuccessfully = naturalWidth > 0 && naturalHeight > 0
results.push(loadedSuccessfully)
}

await test.expect(results.every((result) => result)).toBeTruthy()
test.expect(results.every((result) => result)).toBeTruthy()
})

test.skip('takes a screenshot of the page', async ({page}) => {
await page.goto('https://extension.js.org/')
await page.waitForSelector('body > div.content_script')
const contentScriptDiv = await getShadowRootElement(
page,
'#extension-root',
'div.content_script'
)
if (!contentScriptDiv) {
throw new Error('div.content_script not found in Shadow DOM for screenshot')
}
await takeScreenshot(page, path.join(__dirname, 'screenshot.png'))
})
Loading

0 comments on commit ce94eff

Please sign in to comment.