зеркало из https://github.com/mozilla/gecko-dev.git
Merge b-s to m-c
This commit is contained in:
Коммит
f5d2d9debe
|
@ -91,7 +91,6 @@ if __name__ == '__main__':
|
|||
t.start()
|
||||
|
||||
automation.setServerInfo("localhost", PORT)
|
||||
automation.initializeProfile(PROFILE_DIRECTORY)
|
||||
browserEnv = automation.environment()
|
||||
browserEnv["XPCOM_DEBUG_BREAK"] = "warn"
|
||||
browserEnv["MOZ_JAR_LOG_DIR"] = MOZ_JAR_LOG_DIR
|
||||
|
@ -102,6 +101,7 @@ if __name__ == '__main__':
|
|||
for i in range(0, num_runs):
|
||||
if num_runs != 1:
|
||||
print "Starting profiling run %d of %d" % (i + 1, num_runs)
|
||||
automation.initializeProfile(PROFILE_DIRECTORY)
|
||||
status = automation.runApp(url, browserEnv, appPath, PROFILE_DIRECTORY, {},
|
||||
debuggerInfo=debuggerInfo,
|
||||
# the profiling HTML doesn't output anything,
|
||||
|
|
|
@ -424,6 +424,11 @@ nsDOMFile::Initialize(nsISupports* aOwner,
|
|||
NS_ENSURE_SUCCESS(rv, rv);
|
||||
NS_ENSURE_TRUE(exists, NS_ERROR_FILE_NOT_FOUND);
|
||||
|
||||
PRBool isDir;
|
||||
rv = file->IsDirectory(&isDir);
|
||||
NS_ENSURE_SUCCESS(rv, rv);
|
||||
NS_ENSURE_FALSE(isDir, NS_ERROR_FILE_IS_DIRECTORY);
|
||||
|
||||
mFile = file;
|
||||
return NS_OK;
|
||||
}
|
||||
|
|
|
@ -64,9 +64,18 @@ try {
|
|||
var nonexistentfile = new File("i/sure/hope/this/does/not/exist/anywhere.txt");
|
||||
ok(false, "This should never be reached!");
|
||||
} catch (e) {
|
||||
ok(true, "Attempt to construct a non-existent file should fail.")
|
||||
ok(true, "Attempt to construct a non-existent file should fail.");
|
||||
}
|
||||
|
||||
try {
|
||||
var dir = Components.classes["@mozilla.org/file/directory_service;1"]
|
||||
.getService(Components.interfaces.nsIProperties)
|
||||
.get("CurWorkD", Components.interfaces.nsIFile);
|
||||
var dirfile = new File(dir);
|
||||
ok(false, "This should never be reached!");
|
||||
} catch (e) {
|
||||
ok(true, "Attempt to construct a file from a directory should fail.");
|
||||
}
|
||||
]]>
|
||||
</script>
|
||||
|
||||
|
|
|
@ -71,6 +71,7 @@
|
|||
#include "nsIFileURL.h"
|
||||
#include "nsIJARURI.h"
|
||||
#include "nsNetUtil.h"
|
||||
#include "nsDOMFile.h"
|
||||
#include "jsxdrapi.h"
|
||||
#include "jscompartment.h"
|
||||
#include "jsprf.h"
|
||||
|
@ -233,11 +234,60 @@ Btoa(JSContext *cx, uintN argc, jsval *vp)
|
|||
return nsXPConnect::Base64Encode(cx, JS_ARGV(cx, vp)[0], &JS_RVAL(cx, vp));
|
||||
}
|
||||
|
||||
static JSBool
|
||||
File(JSContext *cx, uintN argc, jsval *vp)
|
||||
{
|
||||
nsresult rv;
|
||||
|
||||
if (!argc) {
|
||||
XPCThrower::Throw(NS_ERROR_UNEXPECTED, cx);
|
||||
return JS_FALSE;
|
||||
}
|
||||
|
||||
nsCOMPtr<nsISupports> native;
|
||||
rv = nsDOMFile::NewFile(getter_AddRefs(native));
|
||||
if (NS_FAILED(rv)) {
|
||||
XPCThrower::Throw(rv, cx);
|
||||
return JS_FALSE;
|
||||
}
|
||||
|
||||
nsCOMPtr<nsIJSNativeInitializer> initializer = do_QueryInterface(native);
|
||||
NS_ASSERTION(initializer, "what?");
|
||||
|
||||
rv = initializer->Initialize(nsnull, cx, nsnull, argc, JS_ARGV(cx, vp));
|
||||
if (NS_FAILED(rv)) {
|
||||
XPCThrower::Throw(rv, cx);
|
||||
return JS_FALSE;
|
||||
}
|
||||
|
||||
nsXPConnect* xpc = nsXPConnect::GetXPConnect();
|
||||
if (!xpc) {
|
||||
XPCThrower::Throw(NS_ERROR_UNEXPECTED, cx);
|
||||
return JS_FALSE;
|
||||
}
|
||||
|
||||
JSObject* glob = JS_GetGlobalForScopeChain(cx);
|
||||
|
||||
nsCOMPtr<nsIXPConnectJSObjectHolder> holder;
|
||||
jsval retval;
|
||||
rv = xpc->WrapNativeToJSVal(cx, glob, native, nsnull,
|
||||
&NS_GET_IID(nsISupports),
|
||||
PR_TRUE, &retval, nsnull);
|
||||
if (NS_FAILED(rv)) {
|
||||
XPCThrower::Throw(rv, cx);
|
||||
return JS_FALSE;
|
||||
}
|
||||
|
||||
JS_SET_RVAL(cx, vp, retval);
|
||||
return JS_TRUE;
|
||||
}
|
||||
|
||||
static JSFunctionSpec gGlobalFun[] = {
|
||||
{"dump", Dump, 1,0},
|
||||
{"debug", Debug, 1,0},
|
||||
{"atob", Atob, 1,0},
|
||||
{"btoa", Btoa, 1,0},
|
||||
{"File", File, 1,JSFUN_CONSTRUCTOR},
|
||||
#ifdef MOZ_CALLGRIND
|
||||
{"startCallgrind", js_StartCallgrind, 0,0},
|
||||
{"stopCallgrind", js_StopCallgrind, 0,0},
|
||||
|
|
|
@ -0,0 +1,152 @@
|
|||
/* ***** BEGIN LICENSE BLOCK *****
|
||||
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
||||
*
|
||||
* The contents of this file are subject to the Mozilla Public License Version
|
||||
* 1.1 (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
* http://www.mozilla.org/MPL/
|
||||
*
|
||||
* Software distributed under the License is distributed on an "AS IS" basis,
|
||||
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
||||
* for the specific language governing rights and limitations under the
|
||||
* License.
|
||||
*
|
||||
* The Original Code is Component Scope File Constructor test code.
|
||||
*
|
||||
* The Initial Developer of the Original Code is the Mozilla Foundation.
|
||||
* Portions created by the Initial Developer are Copyright (C) 2011.
|
||||
* the Initial Developer. All Rights Reserved.
|
||||
*
|
||||
* Contributor(s):
|
||||
*
|
||||
* Alternatively, the contents of this file may be used under the terms of
|
||||
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
||||
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
||||
* in which case the provisions of the GPL or the LGPL are applicable instead
|
||||
* of those above. If you wish to allow use of your version of this file only
|
||||
* under the terms of either the GPL or the LGPL, and not to allow others to
|
||||
* use your version of this file under the terms of the MPL, indicate your
|
||||
* decision by deleting the provisions above and replace them with the notice
|
||||
* and other provisions required by the GPL or the LGPL. If you do not delete
|
||||
* the provisions above, a recipient may use your version of this file under
|
||||
* the terms of any one of the MPL, the GPL or the LGPL.
|
||||
*
|
||||
* ***** END LICENSE BLOCK ***** */
|
||||
|
||||
Components.utils.import("resource://gre/modules/XPCOMUtils.jsm");
|
||||
|
||||
const Ci = Components.interfaces;
|
||||
|
||||
function do_check_true(cond, text) {
|
||||
// we don't have the test harness' utilities in this scope, so we need this
|
||||
// little helper. In the failure case, the exception is propagated to the
|
||||
// caller in the main run_test() function, and the test fails.
|
||||
if (!cond)
|
||||
throw "Failed check: " + text;
|
||||
}
|
||||
|
||||
function FileComponent() {
|
||||
this.wrappedJSObject = this;
|
||||
}
|
||||
FileComponent.prototype =
|
||||
{
|
||||
doTest: function() {
|
||||
// throw if anything goes wrong
|
||||
|
||||
// find the current directory path
|
||||
var file = Components.classes["@mozilla.org/file/directory_service;1"]
|
||||
.getService(Ci.nsIProperties)
|
||||
.get("CurWorkD", Ci.nsIFile);
|
||||
file.append("xpcshell.ini");
|
||||
|
||||
// should be able to construct a file
|
||||
var f1 = File(file.path);
|
||||
// with either constructor syntax
|
||||
var f2 = new File(file.path);
|
||||
// and with nsIFiles
|
||||
var f3 = File(file);
|
||||
var f4 = new File(file);
|
||||
// and extra args are ignored
|
||||
var f5 = File(file.path, "foopy");
|
||||
var f6 = new File(file, Date(123123154));
|
||||
|
||||
// do some tests
|
||||
do_check_true(f1 instanceof Ci.nsIDOMFile, "Should be a DOM File");
|
||||
do_check_true(f2 instanceof Ci.nsIDOMFile, "Should be a DOM File");
|
||||
do_check_true(f3 instanceof Ci.nsIDOMFile, "Should be a DOM File");
|
||||
do_check_true(f4 instanceof Ci.nsIDOMFile, "Should be a DOM File");
|
||||
do_check_true(f5 instanceof Ci.nsIDOMFile, "Should be a DOM File");
|
||||
do_check_true(f6 instanceof Ci.nsIDOMFile, "Should be a DOM File");
|
||||
|
||||
do_check_true(f1.name == "xpcshell.ini", "Should be the right file");
|
||||
do_check_true(f2.name == "xpcshell.ini", "Should be the right file");
|
||||
do_check_true(f3.name == "xpcshell.ini", "Should be the right file");
|
||||
do_check_true(f4.name == "xpcshell.ini", "Should be the right file");
|
||||
do_check_true(f5.name == "xpcshell.ini", "Should be the right file");
|
||||
do_check_true(f6.name == "xpcshell.ini", "Should be the right file");
|
||||
|
||||
do_check_true(f1.type = "text/plain", "Should be the right type");
|
||||
do_check_true(f2.type = "text/plain", "Should be the right type");
|
||||
do_check_true(f3.type = "text/plain", "Should be the right type");
|
||||
do_check_true(f4.type = "text/plain", "Should be the right type");
|
||||
do_check_true(f5.type = "text/plain", "Should be the right type");
|
||||
do_check_true(f6.type = "text/plain", "Should be the right type");
|
||||
|
||||
var threw = false;
|
||||
try {
|
||||
// Needs a ctor argument
|
||||
var f7 = File();
|
||||
} catch (e) {
|
||||
threw = true;
|
||||
}
|
||||
do_check_true(threw, "No ctor arguments should throw");
|
||||
|
||||
var threw = false;
|
||||
try {
|
||||
// Needs a valid ctor argument
|
||||
var f7 = File(Date(132131532));
|
||||
} catch (e) {
|
||||
threw = true;
|
||||
}
|
||||
do_check_true(threw, "Passing a random object should fail");
|
||||
|
||||
var threw = false
|
||||
try {
|
||||
// Directories fail
|
||||
var dir = Components.classes["@mozilla.org/file/directory_service;1"]
|
||||
.getService(Ci.nsIProperties)
|
||||
.get("CurWorkD", Ci.nsIFile);
|
||||
var f7 = File(dir)
|
||||
} catch (e) {
|
||||
threw = true;
|
||||
}
|
||||
do_check_true(threw, "Can't create a File object for a directory");
|
||||
|
||||
return true;
|
||||
},
|
||||
|
||||
// nsIClassInfo + information for XPCOM registration code in XPCOMUtils.jsm
|
||||
classDescription: "File in components scope code",
|
||||
classID: Components.ID("{da332370-91d4-464f-a730-018e14769cab}"),
|
||||
contractID: "@mozilla.org/tests/component-file;1",
|
||||
|
||||
// nsIClassInfo
|
||||
implementationLanguage: Components.interfaces.nsIProgrammingLanguage.JAVASCRIPT,
|
||||
flags: 0,
|
||||
|
||||
getInterfaces: function getInterfaces(aCount) {
|
||||
var interfaces = [Components.interfaces.nsIClassInfo];
|
||||
aCount.value = interfaces.length;
|
||||
return interfaces;
|
||||
},
|
||||
|
||||
getHelperForLanguage: function getHelperForLanguage(aLanguage) {
|
||||
return null;
|
||||
},
|
||||
|
||||
// nsISupports
|
||||
QueryInterface: XPCOMUtils.generateQI([Components.interfaces.nsIClassInfo])
|
||||
};
|
||||
|
||||
var gComponentsArray = [FileComponent];
|
||||
var NSGetFactory = XPCOMUtils.generateNSGetFactory(gComponentsArray);
|
|
@ -0,0 +1,2 @@
|
|||
component {da332370-91d4-464f-a730-018e14769cab} component-file.js
|
||||
contract @mozilla.org/tests/component-file;1 {da332370-91d4-464f-a730-018e14769cab}
|
|
@ -0,0 +1,50 @@
|
|||
/*
|
||||
* ***** BEGIN LICENSE BLOCK *****
|
||||
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
||||
*
|
||||
* The contents of this file are subject to the Mozilla Public License Version
|
||||
* 1.1 (the "License"); you may not use this file except in compliance with
|
||||
* the License. You may obtain a copy of the License at
|
||||
* http://www.mozilla.org/MPL/
|
||||
*
|
||||
* Software distributed under the License is distributed on an "AS IS" basis,
|
||||
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
||||
* for the specific language governing rights and limitations under the
|
||||
* License.
|
||||
*
|
||||
* The Original Code is Mozilla code.
|
||||
*
|
||||
* The Initial Developer of the Original Code is
|
||||
* Mozilla Foundation.
|
||||
* Portions created by the Initial Developer are Copyright (C) 2007
|
||||
* the Initial Developer. All Rights Reserved.
|
||||
*
|
||||
* Contributor(s):
|
||||
* Robert Sayre <sayrer@gmail.com> (original author)
|
||||
* Alexander J. Vincent <ajvincent@gmail.com>
|
||||
*
|
||||
* Alternatively, the contents of this file may be used under the terms of
|
||||
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
||||
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
||||
* in which case the provisions of the GPL or the LGPL are applicable instead
|
||||
* of those above. If you wish to allow use of your version of this file only
|
||||
* under the terms of either the GPL or the LGPL, and not to allow others to
|
||||
* use your version of this file under the terms of the MPL, indicate your
|
||||
* decision by deleting the provisions above and replace them with the notice
|
||||
* and other provisions required by the GPL or the LGPL. If you do not delete
|
||||
* the provisions above, a recipient may use your version of this file under
|
||||
* the terms of any one of the MPL, the GPL or the LGPL.
|
||||
*
|
||||
* ***** END LICENSE BLOCK ***** */
|
||||
|
||||
function run_test() {
|
||||
do_load_manifest("component-file.manifest");
|
||||
const contractID = "@mozilla.org/tests/component-file;1";
|
||||
do_check_true(contractID in Components.classes);
|
||||
var foo = Components.classes[contractID]
|
||||
.createInstance(Components.interfaces.nsIClassInfo);
|
||||
do_check_true(Boolean(foo));
|
||||
do_check_true(foo.contractID == contractID);
|
||||
do_check_true(!!foo.wrappedJSObject);
|
||||
do_check_true(foo.wrappedJSObject.doTest());
|
||||
}
|
|
@ -10,6 +10,7 @@ tail =
|
|||
[test_bug608142.js]
|
||||
[test_bug641378.js]
|
||||
[test_bug_442086.js]
|
||||
[test_file.js]
|
||||
[test_import.js]
|
||||
[test_js_weak_references.js]
|
||||
[test_localeCompare.js]
|
||||
|
|
|
@ -77,7 +77,6 @@
|
|||
#include "prprf.h"
|
||||
#include "prnetdb.h"
|
||||
#include "zlib.h"
|
||||
#include "mozilla/Preferences.h"
|
||||
|
||||
// Needed to interpert mozIStorageConnection::GetLastError
|
||||
#include <sqlite3.h>
|
||||
|
@ -1799,6 +1798,7 @@ nsUrlClassifierDBServiceWorker::GetTables(nsIUrlClassifierCallback* c)
|
|||
|
||||
nsresult rv = OpenDb();
|
||||
if (NS_FAILED(rv)) {
|
||||
NS_ERROR("Unable to open database");
|
||||
return NS_ERROR_FAILURE;
|
||||
}
|
||||
|
||||
|
@ -2913,6 +2913,7 @@ nsUrlClassifierDBServiceWorker::BeginUpdate(nsIUrlClassifierUpdateObserver *obse
|
|||
|
||||
nsresult rv = OpenDb();
|
||||
if (NS_FAILED(rv)) {
|
||||
NS_ERROR("Unable to open database");
|
||||
return NS_ERROR_FAILURE;
|
||||
}
|
||||
|
||||
|
@ -3060,6 +3061,7 @@ nsUrlClassifierDBServiceWorker::UpdateStream(const nsACString& chunk)
|
|||
LOG(("Update from Stream."));
|
||||
nsresult rv = OpenDb();
|
||||
if (NS_FAILED(rv)) {
|
||||
NS_ERROR("Unable to open database");
|
||||
return NS_ERROR_FAILURE;
|
||||
}
|
||||
|
||||
|
@ -3365,15 +3367,6 @@ nsUrlClassifierDBServiceWorker::OpenDb()
|
|||
if (mConnection)
|
||||
return NS_OK;
|
||||
|
||||
// If we're turned off, refuse to open the DB
|
||||
PRBool openDB =
|
||||
Preferences::GetBool(CHECK_MALWARE_PREF, CHECK_MALWARE_DEFAULT) ||
|
||||
Preferences::GetBool(CHECK_PHISHING_PREF, CHECK_PHISHING_DEFAULT);
|
||||
if (!openDB) {
|
||||
NS_WARNING("Not opening url-classifier DB");
|
||||
return NS_ERROR_NOT_AVAILABLE;
|
||||
}
|
||||
|
||||
LOG(("Opening db\n"));
|
||||
|
||||
nsresult rv;
|
||||
|
|
Загрузка…
Ссылка в новой задаче