2009-10-13 15:36:28 -07:00
|
|
|
#ifndef mozilla__ipdltest_TestLatency_h
|
|
|
|
#define mozilla__ipdltest_TestLatency_h 1
|
|
|
|
|
2009-12-03 00:16:28 -08:00
|
|
|
#include "mozilla/_ipdltest/IPDLUnitTests.h"
|
2009-10-13 15:36:28 -07:00
|
|
|
|
|
|
|
#include "mozilla/_ipdltest/PTestLatencyParent.h"
|
|
|
|
#include "mozilla/_ipdltest/PTestLatencyChild.h"
|
|
|
|
|
2009-10-13 21:08:24 -07:00
|
|
|
#include "mozilla/TimeStamp.h"
|
|
|
|
|
2009-12-03 00:16:28 -08:00
|
|
|
#define NR_TRIALS 10000
|
|
|
|
|
2009-10-13 15:36:28 -07:00
|
|
|
namespace mozilla {
|
|
|
|
namespace _ipdltest {
|
|
|
|
|
|
|
|
class TestLatencyParent :
|
|
|
|
public PTestLatencyParent
|
|
|
|
{
|
|
|
|
private:
|
|
|
|
typedef mozilla::TimeStamp TimeStamp;
|
|
|
|
typedef mozilla::TimeDuration TimeDuration;
|
|
|
|
|
|
|
|
public:
|
|
|
|
TestLatencyParent();
|
|
|
|
virtual ~TestLatencyParent();
|
|
|
|
|
|
|
|
void Main();
|
|
|
|
|
2009-12-03 00:16:28 -08:00
|
|
|
protected:
|
|
|
|
NS_OVERRIDE
|
2009-10-13 15:36:28 -07:00
|
|
|
virtual bool RecvPong();
|
2009-12-03 00:16:28 -08:00
|
|
|
NS_OVERRIDE
|
2009-10-13 15:36:28 -07:00
|
|
|
virtual bool RecvPong5();
|
|
|
|
|
2009-12-03 00:16:28 -08:00
|
|
|
NS_OVERRIDE
|
|
|
|
virtual void ActorDestroy(ActorDestroyReason why)
|
|
|
|
{
|
|
|
|
if (NormalShutdown != why)
|
|
|
|
fail("unexpected destruction!");
|
|
|
|
|
2010-02-04 19:40:42 -08:00
|
|
|
passed("average ping/pong latency: %g sec, "
|
|
|
|
"average ping5/pong5 latency: %g sec, "
|
|
|
|
"average RPC call/answer: %g sec",
|
2010-01-11 21:46:17 -08:00
|
|
|
mPPTimeTotal.ToSecondsSigDigits() / (double) NR_TRIALS,
|
2010-02-04 19:40:42 -08:00
|
|
|
mPP5TimeTotal.ToSecondsSigDigits() / (double) NR_TRIALS,
|
|
|
|
mRpcTimeTotal.ToSecondsSigDigits() / (double) NR_TRIALS);
|
2009-12-03 00:16:28 -08:00
|
|
|
|
|
|
|
QuitParent();
|
|
|
|
}
|
|
|
|
|
2009-10-13 15:36:28 -07:00
|
|
|
private:
|
|
|
|
void PingPongTrial();
|
|
|
|
void Ping5Pong5Trial();
|
2010-02-04 19:40:42 -08:00
|
|
|
void RpcTrials();
|
2009-10-13 15:36:28 -07:00
|
|
|
void Exit();
|
|
|
|
|
|
|
|
TimeStamp mStart;
|
|
|
|
TimeDuration mPPTimeTotal;
|
|
|
|
TimeDuration mPP5TimeTotal;
|
2010-02-04 19:40:42 -08:00
|
|
|
TimeDuration mRpcTimeTotal;
|
2009-10-13 15:36:28 -07:00
|
|
|
|
|
|
|
int mPPTrialsToGo;
|
|
|
|
int mPP5TrialsToGo;
|
|
|
|
|
|
|
|
// FIXME/cjones: HACK ALERT: don't need this once IPDL exposes actor state
|
|
|
|
int mPongsToGo;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class TestLatencyChild :
|
|
|
|
public PTestLatencyChild
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
TestLatencyChild();
|
|
|
|
virtual ~TestLatencyChild();
|
|
|
|
|
|
|
|
protected:
|
2009-12-03 00:16:28 -08:00
|
|
|
NS_OVERRIDE
|
2009-10-13 15:36:28 -07:00
|
|
|
virtual bool RecvPing();
|
2009-12-03 00:16:28 -08:00
|
|
|
NS_OVERRIDE
|
2009-10-13 15:36:28 -07:00
|
|
|
virtual bool RecvPing5();
|
2010-02-04 19:40:42 -08:00
|
|
|
NS_OVERRIDE
|
|
|
|
virtual bool AnswerRpc();
|
2009-12-03 00:16:28 -08:00
|
|
|
|
|
|
|
NS_OVERRIDE
|
|
|
|
virtual void ActorDestroy(ActorDestroyReason why)
|
|
|
|
{
|
|
|
|
if (NormalShutdown != why)
|
|
|
|
fail("unexpected destruction!");
|
|
|
|
QuitChild();
|
|
|
|
}
|
2009-10-13 15:36:28 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace _ipdltest
|
|
|
|
} // namespace mozilla
|
|
|
|
|
|
|
|
|
|
|
|
#endif // ifndef mozilla__ipdltest_TestLatency_h
|