mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-29 21:25:35 +00:00
d144ed6ded
Adds security/sandbox/test/browser_content_sandbox_fs.js for validating content sandbox file I/O restrictions. Adds security/sandbox/test/browser_content_sandbox_syscalls.js for validating OS-level calls are sandboxed as intended. Uses js-ctypes to invoke native library routines. Windows tests yet to be added here. Adds security/sandbox/test/browser_content_sandbox_utils.js with some shared utility functions. MozReview-Commit-ID: 5zfCLctfuN5 --HG-- extra : rebase_source : 4edd14220bcd18b15a3c522e44d7223547a79f43
58 lines
2.0 KiB
JavaScript
58 lines
2.0 KiB
JavaScript
/* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/ */
|
|
|
|
const uuidGenerator = Cc["@mozilla.org/uuid-generator;1"]
|
|
.getService(Ci.nsIUUIDGenerator);
|
|
|
|
/*
|
|
* Utility functions for the browser content sandbox tests.
|
|
*/
|
|
|
|
function isMac() { return Services.appinfo.OS == "Darwin" }
|
|
function isWin() { return Services.appinfo.OS == "WINNT" }
|
|
function isLinux() { return Services.appinfo.OS == "Linux" }
|
|
|
|
function isNightly() {
|
|
let version = SpecialPowers.Cc["@mozilla.org/xre/app-info;1"].
|
|
getService(SpecialPowers.Ci.nsIXULAppInfo).version;
|
|
return (version.endsWith("a1"));
|
|
}
|
|
|
|
function uuid() {
|
|
return uuidGenerator.generateUUID().toString();
|
|
}
|
|
|
|
// Returns a file object for a new file in the home dir ($HOME/<UUID>).
|
|
function fileInHomeDir() {
|
|
// get home directory, make sure it exists
|
|
let homeDir = Services.dirsvc.get("Home", Ci.nsILocalFile);
|
|
Assert.ok(homeDir.exists(), "Home dir exists");
|
|
Assert.ok(homeDir.isDirectory(), "Home dir is a directory");
|
|
|
|
// build a file object for a new file named $HOME/<UUID>
|
|
let homeFile = homeDir.clone();
|
|
homeFile.appendRelativePath(uuid());
|
|
Assert.ok(!homeFile.exists(), homeFile.path + " does not exist");
|
|
return (homeFile);
|
|
}
|
|
|
|
// Returns a file object for a new file in the content temp dir (.../<UUID>).
|
|
function fileInTempDir() {
|
|
let contentTempKey = "ContentTmpD";
|
|
if (Services.appinfo.OS == "Linux") {
|
|
// Linux builds don't use the content-specific temp key
|
|
contentTempKey = "TmpD";
|
|
}
|
|
|
|
// get the content temp dir, make sure it exists
|
|
let ctmp = Services.dirsvc.get(contentTempKey, Ci.nsILocalFile);
|
|
Assert.ok(ctmp.exists(), "Content temp dir exists");
|
|
Assert.ok(ctmp.isDirectory(), "Content temp dir is a directory");
|
|
|
|
// build a file object for a new file in content temp
|
|
let tempFile = ctmp.clone();
|
|
tempFile.appendRelativePath(uuid());
|
|
Assert.ok(!tempFile.exists(), tempFile.path + " does not exist");
|
|
return (tempFile);
|
|
}
|