Skip to content

Commit a4f35ad

Browse files
shakyShanegithub-actions[bot]
authored andcommitted
Release build 4.30.0 [ci release]
1 parent c8d6ff1 commit a4f35ad

File tree

12 files changed

+658
-0
lines changed

12 files changed

+658
-0
lines changed

Sources/ContentScopeScripts/dist/contentScope.js

Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -3063,6 +3063,9 @@
30633063
if (this.getFeatureSettingEnabled('safariObject')) {
30643064
this.safariObjectFix();
30653065
}
3066+
if (this.getFeatureSettingEnabled('messageHandlers')) {
3067+
this.messageHandlersFix();
3068+
}
30663069
}
30673070

30683071
/**
@@ -3152,6 +3155,48 @@
31523155
permissionsFix(settings);
31533156
}
31543157
}
3158+
3159+
/**
3160+
* Support for proxying `window.webkit.messageHandlers`
3161+
*/
3162+
messageHandlersFix () {
3163+
const settings = this.getFeatureSetting('messageHandlers');
3164+
3165+
// Do nothing if `messageHandlers` is absent
3166+
if (!globalThis.webkit?.messageHandlers) return
3167+
3168+
const proxy = new Proxy(globalThis.webkit.messageHandlers, {
3169+
get (target, messageName, receiver) {
3170+
const handlerName = String(messageName);
3171+
3172+
// handle known message names, such as DDG webkit messaging
3173+
if (settings.handlerStrategies.reflect.includes(handlerName)) {
3174+
return Reflect.get(target, messageName, receiver)
3175+
}
3176+
3177+
if (settings.handlerStrategies.undefined.includes(handlerName)) {
3178+
return undefined
3179+
}
3180+
3181+
if (settings.handlerStrategies.polyfill.includes('*') ||
3182+
settings.handlerStrategies.polyfill.includes(handlerName)
3183+
) {
3184+
return {
3185+
postMessage () {
3186+
return Promise.resolve({})
3187+
}
3188+
}
3189+
}
3190+
// if we get here, we couldn't handle the message handler name, so we opt for doing nothing.
3191+
// It's unlikely we'll ever reach here, since `["*"]' should be present
3192+
}
3193+
});
3194+
3195+
globalThis.webkit = {
3196+
...globalThis.webkit,
3197+
messageHandlers: proxy
3198+
};
3199+
}
31553200
}
31563201

31573202
function generateUniqueID () {

build/android/contentScope.js

Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7099,6 +7099,9 @@
70997099
if (this.getFeatureSettingEnabled('safariObject')) {
71007100
this.safariObjectFix();
71017101
}
7102+
if (this.getFeatureSettingEnabled('messageHandlers')) {
7103+
this.messageHandlersFix();
7104+
}
71027105
}
71037106

71047107
/**
@@ -7188,6 +7191,48 @@
71887191
permissionsFix(settings);
71897192
}
71907193
}
7194+
7195+
/**
7196+
* Support for proxying `window.webkit.messageHandlers`
7197+
*/
7198+
messageHandlersFix () {
7199+
const settings = this.getFeatureSetting('messageHandlers');
7200+
7201+
// Do nothing if `messageHandlers` is absent
7202+
if (!globalThis.webkit?.messageHandlers) return
7203+
7204+
const proxy = new Proxy(globalThis.webkit.messageHandlers, {
7205+
get (target, messageName, receiver) {
7206+
const handlerName = String(messageName);
7207+
7208+
// handle known message names, such as DDG webkit messaging
7209+
if (settings.handlerStrategies.reflect.includes(handlerName)) {
7210+
return Reflect.get(target, messageName, receiver)
7211+
}
7212+
7213+
if (settings.handlerStrategies.undefined.includes(handlerName)) {
7214+
return undefined
7215+
}
7216+
7217+
if (settings.handlerStrategies.polyfill.includes('*') ||
7218+
settings.handlerStrategies.polyfill.includes(handlerName)
7219+
) {
7220+
return {
7221+
postMessage () {
7222+
return Promise.resolve({})
7223+
}
7224+
}
7225+
}
7226+
// if we get here, we couldn't handle the message handler name, so we opt for doing nothing.
7227+
// It's unlikely we'll ever reach here, since `["*"]' should be present
7228+
}
7229+
});
7230+
7231+
globalThis.webkit = {
7232+
...globalThis.webkit,
7233+
messageHandlers: proxy
7234+
};
7235+
}
71917236
}
71927237

71937238
const logoImg = '';

build/contentScope.js

Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11439,6 +11439,9 @@
1143911439
if (this.getFeatureSettingEnabled('safariObject')) {
1144011440
this.safariObjectFix();
1144111441
}
11442+
if (this.getFeatureSettingEnabled('messageHandlers')) {
11443+
this.messageHandlersFix();
11444+
}
1144211445
}
1144311446

