 Chromium Code Reviews
 Chromium Code Reviews Issue 9195029:
  Add ppapi perftests infrastructure, plus a performance test for PPP_Messaging.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src
    
  
    Issue 9195029:
  Add ppapi perftests infrastructure, plus a performance test for PPP_Messaging.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src| Index: ppapi/proxy/ppp_messaging_proxy_perftest.cc | 
| diff --git a/ppapi/proxy/ppp_messaging_proxy_perftest.cc b/ppapi/proxy/ppp_messaging_proxy_perftest.cc | 
| new file mode 100644 | 
| index 0000000000000000000000000000000000000000..ba9eed21cd2ad306674e794583d9d254f457e911 | 
| --- /dev/null | 
| +++ b/ppapi/proxy/ppp_messaging_proxy_perftest.cc | 
| @@ -0,0 +1,72 @@ | 
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. | 
| +// Use of this source code is governed by a BSD-style license that can be | 
| +// found in the LICENSE file. | 
| + | 
| +#include "base/command_line.h" | 
| +#include "base/perftimer.h" | 
| +#include "base/string_number_conversions.h" | 
| +#include "ppapi/c/ppp_messaging.h" | 
| +#include "ppapi/proxy/ppapi_proxy_test.h" | 
| +#include "ppapi/proxy/serialized_var.h" | 
| +#include "ppapi/shared_impl/ppapi_globals.h" | 
| +#include "ppapi/shared_impl/var.h" | 
| +#include "ppapi/shared_impl/var_tracker.h" | 
| + | 
| +namespace ppapi { | 
| +namespace proxy { | 
| +namespace { | 
| + | 
| +base::WaitableEvent handle_message_called(false, false); | 
| + | 
| +void HandleMessage(PP_Instance /* instance */, PP_Var /* message_data */) { | 
| + handle_message_called.Signal(); | 
| +} | 
| + | 
| +PPP_Messaging ppp_messaging_mock = { | 
| + &HandleMessage | 
| +}; | 
| + | 
| +class PppMessagingPerfTest : public TwoWayTest { | 
| + public: | 
| + PppMessagingPerfTest() : TwoWayTest(TwoWayTest::TEST_PPP_INTERFACE) { | 
| + plugin().RegisterTestInterface(PPP_MESSAGING_INTERFACE, | 
| + &ppp_messaging_mock); | 
| + } | 
| +}; | 
| + | 
| +} // namespace | 
| + | 
| +// Tests the performance of sending strings through the proxy. | 
| +TEST_F(PppMessagingPerfTest, StringPerformance) { | 
| + // Grab the host-side proxy of ppp_messaging. | 
| + const PPP_Messaging* ppp_messaging = static_cast<const PPP_Messaging*>( | 
| + host().host_dispatcher()->GetProxiedInterface( | 
| + PPP_MESSAGING_INTERFACE)); | 
| + const PP_Instance kTestInstance = pp_instance(); | 
| + int string_size = 100000; | 
| + int string_count = 1000; | 
| + CommandLine* command_line = CommandLine::ForCurrentProcess(); | 
| + if (command_line) { | 
| + if (command_line->HasSwitch("string_size")) { | 
| + base::StringToInt(command_line->GetSwitchValueASCII("string_size"), | 
| + &string_size); | 
| + } | 
| + if (command_line->HasSwitch("string_count")) { | 
| + base::StringToInt(command_line->GetSwitchValueASCII("string_count"), | 
| + &string_count); | 
| + } | 
| + } | 
| + // Make a string var of size string_size. | 
| + const std::string kTestString(string_size, 'a'); | 
| + PP_Var host_string = StringVar::StringToPPVar(kTestString); | 
| 
piman
2012/01/20 17:39:23
TBH, if you truly want to measure the cost of send
 
dmichael (off chromium)
2012/01/20 17:53:20
I thought about doing it that way, but I decided t
 | 
| + PerfTimeLogger logger("PppMessagingPerfTest.StringPerformance"); | 
| + for (int i = 0; i < string_count; ++i) { | 
| + ppp_messaging->HandleMessage(kTestInstance, host_string); | 
| + handle_message_called.Wait(); | 
| + } | 
| + PpapiGlobals::Get()->GetVarTracker()->ReleaseVar(host_string); | 
| +} | 
| + | 
| +} // namespace proxy | 
| +} // namespace ppapi | 
| + |