mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-27 04:51:16 +00:00
9e110c81ee
- Bug 1171796: Add sandbox rule for child process NSPR log file on Windows. r=bbondy (1393c5eed4) - Bug 1171994: Separate RIL I/O interfaces, r=htsai (eb62c398f9) - Bug 1171994: Store an instance of |RilWorker| for each RIL connection, r=htsai (6f85151cfe) - Bug 1171464 - Check that socket isn't already closed before closing it, r=kmachulis (05a6ecd79c) - Bug 1156352: Remove |UnixSocketRawData| from RIL interfaces, r=htsai (4c2c066809) - Bug 1171994: Use |RilSocket| to handle RIL messages on the RIL worker, r=htsai (cdbc7a3868) - Bug 1171994: Cleanup JSAPI code of |RilConsumer|, r=htsai (eaf9623f2c) - Bug 1207539 - Remove !JS_IsRunning(aCx) assertion from RilConsumer::ConnectWorkerToRIL; r=mrbkap (f5d20f6d75) - missing bit of Bug 1138293 - Use malloc/free/realloc/calloc (3cdb9ee5d6) - Bug 1140261 - Fix compiler error comparison of unsigned expression >= 0 is always true. r=hchang (f808fc5f09) - Bug 1158896 - prevent dead code from being generated in lower.py; r=bent (8ebbd3109d) - Bug 1169382 - Don't generate commented out NS_INTERFACE_CLASS or NS_ABSTRACT_CLASS in IPDL. r=billm (20fc4894c0) - Bug 1219537 - Simplify a couple of PresContext() gets on nsIFrame/nsStyleContext. r=dholbert (cff7f8aa43) - Bug 1223258 - Fix -Wunreachable-code warnings in widget. r=masayuki (8682636334) - bit of Add an nsIGfxInfo function to query monitors. (bug 1175005 partart 1) (36bb03dfb2) - Bug 1210086 - Fix warnings caused by toolbar buttons in gtk2. r=karl (0e7f0aaba2) - Bug 1176109 - Don't attach menu popups to menubars on GTK3. r=karlt (1cbdd6798f) - Bug 1188138 - Prevent default buttons from being drawn twice on GTK3. r=karlt (24d3b48643) - Bug 1189028 - Draw a toplevel popup behind popup menus on GTK3. r=karlt (6dcb65f4af) - Bug 1160154 - Decrease padding between icons in the personal toolbar with Gtk3 by using "image-button" css style class. r=karlt (50254fd1ce) - Bug 1073117 - Fixed Theme issues with GTK 3.14 - GtkButtons - use border style (cde1375eec) - Bug 1168578 - Use widget state in GTK3 toggles' style context. r=karlt (2889392859) - Bug 1198613 - Use GTK style padding for dropdown boxes in HTML. r=karlt (5e97b42105) - Bug 1216582 - [gtk3] Scrollbar buttons not drawn correctly. r=karlt (4a7ca51f14) - Bug 1174248 - Workaround unico theme engine resizer bug on GTK3. r=karlt (ca55b44a4a) - Bug 1173907 - Don't use gtk_render_activity for drawing progress chunks on GTK versions above 3.13.7. r=karlt (57e97d2d55) - Bug 1218008 - Fix progress bar rendering on the Ambiance GTK3 theme. r=karlt (5dcfff5ab5) - Bug 1171011 - Use only document padding for MOZ_GTK_ENTRY in XUL. r=karlt (3d164c219e) - Bug 1187385 - Use GTK style padding for entry widgets. r=karlt (f44fffb148) - Bug 1176929 - Disable Ctrl-K in GtkEntry unless custom key bindings are (46c9b03899) - Bug 1120490 - Take the 'GetRotateForLandscape' gfxASurface configuration into account when creating printing surfaces. r=jwatt (b259f7006a) - Bug 1228216 - Event::GetScreenCoords incorrectly converts the coords to a CSSPoint when the widget is null r=tnikkel (9e58f9f640) - Bug 1226872 - Stop keeping a copy of the resolution in the root scrollframe. r=roc (c168509f4d) - Bug 1224015 - Part 1: nsLayoutUtils functions do not account for nsPresShell resolution r=tnikkel (c6a1cca145) - Bug 1224015 - Part 2: Have nsDisplayResolution items adjust event coordinates for hit testing and dispatching to content r=tnikkel (09fad089ce) - Bug 1224015 - Part 3: ifdef changes to C++APZ so that they only apply to single process APZ. r=tnikkel (340b30205d) - Bug 1228597 - Remove the MOZ_SINGLE_PROCESS_APZ define. r=tn (6733cf7b4b) - Bug 1177406, don't rely on owner to be set only on main thread, r=khuey (a31d3ee5fe) - Bug 1221822 - Finish the WebGL texture refactor. r=kamidphish,mattwoodrow,bz (9df451d68f) - bug 1214953 set GDK_VERSION_MIN_REQUIRED/MAX_ALLOWED to specify the GTK/GDK API and suppress irrelevant deprecated warnings r=glandium (e9161dc6f4) - Bug 1160666 - Allow per-product b2g branding. r=fabrice (8d95dfa1ea) - Fix due to backport (900ffc0c50) - Bug 1224490 - Don't set NSS_LIBS in the non-native NSS case. r=mshal We never use the variable in that case. Bug 1224490 - Kill LIBXUL_DIST. r=mshal (bf53e3e930) - Bug 1175555 - Build flag to exclude hyphenation dictionaries from Android builds. r=nalexander (eb94fae1dd) - Bug 1141534 - fix mulet nightly mozconfigs; r=bhearsum We don't want uploadsymbols or update-packaging for nightly mulet builds, but these were being set by the underlying browser mozconfigs. (1a9e4cb294) - Bug 1137000 - Enable SDK building on nightlies; r=glandium (c28e4f9cae) - Bug 1181040 - Include mozconfig.cache after mozconfig.common.override. r=mshal (610364f8ae) - bug 1182519 - Put mozconfigs for cross-mac builds in tree. r=mshal (0c3768b90a) - bug 935237 - add genisoimage+dmg binaries to tooltool manifest, use them in cross-mac mozconfig. r=gps (d0252cb263) - bug 1203689 - Use tooltool gcc as host compiler for cross-mac builds. r=dustin (2597df48cd) - Bug 1204068 - Update the clang used for OSX cross compiles to the latest that we use on Linux64; r=ted (0323202013) - Bug 1204763 - Enable cross compiling the clang plugin for OS X on Linux; r=glandium (2813897f8b) - Bug 1208787 - Enable static analysis checks by default on OSX cross builds; r=ted (9aa48ddb43) - bug 543111 - enable Breakpad for cross-mac builds. r=glandium (1a2be876d8) - bug 1190522 - Rewrite pkg-dmg as a Python script. r=gps (796e8ef8e1) - bug 935237 - use libdmg-hfsplus to create DMG files during packaging on Linux. r=gps (d676c7eb8f) - bug 543111 - add support for alternate dsymutil paths to configure, add to cross-mozconfig. r=glandium (401ec2b3a4)
504 lines
12 KiB
C++
504 lines
12 KiB
C++
/**
|
|
* Any copyright is dedicated to the Public Domain.
|
|
* http://creativecommons.org/publicdomain/zero/1.0/
|
|
*/
|
|
|
|
#include "TestHarness.h"
|
|
|
|
#include "nsIAppShell.h"
|
|
#include "nsIAppShellService.h"
|
|
#include "nsIDocument.h"
|
|
#include "nsIDOMEvent.h"
|
|
#include "nsIDOMEventListener.h"
|
|
#include "nsIDOMEventTarget.h"
|
|
#include "nsIDOMWindow.h"
|
|
#include "nsIDOMWindowUtils.h"
|
|
#include "nsIInterfaceRequestor.h"
|
|
#include "nsIRunnable.h"
|
|
#include "nsIURI.h"
|
|
#include "nsIWebBrowserChrome.h"
|
|
#include "nsIXULWindow.h"
|
|
|
|
#include "nsAppShellCID.h"
|
|
#include "nsIInterfaceRequestorUtils.h"
|
|
#include "nsNetUtil.h"
|
|
#include "nsThreadUtils.h"
|
|
#include "mozilla/Attributes.h"
|
|
|
|
#ifdef XP_WIN
|
|
#include <windows.h>
|
|
#endif
|
|
|
|
using namespace mozilla;
|
|
|
|
typedef void (*TestFunc)(nsIAppShell*);
|
|
|
|
bool gStableStateEventHasRun = false;
|
|
|
|
class ExitAppShellRunnable : public nsRunnable
|
|
{
|
|
nsCOMPtr<nsIAppShell> mAppShell;
|
|
|
|
public:
|
|
explicit ExitAppShellRunnable(nsIAppShell* aAppShell)
|
|
: mAppShell(aAppShell)
|
|
{ }
|
|
|
|
NS_IMETHOD
|
|
Run()
|
|
{
|
|
return mAppShell->Exit();
|
|
}
|
|
};
|
|
|
|
class StableStateRunnable : public nsRunnable
|
|
{
|
|
public:
|
|
NS_IMETHOD
|
|
Run()
|
|
{
|
|
if (gStableStateEventHasRun) {
|
|
fail("StableStateRunnable already ran");
|
|
}
|
|
gStableStateEventHasRun = true;
|
|
return NS_OK;
|
|
}
|
|
};
|
|
|
|
class CheckStableStateRunnable : public nsRunnable
|
|
{
|
|
bool mShouldHaveRun;
|
|
|
|
public:
|
|
explicit CheckStableStateRunnable(bool aShouldHaveRun)
|
|
: mShouldHaveRun(aShouldHaveRun)
|
|
{ }
|
|
|
|
NS_IMETHOD
|
|
Run()
|
|
{
|
|
if (mShouldHaveRun == gStableStateEventHasRun) {
|
|
passed("StableStateRunnable state correct (%s)",
|
|
mShouldHaveRun ? "true" : "false");
|
|
} else {
|
|
fail("StableStateRunnable ran at wrong time");
|
|
}
|
|
return NS_OK;
|
|
}
|
|
};
|
|
|
|
class ScheduleStableStateRunnable : public CheckStableStateRunnable
|
|
{
|
|
protected:
|
|
nsCOMPtr<nsIAppShell> mAppShell;
|
|
|
|
public:
|
|
explicit ScheduleStableStateRunnable(nsIAppShell* aAppShell)
|
|
: CheckStableStateRunnable(false), mAppShell(aAppShell)
|
|
{ }
|
|
|
|
NS_IMETHOD
|
|
Run()
|
|
{
|
|
CheckStableStateRunnable::Run();
|
|
|
|
nsCOMPtr<nsIRunnable> runnable = new StableStateRunnable();
|
|
nsresult rv = mAppShell->RunBeforeNextEvent(runnable);
|
|
if (NS_FAILED(rv)) {
|
|
fail("RunBeforeNextEvent returned failure code %u", rv);
|
|
}
|
|
|
|
return rv;
|
|
}
|
|
};
|
|
|
|
class NextTestRunnable : public nsRunnable
|
|
{
|
|
nsCOMPtr<nsIAppShell> mAppShell;
|
|
|
|
public:
|
|
explicit NextTestRunnable(nsIAppShell* aAppShell)
|
|
: mAppShell(aAppShell)
|
|
{ }
|
|
|
|
NS_IMETHOD Run();
|
|
};
|
|
|
|
class ScheduleNestedStableStateRunnable : public ScheduleStableStateRunnable
|
|
{
|
|
public:
|
|
explicit ScheduleNestedStableStateRunnable(nsIAppShell* aAppShell)
|
|
: ScheduleStableStateRunnable(aAppShell)
|
|
{ }
|
|
|
|
NS_IMETHOD
|
|
Run()
|
|
{
|
|
ScheduleStableStateRunnable::Run();
|
|
|
|
nsCOMPtr<nsIRunnable> runnable = new CheckStableStateRunnable(false);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch check runnable");
|
|
}
|
|
|
|
if (NS_FAILED(NS_ProcessPendingEvents(nullptr))) {
|
|
fail("Failed to process all pending events");
|
|
}
|
|
|
|
runnable = new CheckStableStateRunnable(true);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch check runnable");
|
|
}
|
|
|
|
runnable = new NextTestRunnable(mAppShell);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch next test runnable");
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
};
|
|
|
|
class EventListener final : public nsIDOMEventListener
|
|
{
|
|
nsCOMPtr<nsIAppShell> mAppShell;
|
|
|
|
static nsIDOMWindowUtils* sWindowUtils;
|
|
static nsIAppShell* sAppShell;
|
|
|
|
~EventListener() {}
|
|
|
|
public:
|
|
NS_DECL_ISUPPORTS
|
|
|
|
explicit EventListener(nsIAppShell* aAppShell)
|
|
: mAppShell(aAppShell)
|
|
{ }
|
|
|
|
NS_IMETHOD
|
|
HandleEvent(nsIDOMEvent* aEvent) override
|
|
{
|
|
nsString type;
|
|
if (NS_FAILED(aEvent->GetType(type))) {
|
|
fail("Failed to get event type");
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
if (type.EqualsLiteral("load")) {
|
|
passed("Got load event");
|
|
|
|
nsCOMPtr<nsIDOMEventTarget> target;
|
|
if (NS_FAILED(aEvent->GetTarget(getter_AddRefs(target)))) {
|
|
fail("Failed to get event type");
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
nsCOMPtr<nsIDocument> document = do_QueryInterface(target);
|
|
if (!document) {
|
|
fail("Failed to QI to nsIDocument!");
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
nsCOMPtr<nsPIDOMWindow> window = document->GetWindow();
|
|
if (!window) {
|
|
fail("Failed to get window from document!");
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
nsCOMPtr<nsIDOMWindowUtils> utils = do_GetInterface(window);
|
|
if (!utils) {
|
|
fail("Failed to get DOMWindowUtils!");
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
if (!ScheduleTimer(utils)) {
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
if (type.EqualsLiteral("keypress")) {
|
|
passed("Got keypress event");
|
|
|
|
nsCOMPtr<nsIRunnable> runnable = new StableStateRunnable();
|
|
nsresult rv = mAppShell->RunBeforeNextEvent(runnable);
|
|
if (NS_FAILED(rv)) {
|
|
fail("RunBeforeNextEvent returned failure code %u", rv);
|
|
return NS_ERROR_FAILURE;
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
fail("Got an unexpected event: %s", NS_ConvertUTF16toUTF8(type).get());
|
|
return NS_OK;
|
|
}
|
|
|
|
#ifdef XP_WIN
|
|
static VOID CALLBACK
|
|
TimerCallback(HWND hwnd, UINT uMsg, UINT idEvent, DWORD dwTime)
|
|
{
|
|
if (sWindowUtils) {
|
|
nsCOMPtr<nsIDOMWindowUtils> utils = dont_AddRef(sWindowUtils);
|
|
sWindowUtils = nullptr;
|
|
|
|
if (gStableStateEventHasRun) {
|
|
fail("StableStateRunnable ran at wrong time");
|
|
} else {
|
|
passed("StableStateRunnable state correct (false)");
|
|
}
|
|
|
|
int32_t layout = 0x409; // US
|
|
int32_t keyCode = 0x41; // VK_A
|
|
NS_NAMED_LITERAL_STRING(a, "a");
|
|
|
|
if (NS_FAILED(utils->SendNativeKeyEvent(layout, keyCode, 0, a, a, nullptr))) {
|
|
fail("Failed to synthesize native event");
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
KillTimer(nullptr, idEvent);
|
|
|
|
nsCOMPtr<nsIAppShell> appShell = dont_AddRef(sAppShell);
|
|
|
|
if (!gStableStateEventHasRun) {
|
|
fail("StableStateRunnable didn't run yet");
|
|
} else {
|
|
passed("StableStateRunnable state correct (true)");
|
|
}
|
|
|
|
nsCOMPtr<nsIRunnable> runnable = new NextTestRunnable(appShell);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch next test runnable");
|
|
}
|
|
|
|
}
|
|
#endif
|
|
|
|
bool
|
|
ScheduleTimer(nsIDOMWindowUtils* aWindowUtils)
|
|
{
|
|
#ifdef XP_WIN
|
|
UINT_PTR timerId = SetTimer(nullptr, 0, 1000, (TIMERPROC)TimerCallback);
|
|
if (!timerId) {
|
|
fail("SetTimer failed!");
|
|
return false;
|
|
}
|
|
|
|
nsCOMPtr<nsIDOMWindowUtils> utils = aWindowUtils;
|
|
utils.forget(&sWindowUtils);
|
|
|
|
nsCOMPtr<nsIAppShell> appShell = mAppShell;
|
|
appShell.forget(&sAppShell);
|
|
|
|
return true;
|
|
#else
|
|
return false;
|
|
#endif
|
|
}
|
|
};
|
|
|
|
nsIDOMWindowUtils* EventListener::sWindowUtils = nullptr;
|
|
nsIAppShell* EventListener::sAppShell = nullptr;
|
|
|
|
NS_IMPL_ISUPPORTS(EventListener, nsIDOMEventListener)
|
|
|
|
already_AddRefed<nsIAppShell>
|
|
GetAppShell()
|
|
{
|
|
static const char* platforms[] = {
|
|
"android", "mac", "gonk", "gtk", "qt", "win"
|
|
};
|
|
|
|
NS_NAMED_LITERAL_CSTRING(contractPrefix, "@mozilla.org/widget/appshell/");
|
|
NS_NAMED_LITERAL_CSTRING(contractSuffix, ";1");
|
|
|
|
for (size_t index = 0; index < ArrayLength(platforms); index++) {
|
|
nsAutoCString contractID(contractPrefix);
|
|
contractID.AppendASCII(platforms[index]);
|
|
contractID.Append(contractSuffix);
|
|
|
|
nsCOMPtr<nsIAppShell> appShell = do_GetService(contractID.get());
|
|
if (appShell) {
|
|
return appShell.forget();
|
|
}
|
|
}
|
|
|
|
return nullptr;
|
|
}
|
|
|
|
void
|
|
Test1(nsIAppShell* aAppShell)
|
|
{
|
|
// Schedule stable state runnable to be run before next event.
|
|
|
|
nsCOMPtr<nsIRunnable> runnable = new StableStateRunnable();
|
|
if (NS_FAILED(aAppShell->RunBeforeNextEvent(runnable))) {
|
|
fail("RunBeforeNextEvent failed");
|
|
}
|
|
|
|
runnable = new CheckStableStateRunnable(true);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch check runnable");
|
|
}
|
|
|
|
runnable = new NextTestRunnable(aAppShell);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch next test runnable");
|
|
}
|
|
}
|
|
|
|
void
|
|
Test2(nsIAppShell* aAppShell)
|
|
{
|
|
// Schedule stable state runnable to be run before next event from another
|
|
// runnable.
|
|
|
|
nsCOMPtr<nsIRunnable> runnable = new ScheduleStableStateRunnable(aAppShell);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch schedule runnable");
|
|
}
|
|
|
|
runnable = new CheckStableStateRunnable(true);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch check runnable");
|
|
}
|
|
|
|
runnable = new NextTestRunnable(aAppShell);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch next test runnable");
|
|
}
|
|
}
|
|
|
|
void
|
|
Test3(nsIAppShell* aAppShell)
|
|
{
|
|
// Schedule steadystate runnable to be run before next event with nested loop.
|
|
|
|
nsCOMPtr<nsIRunnable> runnable =
|
|
new ScheduleNestedStableStateRunnable(aAppShell);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch schedule runnable");
|
|
}
|
|
}
|
|
|
|
bool
|
|
Test4Internal(nsIAppShell* aAppShell)
|
|
{
|
|
#ifndef XP_WIN
|
|
// Not sure how to test on other platforms.
|
|
return false;
|
|
#else
|
|
nsCOMPtr<nsIAppShellService> appService =
|
|
do_GetService(NS_APPSHELLSERVICE_CONTRACTID);
|
|
if (!appService) {
|
|
fail("Failed to get appshell service!");
|
|
return false;
|
|
}
|
|
|
|
nsCOMPtr<nsIURI> uri;
|
|
if (NS_FAILED(NS_NewURI(getter_AddRefs(uri), "about:", nullptr))) {
|
|
fail("Failed to create new uri");
|
|
return false;
|
|
}
|
|
|
|
uint32_t flags = nsIWebBrowserChrome::CHROME_DEFAULT;
|
|
|
|
nsCOMPtr<nsIXULWindow> xulWindow;
|
|
if (NS_FAILED(appService->CreateTopLevelWindow(nullptr, uri, flags, 100, 100, nullptr,
|
|
getter_AddRefs(xulWindow)))) {
|
|
fail("Failed to create new window");
|
|
return false;
|
|
}
|
|
|
|
nsCOMPtr<nsIDOMWindow> window = do_GetInterface(xulWindow);
|
|
if (!window) {
|
|
fail("Can't get dom window!");
|
|
return false;
|
|
}
|
|
|
|
nsCOMPtr<nsIDOMEventTarget> target = do_QueryInterface(window);
|
|
if (!target) {
|
|
fail("Can't QI to nsIDOMEventTarget!");
|
|
return false;
|
|
}
|
|
|
|
nsCOMPtr<nsIDOMEventListener> listener = new EventListener(aAppShell);
|
|
if (NS_FAILED(target->AddEventListener(NS_LITERAL_STRING("keypress"),
|
|
listener, false, false)) ||
|
|
NS_FAILED(target->AddEventListener(NS_LITERAL_STRING("load"), listener,
|
|
false, false))) {
|
|
fail("Can't add event listeners!");
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
#endif
|
|
}
|
|
|
|
void
|
|
Test4(nsIAppShell* aAppShell)
|
|
{
|
|
if (!Test4Internal(aAppShell)) {
|
|
nsCOMPtr<nsIRunnable> runnable = new NextTestRunnable(aAppShell);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch next test runnable");
|
|
}
|
|
}
|
|
}
|
|
|
|
const TestFunc gTests[] = {
|
|
Test1, Test2, Test3, Test4
|
|
};
|
|
|
|
size_t gTestIndex = 0;
|
|
|
|
NS_IMETHODIMP
|
|
NextTestRunnable::Run()
|
|
{
|
|
if (gTestIndex > 0) {
|
|
passed("Finished test %u", gTestIndex);
|
|
}
|
|
|
|
gStableStateEventHasRun = false;
|
|
|
|
if (gTestIndex < ArrayLength(gTests)) {
|
|
gTests[gTestIndex++](mAppShell);
|
|
}
|
|
else {
|
|
nsCOMPtr<nsIRunnable> exitRunnable = new ExitAppShellRunnable(mAppShell);
|
|
|
|
nsresult rv = NS_DispatchToCurrentThread(exitRunnable);
|
|
if (NS_FAILED(rv)) {
|
|
fail("Failed to dispatch exit runnable!");
|
|
}
|
|
}
|
|
|
|
return NS_OK;
|
|
}
|
|
|
|
int main(int argc, char** argv)
|
|
{
|
|
ScopedLogging log;
|
|
ScopedXPCOM xpcom("TestAppShellSteadyState");
|
|
|
|
if (!xpcom.failed()) {
|
|
nsCOMPtr<nsIAppShell> appShell = GetAppShell();
|
|
if (!appShell) {
|
|
fail("Couldn't get appshell!");
|
|
} else {
|
|
nsCOMPtr<nsIRunnable> runnable = new NextTestRunnable(appShell);
|
|
if (NS_FAILED(NS_DispatchToCurrentThread(runnable))) {
|
|
fail("Failed to dispatch next test runnable");
|
|
} else if (NS_FAILED(appShell->Run())) {
|
|
fail("Failed to run appshell");
|
|
}
|
|
}
|
|
}
|
|
|
|
return gFailCount != 0;
|
|
}
|