Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(297)

Unified Diff: LayoutTests/http/tests/security/subresourceIntegrity/subresource-integrity-fetch.html

Issue 1279163005: Initial Fetch integration for Subresource Integrity (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | Source/core/dom/ScriptLoader.cpp » ('j') | Source/modules/fetch/BodyStreamBuffer.h » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: LayoutTests/http/tests/security/subresourceIntegrity/subresource-integrity-fetch.html
diff --git a/LayoutTests/http/tests/security/subresourceIntegrity/subresource-integrity-fetch.html b/LayoutTests/http/tests/security/subresourceIntegrity/subresource-integrity-fetch.html
new file mode 100644
index 0000000000000000000000000000000000000000..6b872116b181ef1d9eaa5f69871b422cf8fb6eb7
--- /dev/null
+++ b/LayoutTests/http/tests/security/subresourceIntegrity/subresource-integrity-fetch.html
@@ -0,0 +1,46 @@
+<!DOCTYPE html>
+<html>
+<head>
+<title>Tests integrity enforcement on fetch()</title>
+<script src="/resources/testharness.js"></script>
+<script src="/resources/testharnessreport.js"></script>
+</head>
+<body>
+<script>
+var SRITest = function(pass, name, src, integrity) {
+ this.pass = pass;
+ this.name = name;
+ this.src = src;
+ this.integrity = integrity;
+}
+SRITest.prototype.execute = function() {
+ var test = async_test(this.name);
+ var pass = this.pass;
+ var integrity = this.integrity;
+ var options = {};
+ if (integrity !== '') {
+ options.integrity = integrity;
+ }
+ fetch(this.src, options)
+ .then(test.step_func(function(response) {
+ if (pass) {
+ test.done();
+ } else {
+ assert_unreached("Response on bad fetch.");
+ }
+ }))
+ .catch(test.step_func(function(error) {
+ if (pass) {
+ assert_unreached("Network error on good fetch.");
+ } else {
+ test.done();
+ }
+ }));
+}
+
+new SRITest(true, 'No integrity', 'call-success.js', '').execute();
+new SRITest(true, 'Good integrity', 'call-success.js', 'sha256-B0/62fJSJFrdjEFR9ba04m/D+LHQ+zG6PGcaR0Trpxg=').execute();
+new SRITest(false, 'Bad integrity', 'call-success.js', 'sha256-deadbeef').execute();
+</script>
+</body>
+</html>
« no previous file with comments | « no previous file | Source/core/dom/ScriptLoader.cpp » ('j') | Source/modules/fetch/BodyStreamBuffer.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698