mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
e333860065
- Bug 1251090 - Shell functions should check whether an off main thread compilation is for a script or a module r=shu (41b89b1232) - Bug 1222420 - Make AutoFinishGC into a function r=terrence (a8f535528c) - Bug 1253094, part 4 - Stop using DebugOnly for class/struct members in js/. r=billm (2c790aa526) - Bug 1080968 - Don't use constexpr on clang-cl when emulating MSVC 2013 (e9cc2d7c7c) - Bug 1257496 - Add information about cycle count and GC state to our GC stats r=sfink (6c2250bfba) - Bug 1256178 - Drop the moz prefix from the MozCSSKeyframeRule and MozCSSKeyframesRule interfaces; r=bzbarsky (894855bce1) - Bug 1249896 - Part 1: Remove unused AndOrLeft, AndOrRight, RelationalLeft, and RelationalRight. r=jwalden (c4db9dfecf) - Bug 1249896 - Part 2: Remove unused type member from SIMD Int8x16Defnetc. r=bbouvier (7d3d7a4db1) - Bug 1249896 - Part 3: Add JS namespace for GenericNaN. r=luke (69acc1f3ec) - Bug 1249896 - Part 4: Avoid declaring variable between cases in switch. r=luke (28e5f94c24) - Bug 1249896 - Part 5: Remove unused ReportInvalidTrapResult. r=efaust (caa948acac) - Bug 1249896 - Part 7: Remove unnecessary static from my_ErrorReporter. r=sfink (7f723e079d) - Bug 1249896 - Part 8: Remove unreachable code from GetLine. r=jwalden (108c857a1a) - Bug 1249896 - Part 9: Include shell/jsshell.h in js.cpp. r=sfink (638bfc13c4) - Bug 1253094, part 3 - Stop using DebugOnly for class/struct members in ipc/. r=billm (ab9e014158) - Bug 1259737 - Make sure BackgroundImpl.cpp's mBoundThread is not used in release builds. r=froydnj (5c278ab398) - Bug 1254515 - GonkCameraImage.cpp:16:5: error: class 'mozilla::GonkCameraImage' does not have any field named 'mThread' r=reuben (e5cac8cf5b) - Bug 1250952: Create a join block in case we're in dead code after the condition; r=luke (1d6b706ae5) - Bug 1249601 - Implement wasm i64 comparisons. r=sunfish (4927f709db) - Bug 1250165 - Implement wasm i64 bitwise ops. r=luke (5c25322772) - Bug 1251225 - Implement wasm i64 binary arithmetic operators. r=sunfish (f478fa8b4b) - Bug 1251392 - Baldr: Implement PopcntI. r=sunfish (79556e947f) - Bug 1229985 - remove nsAutoArrayPtr; r=erahm (91c49451ca) - Bug 1251541: Replace |nsAutoArrayPtr<>| with |UniquePtr<[]>| in Bluetooth managers, r=shuang (2c1dc7ca89) - Bug 1251541: Pass arguments to AVRCP passthrough command as uint8_t, r=shuang (73a094bd26) - Bug 1251541: Replace |nsAutoArrayPtr<>| with |UniquePtr<[]>| in Bluetooth interfaces, r=shuang (371041f093) - Bug 1249424 - Remove use of nsAutoArrayPtr from librlz. r=gerald (7cbcfea1b0) - Bug 1249389 - part 0 - use getter_Transfers in TestStartupCache.cpp; r=erahm (ecb8818959) - Bug 1249389 - part 1 - change NewObjectInputStreamFromBuffer to take a UniquePtr argument; r=erahm (0bdafa20ae) - Bug 1249389 - part 2 - change NewBufferFromStorageStream's outparam into a UniquePtr; r=erahm (b27a70ce2d) - Bug 1249389 - part 3 - assert the size of nsZipItemPtr's storage type; r=erahm (7c55da9ea7) - Bug 1249389 - part 4 - make StartupCache::GetBuffer take a UniquePtr outparam; r=erahm (84b722479b) - Bug 1249389 - part 5 - use UniquePtr instead of nsAutoArrayPtr in mozilla::scache::CacheEntry; r=erahm (0fd492ea95) - Bug 1249389 - part 6 - provide UniquePtr overload for nsIStartupCache::GetBuffer; r=erahm (c27231d945) - Bug 1249389 - followup - fix compilation bustage in gfxFT2FontList.cpp; r=me (a86a1b0399) - Bug 1249389 - part 7 - clean up calls to GetBuffer in TestStartupCache; r=erahm (98939334b6) - Bug 1249369 - use UniquePtr instead of nsAutoArrayPtr in MediaPipeline.cpp; r=jesup (7402a75a8a) - Bug 1238842 - Add error codes to Gecko by following W3C spec. r=brsun (0dd283f6ba) - Bug 1253217 - Change filename from BluetoothUuid to BluetoothUuidHelper. r=jocelyn (1946bcac26) - Bug 1241382 - Revise default value of BluetoothAdapter.address and BluetoothDevice.address to empty string, f=wiwang, r=shuang (d9fdb97743) - Bug 1223722: Transfer arrays of Bluetooth UUIDs in |BluetoothValue|, r=brsun (344af40591) - Bug 1222956: Use |BluetoothUuid| in |BluetoothDiscoveryHandle|, r=tzimmermann (40512de386) - Bug 1250694: Use functions to return static const BluetoothAddress and BluetoothUuid; r=tzimmermann (0c4b20066f) - Bug 1236561 - part 1 - convert easy cases of nsAutoArrayPtr<T> to UniquePtr<T[]> in dom/bluetooth/; r=btian (31ef8b7b50) - Bug 1236561 - part 2 - remove ObexHeaderSet::GetAuthChallenge; r=btian (f70daddd53) - Bug 1236561 - part 3 - make BluetoothConfigurationParameter.mValue a UniquePtr; r=btian (a5a0ac988a) - Bug 1239979: Add |BluetoothSocket::Accept| method, r=btian (ca92a0ab7c) - Bug 1239979: Store pointer to Bluetooth socket interface in |BluetoothSocket|, r=btian (7c15e75133) - Bug 1239979: Cleanup |BluetoothSocket|'s internals when connections close, r=btian (b6ac677d2e) - Bug 1252841: Convert Bluetooth module to |UniquePtr<>|, r=btian (76d9759afd) - Bug 1232687: Start bluetoothd with HAL service interface, r=shuang (379a68064f) - Bug 1223729 - HID Connection Implementation, r=jocelyn, sr=mrbkap (0eeddf875e) - Bug 1232670: Prepare Bluetooth PDU for sending after checking connection status, r=shuang (699ff14d9b) - Bug 1252841: Convert Bluetooth daemon interfaces to |UniquePtr<>|, r=brsun (797260c6dc)
472 lines
12 KiB
C++
472 lines
12 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2; -*- */
|
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
#include "TestHarness.h"
|
|
|
|
#include "nsThreadUtils.h"
|
|
#include "nsIClassInfo.h"
|
|
#include "nsIOutputStream.h"
|
|
#include "nsIObserver.h"
|
|
#include "nsISerializable.h"
|
|
#include "nsISupports.h"
|
|
#include "nsIStartupCache.h"
|
|
#include "nsIStringStream.h"
|
|
#include "nsIStorageStream.h"
|
|
#include "nsIObjectInputStream.h"
|
|
#include "nsIObjectOutputStream.h"
|
|
#include "nsIURI.h"
|
|
#include "nsStringAPI.h"
|
|
#include "nsIPrefBranch.h"
|
|
#include "nsIPrefService.h"
|
|
#include "nsIXPConnect.h"
|
|
#include "prio.h"
|
|
#include "mozilla/Maybe.h"
|
|
#include "mozilla/UniquePtr.h"
|
|
|
|
using namespace JS;
|
|
|
|
namespace mozilla {
|
|
namespace scache {
|
|
|
|
NS_IMPORT nsresult
|
|
NewObjectInputStreamFromBuffer(UniquePtr<char[]> buffer, uint32_t len,
|
|
nsIObjectInputStream** stream);
|
|
|
|
// We can't retrieve the wrapped stream from the objectOutputStream later,
|
|
// so we return it here.
|
|
NS_IMPORT nsresult
|
|
NewObjectOutputWrappedStorageStream(nsIObjectOutputStream **wrapperStream,
|
|
nsIStorageStream** stream);
|
|
|
|
NS_IMPORT nsresult
|
|
NewBufferFromStorageStream(nsIStorageStream *storageStream,
|
|
UniquePtr<char[]>* buffer, uint32_t* len);
|
|
} // namespace scache
|
|
} // namespace mozilla
|
|
|
|
using namespace mozilla::scache;
|
|
using mozilla::UniquePtr;
|
|
|
|
#define NS_ENSURE_STR_MATCH(str1, str2, testname) \
|
|
PR_BEGIN_MACRO \
|
|
if (0 != strcmp(str1, str2)) { \
|
|
fail("failed " testname); \
|
|
return NS_ERROR_FAILURE; \
|
|
} \
|
|
passed("passed " testname); \
|
|
PR_END_MACRO
|
|
|
|
nsresult
|
|
WaitForStartupTimer() {
|
|
nsresult rv;
|
|
nsCOMPtr<nsIStartupCache> sc
|
|
= do_GetService("@mozilla.org/startupcache/cache;1");
|
|
PR_Sleep(10 * PR_TicksPerSecond());
|
|
|
|
bool complete;
|
|
while (true) {
|
|
|
|
NS_ProcessPendingEvents(nullptr);
|
|
rv = sc->StartupWriteComplete(&complete);
|
|
if (NS_FAILED(rv) || complete)
|
|
break;
|
|
PR_Sleep(1 * PR_TicksPerSecond());
|
|
}
|
|
return rv;
|
|
}
|
|
|
|
nsresult
|
|
TestStartupWriteRead() {
|
|
nsresult rv;
|
|
nsCOMPtr<nsIStartupCache> sc
|
|
= do_GetService("@mozilla.org/startupcache/cache;1", &rv);
|
|
if (!sc) {
|
|
fail("didn't get a pointer...");
|
|
return NS_ERROR_FAILURE;
|
|
} else {
|
|
passed("got a pointer?");
|
|
}
|
|
sc->InvalidateCache();
|
|
|
|
const char* buf = "Market opportunities for BeardBook";
|
|
const char* id = "id";
|
|
UniquePtr<char[]> outbuf;
|
|
uint32_t len;
|
|
|
|
rv = sc->PutBuffer(id, buf, strlen(buf) + 1);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
rv = sc->GetBuffer(id, &outbuf, &len);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
NS_ENSURE_STR_MATCH(buf, outbuf.get(), "pre-write read");
|
|
|
|
rv = sc->ResetStartupWriteTimer();
|
|
rv = WaitForStartupTimer();
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
rv = sc->GetBuffer(id, &outbuf, &len);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
NS_ENSURE_STR_MATCH(buf, outbuf.get(), "simple write/read");
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
TestWriteInvalidateRead() {
|
|
nsresult rv;
|
|
const char* buf = "BeardBook competitive analysis";
|
|
const char* id = "id";
|
|
UniquePtr<char[]> outbuf;
|
|
uint32_t len;
|
|
nsCOMPtr<nsIStartupCache> sc
|
|
= do_GetService("@mozilla.org/startupcache/cache;1", &rv);
|
|
sc->InvalidateCache();
|
|
|
|
rv = sc->PutBuffer(id, buf, strlen(buf) + 1);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
sc->InvalidateCache();
|
|
|
|
rv = sc->GetBuffer(id, &outbuf, &len);
|
|
if (rv == NS_ERROR_NOT_AVAILABLE) {
|
|
passed("buffer not available after invalidate");
|
|
} else if (NS_SUCCEEDED(rv)) {
|
|
fail("GetBuffer succeeded unexpectedly after invalidate");
|
|
return NS_ERROR_UNEXPECTED;
|
|
} else {
|
|
fail("GetBuffer gave an unexpected failure, expected NOT_AVAILABLE");
|
|
return rv;
|
|
}
|
|
|
|
sc->InvalidateCache();
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
TestWriteObject() {
|
|
nsresult rv;
|
|
|
|
nsCOMPtr<nsIURI> obj
|
|
= do_CreateInstance("@mozilla.org/network/simple-uri;1");
|
|
if (!obj) {
|
|
fail("did not create object in test write object");
|
|
return NS_ERROR_UNEXPECTED;
|
|
}
|
|
NS_NAMED_LITERAL_CSTRING(spec, "http://www.mozilla.org");
|
|
obj->SetSpec(spec);
|
|
nsCOMPtr<nsIStartupCache> sc = do_GetService("@mozilla.org/startupcache/cache;1", &rv);
|
|
|
|
sc->InvalidateCache();
|
|
|
|
// Create an object stream. Usually this is done with
|
|
// NewObjectOutputWrappedStorageStream, but that uses
|
|
// StartupCache::GetSingleton in debug builds, and we
|
|
// don't have access to that here. Obviously.
|
|
const char* id = "id";
|
|
nsCOMPtr<nsIStorageStream> storageStream
|
|
= do_CreateInstance("@mozilla.org/storagestream;1");
|
|
NS_ENSURE_ARG_POINTER(storageStream);
|
|
|
|
rv = storageStream->Init(256, (uint32_t) -1);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
nsCOMPtr<nsIObjectOutputStream> objectOutput
|
|
= do_CreateInstance("@mozilla.org/binaryoutputstream;1");
|
|
if (!objectOutput)
|
|
return NS_ERROR_OUT_OF_MEMORY;
|
|
|
|
nsCOMPtr<nsIOutputStream> outputStream
|
|
= do_QueryInterface(storageStream);
|
|
|
|
rv = objectOutput->SetOutputStream(outputStream);
|
|
|
|
if (NS_FAILED(rv)) {
|
|
fail("failed to create output stream");
|
|
return rv;
|
|
}
|
|
nsCOMPtr<nsISupports> objQI(do_QueryInterface(obj));
|
|
rv = objectOutput->WriteObject(objQI, true);
|
|
if (NS_FAILED(rv)) {
|
|
fail("failed to write object");
|
|
return rv;
|
|
}
|
|
|
|
UniquePtr<char[]> buf;
|
|
uint32_t len;
|
|
NewBufferFromStorageStream(storageStream, &buf, &len);
|
|
|
|
// Since this is a post-startup write, it should be written and
|
|
// available.
|
|
rv = sc->PutBuffer(id, buf.get(), len);
|
|
if (NS_FAILED(rv)) {
|
|
fail("failed to insert input stream");
|
|
return rv;
|
|
}
|
|
|
|
UniquePtr<char[]> buf2;
|
|
uint32_t len2;
|
|
nsCOMPtr<nsIObjectInputStream> objectInput;
|
|
rv = sc->GetBuffer(id, &buf2, &len2);
|
|
if (NS_FAILED(rv)) {
|
|
fail("failed to retrieve buffer");
|
|
return rv;
|
|
}
|
|
|
|
rv = NewObjectInputStreamFromBuffer(Move(buf2), len2,
|
|
getter_AddRefs(objectInput));
|
|
if (NS_FAILED(rv)) {
|
|
fail("failed to created input stream");
|
|
return rv;
|
|
}
|
|
|
|
nsCOMPtr<nsISupports> deserialized;
|
|
rv = objectInput->ReadObject(true, getter_AddRefs(deserialized));
|
|
if (NS_FAILED(rv)) {
|
|
fail("failed to read object");
|
|
return rv;
|
|
}
|
|
|
|
bool match = false;
|
|
nsCOMPtr<nsIURI> uri(do_QueryInterface(deserialized));
|
|
if (uri) {
|
|
nsCString outSpec;
|
|
uri->GetSpec(outSpec);
|
|
match = outSpec.Equals(spec);
|
|
}
|
|
if (!match) {
|
|
fail("deserialized object has incorrect information");
|
|
return rv;
|
|
}
|
|
|
|
passed("write object");
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
LockCacheFile(bool protect, nsIFile* profileDir) {
|
|
NS_ENSURE_ARG(profileDir);
|
|
|
|
nsCOMPtr<nsIFile> startupCache;
|
|
profileDir->Clone(getter_AddRefs(startupCache));
|
|
NS_ENSURE_STATE(startupCache);
|
|
startupCache->AppendNative(NS_LITERAL_CSTRING("startupCache"));
|
|
|
|
nsresult rv;
|
|
#ifndef XP_WIN
|
|
static uint32_t oldPermissions;
|
|
#else
|
|
static PRFileDesc* fd = nullptr;
|
|
#endif
|
|
|
|
// To prevent deletion of the startupcache file, we change the containing
|
|
// directory's permissions on Linux/Mac, and hold the file open on Windows
|
|
if (protect) {
|
|
#ifndef XP_WIN
|
|
rv = startupCache->GetPermissions(&oldPermissions);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
rv = startupCache->SetPermissions(0555);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
#else
|
|
// Filename logic from StartupCache.cpp
|
|
#ifdef IS_BIG_ENDIAN
|
|
#define SC_ENDIAN "big"
|
|
#else
|
|
#define SC_ENDIAN "little"
|
|
#endif
|
|
|
|
#if PR_BYTES_PER_WORD == 4
|
|
#define SC_WORDSIZE "4"
|
|
#else
|
|
#define SC_WORDSIZE "8"
|
|
#endif
|
|
char sStartupCacheName[] = "startupCache." SC_WORDSIZE "." SC_ENDIAN;
|
|
startupCache->AppendNative(NS_LITERAL_CSTRING(sStartupCacheName));
|
|
|
|
rv = startupCache->OpenNSPRFileDesc(PR_RDONLY, 0, &fd);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
#endif
|
|
} else {
|
|
#ifndef XP_WIN
|
|
rv = startupCache->SetPermissions(oldPermissions);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
#else
|
|
PR_Close(fd);
|
|
#endif
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
TestIgnoreDiskCache(nsIFile* profileDir) {
|
|
nsresult rv;
|
|
nsCOMPtr<nsIStartupCache> sc
|
|
= do_GetService("@mozilla.org/startupcache/cache;1", &rv);
|
|
sc->InvalidateCache();
|
|
|
|
const char* buf = "Get a Beardbook app for your smartphone";
|
|
const char* id = "id";
|
|
UniquePtr<char[]> outbuf;
|
|
uint32_t len;
|
|
|
|
rv = sc->PutBuffer(id, buf, strlen(buf) + 1);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
rv = sc->ResetStartupWriteTimer();
|
|
rv = WaitForStartupTimer();
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
// Prevent StartupCache::InvalidateCache from deleting the disk file
|
|
rv = LockCacheFile(true, profileDir);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
sc->IgnoreDiskCache();
|
|
|
|
rv = sc->GetBuffer(id, &outbuf, &len);
|
|
|
|
nsresult r = LockCacheFile(false, profileDir);
|
|
NS_ENSURE_SUCCESS(r, r);
|
|
|
|
if (rv == NS_ERROR_NOT_AVAILABLE) {
|
|
passed("buffer not available after ignoring disk cache");
|
|
} else if (NS_SUCCEEDED(rv)) {
|
|
fail("GetBuffer succeeded unexpectedly after ignoring disk cache");
|
|
return NS_ERROR_UNEXPECTED;
|
|
} else {
|
|
fail("GetBuffer gave an unexpected failure, expected NOT_AVAILABLE");
|
|
return rv;
|
|
}
|
|
|
|
sc->InvalidateCache();
|
|
return NS_OK;
|
|
}
|
|
|
|
nsresult
|
|
TestEarlyShutdown() {
|
|
nsresult rv;
|
|
nsCOMPtr<nsIStartupCache> sc
|
|
= do_GetService("@mozilla.org/startupcache/cache;1", &rv);
|
|
sc->InvalidateCache();
|
|
|
|
const char* buf = "Find your soul beardmate on BeardBook";
|
|
const char* id = "id";
|
|
uint32_t len;
|
|
UniquePtr<char[]> outbuf;
|
|
|
|
sc->ResetStartupWriteTimer();
|
|
rv = sc->PutBuffer(id, buf, strlen(buf) + 1);
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
nsCOMPtr<nsIObserver> obs;
|
|
sc->GetObserver(getter_AddRefs(obs));
|
|
obs->Observe(nullptr, "xpcom-shutdown", nullptr);
|
|
rv = WaitForStartupTimer();
|
|
NS_ENSURE_SUCCESS(rv, rv);
|
|
|
|
rv = sc->GetBuffer(id, &outbuf, &len);
|
|
|
|
if (NS_SUCCEEDED(rv)) {
|
|
passed("GetBuffer succeeded after early shutdown");
|
|
} else {
|
|
fail("GetBuffer failed after early shutdown");
|
|
return rv;
|
|
}
|
|
|
|
const char* other_id = "other_id";
|
|
rv = sc->PutBuffer(other_id, buf, strlen(buf) + 1);
|
|
|
|
if (rv == NS_ERROR_NOT_AVAILABLE) {
|
|
passed("PutBuffer not available after early shutdown");
|
|
} else if (NS_SUCCEEDED(rv)) {
|
|
fail("PutBuffer succeeded unexpectedly after early shutdown");
|
|
return NS_ERROR_UNEXPECTED;
|
|
} else {
|
|
fail("PutBuffer gave an unexpected failure, expected NOT_AVAILABLE");
|
|
return rv;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
ScopedXPCOM xpcom("Startup Cache");
|
|
if (xpcom.failed())
|
|
return 1;
|
|
|
|
nsCOMPtr<nsIPrefBranch> prefs = do_GetService(NS_PREFSERVICE_CONTRACTID);
|
|
prefs->SetIntPref("hangmonitor.timeout", 0);
|
|
|
|
int rv = 0;
|
|
nsresult scrv;
|
|
|
|
// Register TestStartupCacheTelemetry
|
|
nsCOMPtr<nsIFile> manifest;
|
|
scrv = NS_GetSpecialDirectory(NS_GRE_DIR,
|
|
getter_AddRefs(manifest));
|
|
if (NS_FAILED(scrv)) {
|
|
fail("NS_XPCOM_CURRENT_PROCESS_DIR");
|
|
return 1;
|
|
}
|
|
|
|
#ifdef XP_MACOSX
|
|
nsCOMPtr<nsIFile> tempManifest;
|
|
manifest->Clone(getter_AddRefs(tempManifest));
|
|
manifest->AppendNative(
|
|
NS_LITERAL_CSTRING("TestStartupCacheTelemetry.manifest"));
|
|
bool exists;
|
|
manifest->Exists(&exists);
|
|
if (!exists) {
|
|
// Workaround for bug 1080338 in mozharness.
|
|
manifest = tempManifest.forget();
|
|
manifest->SetNativeLeafName(NS_LITERAL_CSTRING("MacOS"));
|
|
manifest->AppendNative(
|
|
NS_LITERAL_CSTRING("TestStartupCacheTelemetry.manifest"));
|
|
}
|
|
#else
|
|
manifest->AppendNative(
|
|
NS_LITERAL_CSTRING("TestStartupCacheTelemetry.manifest"));
|
|
#endif
|
|
|
|
XRE_AddManifestLocation(NS_COMPONENT_LOCATION, manifest);
|
|
|
|
nsCOMPtr<nsIObserver> telemetryThing =
|
|
do_GetService("@mozilla.org/testing/startup-cache-telemetry.js");
|
|
if (!telemetryThing) {
|
|
fail("telemetryThing");
|
|
return 1;
|
|
}
|
|
scrv = telemetryThing->Observe(nullptr, "save-initial", nullptr);
|
|
if (NS_FAILED(scrv)) {
|
|
fail("save-initial");
|
|
rv = 1;
|
|
}
|
|
|
|
nsCOMPtr<nsIStartupCache> sc
|
|
= do_GetService("@mozilla.org/startupcache/cache;1", &scrv);
|
|
if (NS_FAILED(scrv))
|
|
rv = 1;
|
|
else
|
|
sc->RecordAgesAlways();
|
|
if (NS_FAILED(TestStartupWriteRead()))
|
|
rv = 1;
|
|
if (NS_FAILED(TestWriteInvalidateRead()))
|
|
rv = 1;
|
|
if (NS_FAILED(TestWriteObject()))
|
|
rv = 1;
|
|
nsCOMPtr<nsIFile> profileDir = xpcom.GetProfileDirectory();
|
|
if (NS_FAILED(TestIgnoreDiskCache(profileDir)))
|
|
rv = 1;
|
|
if (NS_FAILED(TestEarlyShutdown()))
|
|
rv = 1;
|
|
|
|
scrv = telemetryThing->Observe(nullptr, "save-initial", nullptr);
|
|
if (NS_FAILED(scrv)) {
|
|
fail("check-final");
|
|
rv = 1;
|
|
}
|
|
|
|
return rv;
|
|
}
|