summaryrefslogtreecommitdiff
path: root/ipc/ipdl/test/cxx/TestBridgeMain.h
diff options
context:
space:
mode:
Diffstat (limited to 'ipc/ipdl/test/cxx/TestBridgeMain.h')
-rw-r--r--ipc/ipdl/test/cxx/TestBridgeMain.h149
1 files changed, 149 insertions, 0 deletions
diff --git a/ipc/ipdl/test/cxx/TestBridgeMain.h b/ipc/ipdl/test/cxx/TestBridgeMain.h
new file mode 100644
index 0000000000..a5c7c10cbc
--- /dev/null
+++ b/ipc/ipdl/test/cxx/TestBridgeMain.h
@@ -0,0 +1,149 @@
+#ifndef mozilla__ipdltest_TestBridgeMain_h
+#define mozilla__ipdltest_TestBridgeMain_h 1
+
+#include "mozilla/_ipdltest/IPDLUnitTests.h"
+
+#include "mozilla/_ipdltest/PTestBridgeMainParent.h"
+#include "mozilla/_ipdltest/PTestBridgeMainChild.h"
+
+#include "mozilla/_ipdltest/PTestBridgeSubParent.h"
+#include "mozilla/_ipdltest/PTestBridgeSubChild.h"
+
+#include "mozilla/_ipdltest/PTestBridgeMainSubParent.h"
+#include "mozilla/_ipdltest/PTestBridgeMainSubChild.h"
+
+namespace mozilla {
+namespace _ipdltest {
+
+//-----------------------------------------------------------------------------
+// "Main" process
+//
+class TestBridgeMainParent :
+ public PTestBridgeMainParent
+{
+public:
+ TestBridgeMainParent() {}
+ virtual ~TestBridgeMainParent() {}
+
+ static bool RunTestInProcesses() { return true; }
+ static bool RunTestInThreads() { return false; }
+
+ void Main();
+
+protected:
+ virtual PTestBridgeMainSubParent*
+ AllocPTestBridgeMainSubParent(Transport* transport,
+ ProcessId otherProcess) override;
+
+ virtual void ActorDestroy(ActorDestroyReason why) override;
+};
+
+class TestBridgeMainSubParent :
+ public PTestBridgeMainSubParent
+{
+public:
+ explicit TestBridgeMainSubParent(Transport* aTransport)
+ : mTransport(aTransport)
+ {}
+ virtual ~TestBridgeMainSubParent() {}
+
+protected:
+ virtual bool RecvHello() override;
+ virtual bool RecvHelloSync() override;
+ virtual bool AnswerHelloRpc() override;
+
+ virtual void ActorDestroy(ActorDestroyReason why) override;
+
+ Transport* mTransport;
+};
+
+//-----------------------------------------------------------------------------
+// "Sub" process --- child of "main"
+//
+class TestBridgeSubParent;
+
+class TestBridgeMainChild :
+ public PTestBridgeMainChild
+{
+public:
+ TestBridgeMainChild();
+ virtual ~TestBridgeMainChild() {}
+
+protected:
+ virtual bool RecvStart() override;
+
+ virtual PTestBridgeMainSubChild*
+ AllocPTestBridgeMainSubChild(Transport* transport,
+ ProcessId otherProcess) override
+ {
+ // This shouldn't be called. It's just a byproduct of testing that
+ // the right code is generated for a bridged protocol that's also
+ // opened, but we only test bridging here.
+ MOZ_CRASH();
+ }
+
+ virtual void ActorDestroy(ActorDestroyReason why) override;
+
+ IPDLUnitTestSubprocess* mSubprocess;
+};
+
+class TestBridgeSubParent :
+ public PTestBridgeSubParent
+{
+public:
+ TestBridgeSubParent() {}
+ virtual ~TestBridgeSubParent() {}
+
+ void Main();
+
+protected:
+ virtual bool RecvBridgeEm() override;
+
+ virtual void ActorDestroy(ActorDestroyReason why) override;
+};
+
+//-----------------------------------------------------------------------------
+// "Subsub" process --- child of "sub"
+//
+class TestBridgeSubChild :
+ public PTestBridgeSubChild
+{
+public:
+ TestBridgeSubChild();
+ virtual ~TestBridgeSubChild() {}
+
+protected:
+ virtual bool RecvPing() override;
+
+ virtual PTestBridgeMainSubChild*
+ AllocPTestBridgeMainSubChild(Transport* transport,
+ ProcessId otherProcess) override;
+
+ virtual void ActorDestroy(ActorDestroyReason why) override;
+};
+
+class TestBridgeMainSubChild :
+ public PTestBridgeMainSubChild
+{
+public:
+ explicit TestBridgeMainSubChild(Transport* aTransport)
+ : mGotHi(false)
+ , mTransport(aTransport)
+ {}
+ virtual ~TestBridgeMainSubChild() {}
+
+protected:
+ virtual bool RecvHi() override;
+ virtual bool AnswerHiRpc() override;
+
+ virtual void ActorDestroy(ActorDestroyReason why) override;
+
+ bool mGotHi;
+ Transport* mTransport;
+};
+
+} // namespace _ipdltest
+} // namespace mozilla
+
+
+#endif // ifndef mozilla__ipdltest_TestBridgeMain_h