2011-09-13 21:24:01 +02:00
|
|
|
var _PSvc;
|
|
|
|
function get_pref_service() {
|
|
|
|
if (_PSvc)
|
|
|
|
return _PSvc;
|
|
|
|
|
|
|
|
return _PSvc = Cc["@mozilla.org/preferences-service;1"].
|
|
|
|
getService(Ci.nsIPrefBranch);
|
|
|
|
}
|
|
|
|
|
2011-06-22 10:49:35 +02:00
|
|
|
function gen_1MiB()
|
|
|
|
{
|
|
|
|
var i;
|
|
|
|
var data="x";
|
|
|
|
for (i=0 ; i < 20 ; i++)
|
|
|
|
data+=data;
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
function write_and_check(str, data, len)
|
|
|
|
{
|
|
|
|
var written = str.write(data, len);
|
|
|
|
if (written != len) {
|
|
|
|
do_throw("str.write has not written all data!\n" +
|
|
|
|
" Expected: " + len + "\n" +
|
|
|
|
" Actual: " + written + "\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-12 14:23:32 -07:00
|
|
|
function write_datafile(status, entry)
|
2011-06-22 10:49:35 +02:00
|
|
|
{
|
2012-06-12 14:23:32 -07:00
|
|
|
do_check_eq(status, Cr.NS_OK);
|
|
|
|
var os = entry.openOutputStream(0);
|
2011-06-22 10:49:35 +02:00
|
|
|
var data = gen_1MiB();
|
|
|
|
|
2013-01-04 00:30:48 +01:00
|
|
|
// write 2MiB
|
2011-06-22 10:49:35 +02:00
|
|
|
var i;
|
2013-01-04 00:30:48 +01:00
|
|
|
for (i=0 ; i<2 ; i++)
|
2012-06-12 14:23:32 -07:00
|
|
|
write_and_check(os, data, data.length);
|
2011-06-22 10:49:35 +02:00
|
|
|
|
2012-06-12 14:23:32 -07:00
|
|
|
os.close();
|
|
|
|
entry.close();
|
2011-06-22 10:49:35 +02:00
|
|
|
|
2013-01-04 00:30:48 +01:00
|
|
|
// now change max_entry_size so that the existing entry is too big
|
|
|
|
get_pref_service().setIntPref("browser.cache.disk.max_entry_size", 1024);
|
|
|
|
|
2012-06-12 14:23:32 -07:00
|
|
|
// append to entry
|
2013-09-20 11:11:25 +02:00
|
|
|
asyncOpenCacheEntry("http://data/",
|
|
|
|
"disk", Ci.nsICacheStorage.OPEN_NORMALLY, null,
|
2012-06-12 14:23:32 -07:00
|
|
|
append_datafile);
|
2011-06-22 10:49:35 +02:00
|
|
|
}
|
|
|
|
|
2012-06-12 14:23:32 -07:00
|
|
|
function append_datafile(status, entry)
|
2011-06-22 10:49:35 +02:00
|
|
|
{
|
2012-06-12 14:23:32 -07:00
|
|
|
do_check_eq(status, Cr.NS_OK);
|
|
|
|
var os = entry.openOutputStream(entry.dataSize);
|
2011-06-22 10:49:35 +02:00
|
|
|
var data = gen_1MiB();
|
|
|
|
|
|
|
|
// append 1MiB
|
|
|
|
try {
|
2012-06-12 14:23:32 -07:00
|
|
|
write_and_check(os, data, data.length);
|
2011-06-22 10:49:35 +02:00
|
|
|
do_throw();
|
|
|
|
}
|
|
|
|
catch (ex) { }
|
|
|
|
|
|
|
|
// closing the ostream should fail in this case
|
|
|
|
try {
|
2012-06-12 14:23:32 -07:00
|
|
|
os.close();
|
2011-06-22 10:49:35 +02:00
|
|
|
do_throw();
|
|
|
|
}
|
|
|
|
catch (ex) { }
|
|
|
|
|
2012-06-12 14:23:32 -07:00
|
|
|
entry.close();
|
|
|
|
|
|
|
|
do_test_finished();
|
2011-06-22 10:49:35 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
function run_test() {
|
2013-09-20 11:11:25 +02:00
|
|
|
if (newCacheBackEndUsed()) {
|
|
|
|
// Needs limit preferences
|
|
|
|
do_check_true(true, "This test doesn't run with the new cache backend, the test or the cache needs to be fixed");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2011-06-22 10:49:35 +02:00
|
|
|
do_get_profile();
|
|
|
|
|
|
|
|
// clear the cache
|
2012-06-12 14:23:32 -07:00
|
|
|
evict_cache_entries();
|
|
|
|
|
2013-09-20 11:11:25 +02:00
|
|
|
asyncOpenCacheEntry("http://data/",
|
|
|
|
"disk", Ci.nsICacheStorage.OPEN_NORMALLY, null,
|
2012-06-12 14:23:32 -07:00
|
|
|
write_datafile);
|
2011-06-22 10:49:35 +02:00
|
|
|
|
|
|
|
do_test_pending();
|
|
|
|
}
|