1144411447
/**
@@ -11528,6 +11531,48 @@
1152811531
permissionsFix(settings);
1152911532
}
1153011533
}
11534+
11535+
/**
11536+
* Support for proxying `window.webkit.messageHandlers`
11537+
*/
11538+
messageHandlersFix () {
11539+
const settings = this.getFeatureSetting('messageHandlers');
11540+
11541+
// Do nothing if `messageHandlers` is absent
11542+
if (!globalThis.webkit?.messageHandlers) return
11543+
11544+
const proxy = new Proxy(globalThis.webkit.messageHandlers, {
11545+
get (target, messageName, receiver) {
11546+
const handlerName = String(messageName);
11547+
11548+
// handle known message names, such as DDG webkit messaging
11549+
if (settings.handlerStrategies.reflect.includes(handlerName)) {
11550+
return Reflect.get(target, messageName, receiver)
11551+
}
11552+
11553+
if (settings.handlerStrategies.undefined.includes(handlerName)) {
11554+
return undefined
11555+
}
11556+
11557+
if (settings.handlerStrategies.polyfill.includes('*') ||
11558+
settings.handlerStrategies.polyfill.includes(handlerName)
11559+
) {
11560+
return {
11561+
postMessage () {
11562+
return Promise.resolve({})
11563+
}
11564+
}
11565+
}
11566+
// if we get here, we couldn't handle the message handler name, so we opt for doing nothing.
11567+
// It's unlikely we'll ever reach here, since `["*"]' should be present
11568+
}
11569+
});
11570+
11571+
globalThis.webkit = {
11572+
...globalThis.webkit,
11573+
messageHandlers: proxy
11574+
};
11575+
}
1153111576
}
1153211577

1153311578
const MSG_NAME_SET_VALUES = 'setUserValues';

build/integration/contentScope.js

Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11439,6 +11439,9 @@
1143911439
if (this.getFeatureSettingEnabled('safariObject')) {
1144011440
this.safariObjectFix();
1144111441
}
11442+
if (this.getFeatureSettingEnabled('messageHandlers')) {
11443+
this.messageHandlersFix();
11444+
}
1144211445
}
1144311446

1144411447
/**
@@ -11528,6 +11531,48 @@
1152811531
permissionsFix(settings);
1152911532
}
1153011533
}
11534+
11535+
/**
11536+
* Support for proxying `window.webkit.messageHandlers`
11537+
*/
11538+
messageHandlersFix () {
11539+
const settings = this.getFeatureSetting('messageHandlers');
11540+
11541+
// Do nothing if `messageHandlers` is absent
11542+
if (!globalThis.webkit?.messageHandlers) return
11543+
11544+
const proxy = new Proxy(globalThis.webkit.messageHandlers, {
11545+
get (target, messageName, receiver) {
11546+
const handlerName = String(messageName);
11547+
11548+
// handle known message names, such as DDG webkit messaging
11549+
if (settings.handlerStrategies.reflect.includes(handlerName)) {
11550+
return Reflect.get(target, messageName, receiver)
11551+
}
11552+
11553+
if (settings.handlerStrategies.undefined.includes(handlerName)) {
11554+
return undefined
11555+
}
11556+
11557+
if (settings.handlerStrategies.polyfill.includes('*') ||
11558+
settings.handlerStrategies.polyfill.includes(handlerName)
11559+
) {
11560+
return {
11561+
postMessage () {
11562+
return Promise.resolve({})
11563+
}
11564+
}
11565+
}
11566+
// if we get here, we couldn't handle the message handler name, so we opt for doing nothing.
11567+
// It's unlikely we'll ever reach here, since `["*"]' should be present
11568+
}
11569+
});
11570+
11571+
globalThis.webkit = {
11572+
...globalThis.webkit,
11573+
messageHandlers: proxy
11574+
};
11575+
}
1153111576
}
1153211577

1153311578
const MSG_NAME_SET_VALUES = 'setUserValues';

