diff -r 000000000000 -r 6474c204b198 ipc/ipdl/test/cxx/TestRacyInterruptReplies.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/ipc/ipdl/test/cxx/TestRacyInterruptReplies.h Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,73 @@ +#ifndef mozilla__ipdltest_TestRacyInterruptReplies_h +#define mozilla__ipdltest_TestRacyInterruptReplies_h 1 + +#include "mozilla/_ipdltest/IPDLUnitTests.h" + +#include "mozilla/_ipdltest/PTestRacyInterruptRepliesParent.h" +#include "mozilla/_ipdltest/PTestRacyInterruptRepliesChild.h" + +namespace mozilla { +namespace _ipdltest { + + +class TestRacyInterruptRepliesParent : + public PTestRacyInterruptRepliesParent +{ +public: + TestRacyInterruptRepliesParent(); + virtual ~TestRacyInterruptRepliesParent(); + + static bool RunTestInProcesses() { return true; } + static bool RunTestInThreads() { return true; } + + void Main(); + +protected: + virtual bool RecvA_() MOZ_OVERRIDE; + + virtual bool Answer_R(int* replyNum) MOZ_OVERRIDE; + + virtual void ActorDestroy(ActorDestroyReason why) MOZ_OVERRIDE + { + if (NormalShutdown != why) + fail("unexpected destruction!"); + passed("ok"); + QuitParent(); + } + +private: + int mReplyNum; +}; + + +class TestRacyInterruptRepliesChild : + public PTestRacyInterruptRepliesChild +{ +public: + TestRacyInterruptRepliesChild(); + virtual ~TestRacyInterruptRepliesChild(); + +protected: + virtual bool AnswerR_(int* replyNum) MOZ_OVERRIDE; + + virtual bool RecvChildTest() MOZ_OVERRIDE; + + virtual bool Recv_A() MOZ_OVERRIDE; + + virtual void ActorDestroy(ActorDestroyReason why) MOZ_OVERRIDE + { + if (NormalShutdown != why) + fail("unexpected destruction!"); + QuitChild(); + } + +private: + int mReplyNum; +}; + + +} // namespace _ipdltest +} // namespace mozilla + + +#endif // ifndef mozilla__ipdltest_TestRacyInterruptReplies_h