diff options
Diffstat (limited to 'ipc/ipdl/test/cxx/TestInterruptErrorCleanup.h')
-rw-r--r-- | ipc/ipdl/test/cxx/TestInterruptErrorCleanup.h | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/ipc/ipdl/test/cxx/TestInterruptErrorCleanup.h b/ipc/ipdl/test/cxx/TestInterruptErrorCleanup.h new file mode 100644 index 000000000..bd45b2c98 --- /dev/null +++ b/ipc/ipdl/test/cxx/TestInterruptErrorCleanup.h @@ -0,0 +1,60 @@ +#ifndef mozilla__ipdltest_TestInterruptErrorCleanup_h +#define mozilla__ipdltest_TestInterruptErrorCleanup_h 1 + +#include "mozilla/_ipdltest/IPDLUnitTests.h" + +#include "mozilla/_ipdltest/PTestInterruptErrorCleanupParent.h" +#include "mozilla/_ipdltest/PTestInterruptErrorCleanupChild.h" + +namespace mozilla { +namespace _ipdltest { + + +class TestInterruptErrorCleanupParent : + public PTestInterruptErrorCleanupParent +{ +public: + TestInterruptErrorCleanupParent(); + virtual ~TestInterruptErrorCleanupParent(); + + static bool RunTestInProcesses() { return true; } + // FIXME/bug 703323 Could work if modified + static bool RunTestInThreads() { return false; } + + void Main(); + +protected: + virtual void ActorDestroy(ActorDestroyReason why) override + { + if (AbnormalShutdown != why) + fail("unexpected destruction!"); + } + + virtual void ProcessingError(Result aCode, const char* aReason) override; + + bool mGotProcessingError; +}; + + +class TestInterruptErrorCleanupChild : + public PTestInterruptErrorCleanupChild +{ +public: + TestInterruptErrorCleanupChild(); + virtual ~TestInterruptErrorCleanupChild(); + +protected: + virtual bool AnswerError() override; + + virtual void ActorDestroy(ActorDestroyReason why) override + { + fail("should have 'crashed'!"); + } +}; + + +} // namespace _ipdltest +} // namespace mozilla + + +#endif // ifndef mozilla__ipdltest_TestInterruptErrorCleanup_h |