OLD | NEW |
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "components/page_load_metrics/common/page_load_metrics_messages.h" | 5 #include "components/page_load_metrics/common/page_load_metrics_messages.h" |
6 #include "components/page_load_metrics/renderer/fake_page_timing_metrics_ipc_sen
der.h" | 6 #include "components/page_load_metrics/renderer/fake_page_load_metrics.h" |
7 #include "ipc/ipc_message.h" | 7 #include "ipc/ipc_message.h" |
8 #include "ipc/ipc_message_macros.h" | 8 #include "ipc/ipc_message_macros.h" |
9 #include "testing/gtest/include/gtest/gtest.h" | 9 #include "testing/gtest/include/gtest/gtest.h" |
10 | 10 |
11 namespace page_load_metrics { | 11 namespace page_load_metrics { |
12 | 12 |
13 FakePageTimingMetricsIPCSender::FakePageTimingMetricsIPCSender() {} | 13 FakePageLoadMetrics::FakePageLoadMetrics() {} |
14 | 14 |
15 FakePageTimingMetricsIPCSender::~FakePageTimingMetricsIPCSender() { | 15 FakePageLoadMetrics::~FakePageLoadMetrics() { |
16 VerifyExpectedTimings(); | 16 VerifyExpectedTimings(); |
17 } | 17 } |
18 | 18 |
19 void FakePageTimingMetricsIPCSender::ExpectPageLoadTiming( | 19 void FakePageLoadMetrics::ExpectPageLoadTiming(const PageLoadTiming& timing) { |
20 const PageLoadTiming& timing) { | |
21 VerifyExpectedTimings(); | 20 VerifyExpectedTimings(); |
22 expected_timings_.push_back(timing); | 21 expected_timings_.push_back(timing); |
23 } | 22 } |
24 | 23 |
25 void FakePageTimingMetricsIPCSender::VerifyExpectedTimings() const { | 24 void FakePageLoadMetrics::VerifyExpectedTimings() const { |
26 // Ideally we'd just call ASSERT_EQ(actual_timings_, expected_timings_) here, | 25 // Ideally we'd just call ASSERT_EQ(actual_timings_, expected_timings_) here, |
27 // but this causes the generated gtest code to fail to build on Windows. See | 26 // but this causes the generated gtest code to fail to build on Windows. See |
28 // the comments in the header file for additional details. | 27 // the comments in the header file for additional details. |
29 ASSERT_EQ(actual_timings_.size(), expected_timings_.size()); | 28 ASSERT_EQ(actual_timings_.size(), expected_timings_.size()); |
30 for (size_t i = 0; i < actual_timings_.size(); ++i) { | 29 for (size_t i = 0; i < actual_timings_.size(); ++i) { |
31 if (actual_timings_.at(i) == expected_timings_.at(i)) | 30 if (actual_timings_.at(i) == expected_timings_.at(i)) |
32 continue; | 31 continue; |
33 ADD_FAILURE() << "Actual timing != expected timing at index " << i; | 32 ADD_FAILURE() << "Actual timing != expected timing at index " << i; |
34 } | 33 } |
35 } | 34 } |
36 | 35 |
37 bool FakePageTimingMetricsIPCSender::Send(IPC::Message* message) { | 36 void FakePageLoadMetrics::TimingUpdated(const PageLoadTiming& timing, |
38 IPC_BEGIN_MESSAGE_MAP(FakePageTimingMetricsIPCSender, *message) | 37 const PageLoadMetadata& metadata) { |
39 IPC_MESSAGE_HANDLER(PageLoadMetricsMsg_TimingUpdated, OnTimingUpdated) | |
40 IPC_MESSAGE_UNHANDLED(ADD_FAILURE()) | |
41 IPC_END_MESSAGE_MAP() | |
42 | |
43 delete message; | |
44 return true; | |
45 } | |
46 | |
47 void FakePageTimingMetricsIPCSender::OnTimingUpdated( | |
48 const PageLoadTiming& timing, | |
49 PageLoadMetadata metadata) { | |
50 actual_timings_.push_back(timing); | 38 actual_timings_.push_back(timing); |
51 VerifyExpectedTimings(); | 39 VerifyExpectedTimings(); |
52 } | 40 } |
53 | 41 |
54 } // namespace page_load_metrics | 42 } // namespace page_load_metrics |
OLD | NEW |