(async function(/** @type {import('test_runner').TestRunner} */ testRunner) {
const {page, session, dp} = await testRunner.startBlank(
`Verifies that mixed content issue is created from mixed content js within an oop iframe\n`);
let requestId;
let frameId;
let issues = [];
let count = 0;
let eventReceived = null;
let allEventsReceived = new Promise(resolve => eventReceived = () => {if (++count == 3) resolve();
});
await dp.Network.enable();
await dp.Audits.enable();
await dp.Target.setAutoAttach({autoAttach: true, waitForDebuggerOnStart: false, flatten: true});
dp.Target.onAttachedToTarget(async e => {
const dp = session.createChild(e.params.sessionId).protocol;
// We expect to receive two issues, one for a speculative prefetch and another for the actual fetch.
dp.Audits.onIssueAdded(issue => {
issues.push(issue.params);
eventReceived();
});
dp.Network.onRequestWillBeSent(async event => {
if (event.params.request.url === 'http://example.test:8000/inspector-protocol/resources/blank.js') {
frameId = event.params.frameId;
requestId = event.params.requestId;
eventReceived();
}
});
await dp.Network.enable();
await dp.Audits.enable();
});
await page.navigate('https://devtools.test:8443/inspector-protocol/resources/mixed-content-within-oopif.html');
await allEventsReceived;
// No sorting necessary, both issues are identical except requestId
issues.forEach(issue => testRunner.log(issue, "Inspector issue: ", ["frameId", "requestId"]));
const match = issues.find(issue =>
issue.issue?.details?.mixedContentIssueDetails?.request?.requestId === requestId
&& issue.issue?.details?.mixedContentIssueDetails?.frame?.frameId === frameId
);
testRunner.log(`requestIds and frameIds match: ${!!match}`)
testRunner.completeTest();
})