blob: d770278401fc765db7fb68b64e2dfc16dade633f (
plain)
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
|
<!DOCTYPE html>
<html>
<head>
<!-- Programmatically converted from a WebKit Reftest, please forgive resulting idiosyncracies.-->
<title>object-src-applet-archive-codebase</title>
<script src="/resources/testharness.js"></script>
<script src="/resources/testharnessreport.js"></script>
<script src='../support/logTest.sub.js?logs=["PASS"]'></script>
<script src="../support/alertAssert.sub.js?alerts=[]"></script>
<!-- enforcing policy:
object-src 'none'; script-src 'self' 'unsafe-inline'; connect-src 'self';
-->
</head>
<body>
<script>
var len = navigator.mimeTypes.length;
var allTypes = "";
var appletMimeType = "application/x-java-applet";
for (var i = 0; i < len; i++) {
allTypes += navigator.mimeTypes[i].type + ';';
}
if (allTypes.indexOf(appletMimeType) == -1) {
t_log.set_status(t_log.NOTRUN, "No Java Plugin, cannot run test.");
t_log.phase = t_log.phases.HAS_RESULT;
t_log.done();
} else {
var s = document.createElement('script');
s.src = "../support/checkReport.sub.js?reportExists=true&reportField=violated-directive&reportValue=object-src%20'none'";
document.body.appendChild(s);
}
</script>
This test passes if there is a CSP violation saying the plugin was blocked.
<applet code="TestThingie" archive="archive.jar" codebase="/plugins/codebase/" id="appletObject" onload="log('FAIL')" onerror="log('PASS')"></applet>
<div id="log"></div>
</body>
</html>
|