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
|
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
// Test devtools/client/netmonitor/src/utils/request-utils.js function
// |parseJSON| ensure that it correctly handles plain JSON, Base 64
// encoded JSON, and JSON that has XSSI protection prepended to it
"use strict";
const { require } = ChromeUtils.importESModule(
"resource://devtools/shared/loader/Loader.sys.mjs"
);
const {
parseJSON,
} = require("resource://devtools/client/netmonitor/src/utils/request-utils.js");
function run_test() {
const validJSON = '{"item":{"subitem":true},"seconditem":"bar"}';
const base64JSON = btoa(validJSON);
const parsedJSON = { item: { subitem: true }, seconditem: "bar" };
const googleStyleXSSI = ")]}'\n";
const facebookStyleXSSI = "for (;;);";
const notRealXSSIPrevention = "sdgijsdjg";
const while1XSSIPrevention = "while(1)";
const parsedValidJSON = parseJSON(validJSON);
info(JSON.stringify(parsedValidJSON));
ok(
parsedValidJSON.json.item.subitem == parsedJSON.item.subitem &&
parsedValidJSON.json.seconditem == parsedJSON.seconditem,
"plain JSON is parsed correctly"
);
const parsedBase64JSON = parseJSON(base64JSON);
ok(
parsedBase64JSON.json.item.subitem === parsedJSON.item.subitem &&
parsedBase64JSON.json.seconditem === parsedJSON.seconditem,
"base64 encoded JSON is parsed correctly"
);
const parsedGoogleStyleXSSIJSON = parseJSON(googleStyleXSSI + validJSON);
ok(
parsedGoogleStyleXSSIJSON.strippedChars === googleStyleXSSI &&
parsedGoogleStyleXSSIJSON.error === void 0 &&
parsedGoogleStyleXSSIJSON.json.item.subitem === parsedJSON.item.subitem &&
parsedGoogleStyleXSSIJSON.json.seconditem === parsedJSON.seconditem,
"Google style XSSI sequence correctly removed and returned"
);
const parsedFacebookStyleXSSIJSON = parseJSON(facebookStyleXSSI + validJSON);
ok(
parsedFacebookStyleXSSIJSON.strippedChars === facebookStyleXSSI &&
parsedFacebookStyleXSSIJSON.error === void 0 &&
parsedFacebookStyleXSSIJSON.json.item.subitem ===
parsedJSON.item.subitem &&
parsedFacebookStyleXSSIJSON.json.seconditem === parsedJSON.seconditem,
"Facebook style XSSI sequence correctly removed and returned"
);
const parsedWhileXSSIJSON = parseJSON(while1XSSIPrevention + validJSON);
ok(
parsedWhileXSSIJSON.strippedChars === while1XSSIPrevention &&
parsedWhileXSSIJSON.error === void 0 &&
parsedWhileXSSIJSON.json.item.subitem === parsedJSON.item.subitem &&
parsedWhileXSSIJSON.json.seconditem === parsedJSON.seconditem,
"While XSSI sequence correctly removed and returned"
);
const parsedInvalidJson = parseJSON(notRealXSSIPrevention + validJSON);
ok(
!parsedInvalidJson.json && !parsedInvalidJson.strippedChars,
"Parsed invalid JSON does not return a data object or strippedChars"
);
equal(
parsedInvalidJson.error.name,
"SyntaxError",
"Parsing invalid JSON yeilds a SyntaxError"
);
}
|