Backed out changeset 752dca088d71 (Bug 865252) for xpcshell bustage

This commit is contained in:
Joe Walker 2013-05-11 12:08:58 +01:00
Родитель e6523c11ef
Коммит bc99487254
4 изменённых файлов: 20 добавлений и 114 удалений

Просмотреть файл

@ -1381,13 +1381,13 @@ PauseScopedActor.prototype = {
* The url of the source we are representing.
* @param aThreadActor ThreadActor
* The current thread actor.
* @param aSourceMap SourceMapConsumer
* Optional. The source map that introduced this source, if available.
* @param aSourceContent String
* Optional. The contents of the source, if we already know it.
*/
function SourceActor(aUrl, aThreadActor, aSourceMap=null) {
function SourceActor(aUrl, aThreadActor, aSourceContent=null) {
this._threadActor = aThreadActor;
this._url = aUrl;
this._sourceMap = aSourceMap;
this._sourceContent = aSourceContent;
}
SourceActor.prototype = {
@ -1415,33 +1415,25 @@ SourceActor.prototype = {
* Handler for the "source" packet.
*/
onSource: function SA_onSource(aRequest) {
let sourceContent = null;
if (this._sourceMap) {
sourceContent = this._sourceMap.sourceContentFor(this._url);
}
if (sourceContent) {
if (this._sourceContent) {
return {
from: this.actorID,
source: this.threadActor.createValueGrip(
sourceContent, this.threadActor.threadLifetimePool)
this._sourceContent, this.threadActor.threadLifetimePool)
};
}
// XXX bug 865252: Don't load from the cache if this is a source mapped
// source because we can't guarantee that the cache has the most up to date
// content for this source like we can if it isn't source mapped.
return fetch(this._url, { loadFromCache: !this._sourceMap })
.then((aSource) => {
return fetch(this._url)
.then(function(aSource) {
return this.threadActor.createValueGrip(
aSource, this.threadActor.threadLifetimePool);
})
.then((aSourceGrip) => {
}.bind(this))
.then(function (aSourceGrip) {
return {
from: this.actorID,
source: aSourceGrip
};
}, (aError) => {
}.bind(this), function (aError) {
let msg = "Got an exception during SA_onSource: " + aError +
"\n" + aError.stack;
Cu.reportError(msg);
@ -1451,7 +1443,7 @@ SourceActor.prototype = {
"error": "loadSourceError",
"message": "Could not load the source for " + this._url + "."
};
});
}.bind(this));
}
};
@ -2452,11 +2444,11 @@ ThreadSources.prototype = {
*
* @param String aURL
* The source URL.
* @param optional SourceMapConsumer aSourceMap
* The source map that introduced this source.
* @param String aSourceContent
* Optional. The content of the source, if we already know it.
* @returns a SourceActor representing the source or null.
*/
source: function TS_source(aURL, aSourceMap=null) {
source: function TS_source(aURL, aSourceContent=null) {
if (!this._allow(aURL)) {
return null;
}
@ -2465,7 +2457,7 @@ ThreadSources.prototype = {
return this._sourceActors[aURL];
}
let actor = new SourceActor(aURL, this._thread, aSourceMap);
let actor = new SourceActor(aURL, this._thread, aSourceContent);
this._thread.threadLifetimePool.addActor(actor);
this._sourceActors[aURL] = actor;
try {
@ -2487,7 +2479,8 @@ ThreadSources.prototype = {
return this.sourceMap(aScript)
.then((aSourceMap) => {
return [
this.source(s, aSourceMap) for (s of aSourceMap.sources)
this.source(s, aSourceMap.sourceContentFor(s))
for (s of aSourceMap.sources)
];
}, (e) => {
reportError(e);
@ -2661,7 +2654,7 @@ function isNotNull(aThing) {
* without relying on caching when we can (not for eval, etc.):
* http://www.softwareishard.com/blog/firebug/nsitraceablechannel-intercept-http-traffic/
*/
function fetch(aURL, aOptions={ loadFromCache: true }) {
function fetch(aURL) {
let deferred = defer();
let scheme;
let url = aURL.split(" -> ").pop();
@ -2728,9 +2721,7 @@ function fetch(aURL, aOptions={ loadFromCache: true }) {
}
};
channel.loadFlags = aOptions.loadFromCache
? channel.LOAD_FROM_CACHE
: channel.LOAD_BYPASS_CACHE;
channel.loadFlags = channel.LOAD_FROM_CACHE;
channel.asyncOpen(streamListener, null);
break;
}

Просмотреть файл

@ -207,18 +207,3 @@ function readFile(aFileName) {
s.close();
}
}
function writeFile(aFileName, aContent) {
let file = do_get_file(aFileName, true);
let stream = Cc["@mozilla.org/network/file-output-stream;1"]
.createInstance(Ci.nsIFileOutputStream);
stream.init(file, -1, -1, 0);
try {
do {
let numWritten = stream.write(aContent, aContent.length);
aContent = aContent.slice(numWritten);
} while (aContent.length > 0);
} finally {
stream.close();
}
}

Просмотреть файл

@ -1,67 +0,0 @@
/* Any copyright is dedicated to the Public Domain.
http://creativecommons.org/publicdomain/zero/1.0/ */
/**
* Test that we don't permanently cache sources from source maps.
*/
var gDebuggee;
var gClient;
var gThreadClient;
Components.utils.import("resource:///modules/devtools/SourceMap.jsm");
function run_test()
{
initTestDebuggerServer();
gDebuggee = addTestGlobal("test-source-map");
gClient = new DebuggerClient(DebuggerServer.connectPipe());
gClient.connect(function() {
attachTestGlobalClientAndResume(gClient, "test-source-map", function(aResponse, aThreadClient) {
gThreadClient = aThreadClient;
test_cached_original_sources();
});
});
do_test_pending();
}
function test_cached_original_sources()
{
writeFile("temp.foobar", "initial content");
gClient.addOneTimeListener("newSource", onNewSource);
let node = new SourceNode(1, 0,
getFileUrl("temp.foobar"),
"function funcFromTemp() {}\n");
let { code, map } = node.toStringWithSourceMap({
file: "abc.js"
});
code += "//@ sourceMappingURL=data:text/json;base64," + btoa(map.toString());
Components.utils.evalInSandbox(code, gDebuggee, "1.8",
"http://example.com/www/js/abc.js", 1);
}
function onNewSource(aEvent, aPacket) {
let sourceClient = gThreadClient.source(aPacket.source);
sourceClient.source(function (aResponse) {
do_check_true(!aResponse.error,
"Should not be an error grabbing the source");
do_check_eq(aResponse.source, "initial content",
"The correct source content should be sent");
writeFile("temp.foobar", "new content");
sourceClient.source(function (aResponse) {
do_check_true(!aResponse.error,
"Should not be an error grabbing the source");
do_check_eq(aResponse.source, "new content",
"The correct source content should not be cached, so we should get the new content");
do_get_file("temp.foobar").remove(false);
finishClient(gClient);
});
});
}

Просмотреть файл

@ -88,9 +88,6 @@ reason = bug 820380
skip-if = toolkit == "gonk"
reason = bug 820380
[test_sourcemaps-06.js]
[test_sourcemaps-07.js]
skip-if = toolkit == "gonk"
reason = bug 820380
[test_objectgrips-01.js]
[test_objectgrips-02.js]
[test_objectgrips-03.js]