integration-test/playwright/type-helpers.mjs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -58,6 +58,7 @@ export class Build {
5858
get artifact () {
5959
const path = this.switch({
6060
windows: () => 'build/windows/contentScope.js',
61+
'apple': () => './Sources/ContentScopeScripts/dist/contentScope.js',
6162
'apple-isolated': () => './Sources/ContentScopeScripts/dist/contentScopeIsolated.js'
6263
})
6364
return readFileSync(path, 'utf8')
Lines changed: 113 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,113 @@
1+
import { test, expect } from '@playwright/test'
2+
import { readFileSync } from 'fs'
3+
import {
4+
mockWebkitMessaging,
5+
wrapWebkitScripts
6+
} from '@duckduckgo/messaging/lib/test-utils.mjs'
7+
import { perPlatform } from './type-helpers.mjs'
8+
9+
test('web compat', async ({ page }, testInfo) => {
10+
const webcompat = WebcompatSpec.create(page, testInfo)
11+
await webcompat.enabled()
12+
const results = await webcompat.collectResults()
13+
expect(results).toMatchObject({
14+
'webkit.messageHandlers - polyfill prevents throw': [{
15+
name: 'Error not thrown polyfil',
16+
result: true,
17+
expected: true
18+
}],
19+
'webkit.messageHandlers - undefined should throw': [{
20+
name: 'undefined handler should throw',
21+
result: true,
22+
expected: true
23+
}],
24+
'webkit.messageHandlers - reflected message': [{
25+
name: 'reflected message should pass through',
26+
result: 'test',
27+
expected: 'test'
28+
}]
29+
})
30+
})
31+
32+
export class WebcompatSpec {
33+
htmlPage = '/webcompat/index.html'
34+
config = './integration-test/test-pages/webcompat/config/message-handlers.json'
35+
36+
/**
37+
* @param {import('@playwright/test').Page} page
38+
* @param {import('./type-helpers.mjs').Build} build
39+
* @param {import('./type-helpers.mjs').PlatformInfo} platform
40+
*/
41+
constructor (page, build, platform) {
42+
this.page = page
43+
this.build = build
44+
this.platform = platform
45+
page.on('console', (msg) => {
46+
console.log(msg.type(), msg.text())
47+
})
48+
}
49+
50+
async enabled () {
51+
const config = JSON.parse(readFileSync(this.config, 'utf8'))
52+
await this.setup({ config })
53+
await this.page.goto(this.htmlPage)
54+
}
55+
56+
collectResults () {
57+
return this.page.evaluate(() => {
58+
return new Promise(resolve => {
59+
// @ts-expect-error - this is added by the test framework
60+
if (window.results) return resolve(window.results)
61+
window.addEventListener('results-ready', () => {
62+
// @ts-expect-error - this is added by the test framework
63+
resolve(window.results)
64+
})
65+
})
66+
})
67+
}
68+
69+
/**
70+
* @param {object} params
71+
* @param {Record<string, any>} params.config
72+
* @return {Promise<void>}
73+
*/
74+
async setup (params) {
75+
const { config } = params
76+
77+
// read the built file from disk and do replacements
78+
const injectedJS = wrapWebkitScripts(this.build.artifact, {
79+
$CONTENT_SCOPE$: config,
80+
$USER_UNPROTECTED_DOMAINS$: [],
81+
$USER_PREFERENCES$: {
82+
platform: { name: 'windows' },
83+
debug: true
84+
}
85+
})
86+
87+
await this.page.addInitScript(mockWebkitMessaging, {
88+
messagingContext: {
89+
env: 'development',
90+
context: 'contentScopeScripts',
91+
featureName: 'n/a'
92+
},
93+
responses: {}
94+
})
95+
96+
// attach the JS
97+
await this.page.addInitScript(injectedJS)
98+
}
99+
100+
/**
101+
* Helper for creating an instance per platform
102+
* @param {import('@playwright/test').Page} page
103+
* @param {import('@playwright/test').TestInfo} testInfo
104+
*/
105+
static create (page, testInfo) {
106+
// Read the configuration object to determine which platform we're testing against
107+
const {
108+
platformInfo,
109+
build
110+
} = perPlatform(testInfo.project.use)
111+
return new WebcompatSpec(page, build, platformInfo)
112+
}
113+
}
Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,34 @@
1+
{
2+
"unprotectedTemporary": [],
3+
"features": {
4+
"webCompat": {
5+
"exceptions": [],
6+
"state": "enabled",
7+
"settings": {
8+
"windowSizing": "enabled",
9+
"navigatorCredentials": "enabled",
10+
"safariObject": "enabled",
11+
"messageHandlers": {
12+
"state": "disabled",
13+
"handlerStrategies": {
14+
"reflect": ["trackerDetectedMessage", "printHandler", "specialPages"],
15+
"polyfill": ["*"],
16+
"undefined": ["jsHandler"]
17+
}
18+
},
19+
"domains": [
20+
{
21+
"domain": "localhost",
22+
"patchSettings": [
23+
{
24+
"op": "replace",
25+
"path": "/messageHandlers/state",
26+
"value": "enabled"
27+
}
28+
]
29+
}
30+
]
31+
}
32+
}
33+
}
34+
}

0 commit comments

Comments
 (0)