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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*-
* vim: sw=2 ts=2 sts=2
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
"use strict";
// STS parser tests
let sss = Cc["@mozilla.org/ssservice;1"].getService(Ci.nsISiteSecurityService);
function testSuccess(header, expectedMaxAge, expectedIncludeSubdomains) {
let dummyUri = Services.io.newURI("https://foo.com/bar.html");
let maxAge = {};
let includeSubdomains = {};
sss.processHeader(dummyUri, header, {}, maxAge, includeSubdomains);
equal(maxAge.value, expectedMaxAge, "Did not correctly parse maxAge");
equal(
includeSubdomains.value,
expectedIncludeSubdomains,
"Did not correctly parse presence/absence of includeSubdomains"
);
}
function testFailure(header) {
let dummyUri = Services.io.newURI("https://foo.com/bar.html");
let maxAge = {};
let includeSubdomains = {};
throws(
() => {
sss.processHeader(dummyUri, header, {}, maxAge, includeSubdomains);
},
/NS_ERROR_FAILURE/,
"Parsed invalid header: " + header
);
}
function run_test() {
// SHOULD SUCCEED:
testSuccess("max-age=100", 100, false);
testSuccess("max-age =100", 100, false);
testSuccess(" max-age=100", 100, false);
testSuccess("max-age = 100 ", 100, false);
testSuccess('max-age = "100" ', 100, false);
testSuccess('max-age="100"', 100, false);
testSuccess(' max-age ="100" ', 100, false);
testSuccess('\tmax-age\t=\t"100"\t', 100, false);
testSuccess("max-age = 100 ", 100, false);
testSuccess("maX-aGe=100", 100, false);
testSuccess("MAX-age =100", 100, false);
testSuccess("max-AGE=100", 100, false);
testSuccess("Max-Age = 100 ", 100, false);
testSuccess("MAX-AGE = 100 ", 100, false);
testSuccess("max-age=100;includeSubdomains", 100, true);
testSuccess("max-age=100\t; includeSubdomains", 100, true);
testSuccess(" max-age=100; includeSubdomains", 100, true);
testSuccess("max-age = 100 ; includeSubdomains", 100, true);
testSuccess(
"max-age = 100 ; includeSubdomains",
100,
true
);
testSuccess("maX-aGe=100; includeSUBDOMAINS", 100, true);
testSuccess("MAX-age =100; includeSubDomains", 100, true);
testSuccess("max-AGE=100; iNcLuDeSuBdoMaInS", 100, true);
testSuccess("Max-Age = 100; includesubdomains ", 100, true);
testSuccess("INCLUDESUBDOMAINS;MaX-AgE = 100 ", 100, true);
// Turns out, the actual directive is entirely optional (hence the
// trailing semicolon)
testSuccess("max-age=100;includeSubdomains;", 100, true);
// these are weird tests, but are testing that some extended syntax is
// still allowed (but it is ignored)
testSuccess("max-age=100 ; includesubdomainsSomeStuff", 100, false);
testSuccess(
"\r\n\t\t \tcompletelyUnrelated = foobar; max-age= 34520103" +
"\t \t; alsoUnrelated;asIsThis;\tincludeSubdomains\t\t \t",
34520103,
true
);
testSuccess('max-age=100; unrelated="quoted \\"thingy\\""', 100, false);
// SHOULD FAIL:
// invalid max-ages
testFailure("max-age");
testFailure("max-age ");
testFailure("max-age=p");
testFailure("max-age=*1p2");
testFailure("max-age=.20032");
testFailure("max-age=!20032");
testFailure("max-age==20032");
// invalid headers
testFailure("foobar");
testFailure("maxage=100");
testFailure("maxa-ge=100");
testFailure("max-ag=100");
testFailure("includesubdomains");
testFailure(";");
testFailure('max-age="100');
// The max-age directive here doesn't conform to the spec, so it MUST
// be ignored. Consequently, the REQUIRED max-age directive is not
// present in this header, and so it is invalid.
testFailure("max-age=100, max-age=200; includeSubdomains");
testFailure("max-age=100 includesubdomains");
testFailure("max-age=100 bar foo");
testFailure("max-age=100randomstuffhere");
// All directives MUST appear only once in an STS header field.
testFailure("max-age=100; max-age=200");
testFailure("includeSubdomains; max-age=200; includeSubdomains");
testFailure("max-age=200; includeSubdomains; includeSubdomains");
// The includeSubdomains directive is valueless.
testFailure("max-age=100; includeSubdomains=unexpected");
// LWS must have at least one space or horizontal tab
testFailure("\r\nmax-age=200");
}
|