diff options
Diffstat (limited to 'ipc/ipdl/test/cxx/TestInterruptShutdownRace.h')
-rw-r--r-- | ipc/ipdl/test/cxx/TestInterruptShutdownRace.h | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/ipc/ipdl/test/cxx/TestInterruptShutdownRace.h b/ipc/ipdl/test/cxx/TestInterruptShutdownRace.h new file mode 100644 index 000000000..c291b14a6 --- /dev/null +++ b/ipc/ipdl/test/cxx/TestInterruptShutdownRace.h @@ -0,0 +1,64 @@ +#ifndef mozilla__ipdltest_TestInterruptShutdownRace_h +#define mozilla__ipdltest_TestInterruptShutdownRace_h 1 + +#include "mozilla/_ipdltest/IPDLUnitTests.h" + +#include "mozilla/_ipdltest/PTestInterruptShutdownRaceParent.h" +#include "mozilla/_ipdltest/PTestInterruptShutdownRaceChild.h" + +namespace mozilla { +namespace _ipdltest { + + +class TestInterruptShutdownRaceParent : + public PTestInterruptShutdownRaceParent +{ +public: + TestInterruptShutdownRaceParent(); + virtual ~TestInterruptShutdownRaceParent(); + + static bool RunTestInProcesses() { return true; } + // FIXME/bug 703323 Could work if modified + static bool RunTestInThreads() { return false; } + + void Main(); + + virtual bool RecvStartDeath() override; + + virtual bool RecvOrphan() override; + +protected: + void StartShuttingDown(); + + virtual void ActorDestroy(ActorDestroyReason why) override + { + if (AbnormalShutdown != why) + fail("unexpected destruction!"); + } +}; + + +class TestInterruptShutdownRaceChild : + public PTestInterruptShutdownRaceChild +{ +public: + TestInterruptShutdownRaceChild(); + virtual ~TestInterruptShutdownRaceChild(); + +protected: + virtual bool RecvStart() override; + + virtual bool AnswerExit() override; + + virtual void ActorDestroy(ActorDestroyReason why) override + { + fail("should have 'crashed'!"); + } +}; + + +} // namespace _ipdltest +} // namespace mozilla + + +#endif // ifndef mozilla__ipdltest_TestInterruptShutdownRace_h |