Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "base/command_line.h" | |
| 6 #include "base/perftimer.h" | |
| 7 #include "base/string_number_conversions.h" | |
| 8 #include "ppapi/c/ppp_messaging.h" | |
| 9 #include "ppapi/proxy/ppapi_proxy_test.h" | |
| 10 #include "ppapi/proxy/serialized_var.h" | |
| 11 #include "ppapi/shared_impl/ppapi_globals.h" | |
| 12 #include "ppapi/shared_impl/var.h" | |
| 13 #include "ppapi/shared_impl/var_tracker.h" | |
| 14 | |
| 15 namespace ppapi { | |
| 16 namespace proxy { | |
| 17 namespace { | |
| 18 | |
| 19 base::WaitableEvent handle_message_called(false, false); | |
| 20 | |
| 21 void HandleMessage(PP_Instance /* instance */, PP_Var /* message_data */) { | |
| 22 handle_message_called.Signal(); | |
| 23 } | |
| 24 | |
| 25 PPP_Messaging ppp_messaging_mock = { | |
| 26 &HandleMessage | |
| 27 }; | |
| 28 | |
| 29 class PppMessagingPerfTest : public TwoWayTest { | |
| 30 public: | |
| 31 PppMessagingPerfTest() : TwoWayTest(TwoWayTest::TEST_PPP_INTERFACE) { | |
| 32 plugin().RegisterTestInterface(PPP_MESSAGING_INTERFACE, | |
| 33 &ppp_messaging_mock); | |
| 34 } | |
| 35 }; | |
| 36 | |
| 37 } // namespace | |
| 38 | |
| 39 // Tests the performance of sending strings through the proxy. | |
| 40 TEST_F(PppMessagingPerfTest, StringPerformance) { | |
| 41 // Grab the host-side proxy of ppp_messaging. | |
| 42 const PPP_Messaging* ppp_messaging = static_cast<const PPP_Messaging*>( | |
| 43 host().host_dispatcher()->GetProxiedInterface( | |
| 44 PPP_MESSAGING_INTERFACE)); | |
| 45 const PP_Instance kTestInstance = pp_instance(); | |
| 46 int string_size = 100000; | |
| 47 int string_count = 1000; | |
| 48 CommandLine* command_line = CommandLine::ForCurrentProcess(); | |
| 49 if (command_line) { | |
| 50 if (command_line->HasSwitch("string_size")) { | |
| 51 base::StringToInt(command_line->GetSwitchValueASCII("string_size"), | |
| 52 &string_size); | |
| 53 } | |
| 54 if (command_line->HasSwitch("string_count")) { | |
| 55 base::StringToInt(command_line->GetSwitchValueASCII("string_count"), | |
| 56 &string_count); | |
| 57 } | |
| 58 } | |
| 59 // Make a string var of size string_size. | |
| 60 const std::string kTestString(string_size, 'a'); | |
| 61 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
| |
| 62 PerfTimeLogger logger("PppMessagingPerfTest.StringPerformance"); | |
| 63 for (int i = 0; i < string_count; ++i) { | |
| 64 ppp_messaging->HandleMessage(kTestInstance, host_string); | |
| 65 handle_message_called.Wait(); | |
| 66 } | |
| 67 PpapiGlobals::Get()->GetVarTracker()->ReleaseVar(host_string); | |
| 68 } | |
| 69 | |
| 70 } // namespace proxy | |
| 71 } // namespace ppapi | |
| 72 | |
| OLD | NEW |