diff options
Diffstat (limited to 'ipc/ipdl/test/cxx/TestRacyUndefer.cpp')
-rw-r--r-- | ipc/ipdl/test/cxx/TestRacyUndefer.cpp | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/ipc/ipdl/test/cxx/TestRacyUndefer.cpp b/ipc/ipdl/test/cxx/TestRacyUndefer.cpp new file mode 100644 index 000000000..8bdd804cc --- /dev/null +++ b/ipc/ipdl/test/cxx/TestRacyUndefer.cpp @@ -0,0 +1,115 @@ +#include "base/basictypes.h" + +#include "TestRacyUndefer.h" + +#include "IPDLUnitTests.h" // fail etc. + +namespace mozilla { +namespace _ipdltest { + +//----------------------------------------------------------------------------- +// parent + +TestRacyUndeferParent::TestRacyUndeferParent() +{ + MOZ_COUNT_CTOR(TestRacyUndeferParent); +} + +TestRacyUndeferParent::~TestRacyUndeferParent() +{ + MOZ_COUNT_DTOR(TestRacyUndeferParent); +} + +void +TestRacyUndeferParent::Main() +{ + if (!SendStart()) + fail("sending Start"); +} + +bool +TestRacyUndeferParent::AnswerSpam() +{ + static bool spammed = false; + static bool raced = false; + if (!spammed) { + spammed = true; + + if (!SendAwakenSpam()) + fail("sending AwakenSpam"); + } + else if (!raced) { + raced = true; + + if (!SendAwakenRaceWinTwice()) + fail("sending WinRaceTwice"); + + if (!CallRace()) + fail("calling Race1"); + } + return true; +} + +bool +TestRacyUndeferParent::AnswerRaceWinTwice() +{ + return true; +} + +bool +TestRacyUndeferParent::RecvDone() +{ + Close(); + return true; +} + + +//----------------------------------------------------------------------------- +// child + +TestRacyUndeferChild::TestRacyUndeferChild() +{ + MOZ_COUNT_CTOR(TestRacyUndeferChild); +} + +TestRacyUndeferChild::~TestRacyUndeferChild() +{ + MOZ_COUNT_DTOR(TestRacyUndeferChild); +} + +bool +TestRacyUndeferChild::RecvStart() +{ + if (!CallSpam()) + fail("calling Spam"); + + if (!SendDone()) + fail("sending Done"); + + return true; +} + +bool +TestRacyUndeferChild::RecvAwakenSpam() +{ + if (!CallSpam()) + fail("calling Spam"); + return true; +} + +bool +TestRacyUndeferChild::RecvAwakenRaceWinTwice() +{ + if (!CallRaceWinTwice()) + fail("calling RaceWinTwice"); + return true; +} + +bool +TestRacyUndeferChild::AnswerRace() +{ + return true; +} + +} // namespace _ipdltest +} // namespace mozilla |