| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "media/cast/logging/simple_event_subscriber.h" | 5 #include "media/cast/logging/simple_event_subscriber.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/memory/ref_counted.h" | 9 #include "base/memory/ref_counted.h" |
| 10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
| (...skipping 29 matching lines...) Expand all Loading... |
| 40 scoped_refptr<CastEnvironment> cast_environment_; | 40 scoped_refptr<CastEnvironment> cast_environment_; |
| 41 SimpleEventSubscriber event_subscriber_; | 41 SimpleEventSubscriber event_subscriber_; |
| 42 }; | 42 }; |
| 43 | 43 |
| 44 TEST_F(SimpleEventSubscriberTest, GetAndResetEvents) { | 44 TEST_F(SimpleEventSubscriberTest, GetAndResetEvents) { |
| 45 // Log some frame events. | 45 // Log some frame events. |
| 46 scoped_ptr<FrameEvent> encode_event(new FrameEvent()); | 46 scoped_ptr<FrameEvent> encode_event(new FrameEvent()); |
| 47 encode_event->timestamp = testing_clock_->NowTicks(); | 47 encode_event->timestamp = testing_clock_->NowTicks(); |
| 48 encode_event->type = FRAME_ENCODED; | 48 encode_event->type = FRAME_ENCODED; |
| 49 encode_event->media_type = AUDIO_EVENT; | 49 encode_event->media_type = AUDIO_EVENT; |
| 50 encode_event->rtp_timestamp = 100u; | 50 encode_event->rtp_timestamp = RtpTimeTicks().Expand(UINT32_C(100)); |
| 51 encode_event->frame_id = 0u; | 51 encode_event->frame_id = 0u; |
| 52 encode_event->size = 1234; | 52 encode_event->size = 1234; |
| 53 encode_event->key_frame = true; | 53 encode_event->key_frame = true; |
| 54 encode_event->target_bitrate = 128u; | 54 encode_event->target_bitrate = 128u; |
| 55 encode_event->encoder_cpu_utilization = 0.01; | 55 encode_event->encoder_cpu_utilization = 0.01; |
| 56 encode_event->idealized_bitrate_utilization = 0.02; | 56 encode_event->idealized_bitrate_utilization = 0.02; |
| 57 cast_environment_->logger()->DispatchFrameEvent(std::move(encode_event)); | 57 cast_environment_->logger()->DispatchFrameEvent(std::move(encode_event)); |
| 58 | 58 |
| 59 scoped_ptr<FrameEvent> playout_event(new FrameEvent()); | 59 scoped_ptr<FrameEvent> playout_event(new FrameEvent()); |
| 60 playout_event->timestamp = testing_clock_->NowTicks(); | 60 playout_event->timestamp = testing_clock_->NowTicks(); |
| 61 playout_event->type = FRAME_PLAYOUT; | 61 playout_event->type = FRAME_PLAYOUT; |
| 62 playout_event->media_type = AUDIO_EVENT; | 62 playout_event->media_type = AUDIO_EVENT; |
| 63 playout_event->rtp_timestamp = 100u; | 63 playout_event->rtp_timestamp = RtpTimeTicks().Expand(UINT32_C(100)); |
| 64 playout_event->frame_id = 0u; | 64 playout_event->frame_id = 0u; |
| 65 playout_event->delay_delta = base::TimeDelta::FromMilliseconds(100); | 65 playout_event->delay_delta = base::TimeDelta::FromMilliseconds(100); |
| 66 cast_environment_->logger()->DispatchFrameEvent(std::move(playout_event)); | 66 cast_environment_->logger()->DispatchFrameEvent(std::move(playout_event)); |
| 67 | 67 |
| 68 scoped_ptr<FrameEvent> decode_event(new FrameEvent()); | 68 scoped_ptr<FrameEvent> decode_event(new FrameEvent()); |
| 69 decode_event->timestamp = testing_clock_->NowTicks(); | 69 decode_event->timestamp = testing_clock_->NowTicks(); |
| 70 decode_event->type = FRAME_DECODED; | 70 decode_event->type = FRAME_DECODED; |
| 71 decode_event->media_type = AUDIO_EVENT; | 71 decode_event->media_type = AUDIO_EVENT; |
| 72 decode_event->rtp_timestamp = 200u; | 72 decode_event->rtp_timestamp = RtpTimeTicks().Expand(UINT32_C(200)); |
| 73 decode_event->frame_id = 0u; | 73 decode_event->frame_id = 0u; |
| 74 cast_environment_->logger()->DispatchFrameEvent(std::move(decode_event)); | 74 cast_environment_->logger()->DispatchFrameEvent(std::move(decode_event)); |
| 75 | 75 |
| 76 // Log some packet events. | 76 // Log some packet events. |
| 77 scoped_ptr<PacketEvent> receive_event(new PacketEvent()); | 77 scoped_ptr<PacketEvent> receive_event(new PacketEvent()); |
| 78 receive_event->timestamp = testing_clock_->NowTicks(); | 78 receive_event->timestamp = testing_clock_->NowTicks(); |
| 79 receive_event->type = PACKET_RECEIVED; | 79 receive_event->type = PACKET_RECEIVED; |
| 80 receive_event->media_type = AUDIO_EVENT; | 80 receive_event->media_type = AUDIO_EVENT; |
| 81 receive_event->rtp_timestamp = 200u; | 81 receive_event->rtp_timestamp = RtpTimeTicks().Expand(UINT32_C(200)); |
| 82 receive_event->frame_id = 0u; | 82 receive_event->frame_id = 0u; |
| 83 receive_event->packet_id = 1u; | 83 receive_event->packet_id = 1u; |
| 84 receive_event->max_packet_id = 5u; | 84 receive_event->max_packet_id = 5u; |
| 85 receive_event->size = 100u; | 85 receive_event->size = 100u; |
| 86 cast_environment_->logger()->DispatchPacketEvent(std::move(receive_event)); | 86 cast_environment_->logger()->DispatchPacketEvent(std::move(receive_event)); |
| 87 | 87 |
| 88 receive_event.reset(new PacketEvent()); | 88 receive_event.reset(new PacketEvent()); |
| 89 receive_event->timestamp = testing_clock_->NowTicks(); | 89 receive_event->timestamp = testing_clock_->NowTicks(); |
| 90 receive_event->type = PACKET_RECEIVED; | 90 receive_event->type = PACKET_RECEIVED; |
| 91 receive_event->media_type = VIDEO_EVENT; | 91 receive_event->media_type = VIDEO_EVENT; |
| 92 receive_event->rtp_timestamp = 200u; | 92 receive_event->rtp_timestamp = RtpTimeTicks().Expand(UINT32_C(200)); |
| 93 receive_event->frame_id = 0u; | 93 receive_event->frame_id = 0u; |
| 94 receive_event->packet_id = 1u; | 94 receive_event->packet_id = 1u; |
| 95 receive_event->max_packet_id = 10u; | 95 receive_event->max_packet_id = 10u; |
| 96 receive_event->size = 1024u; | 96 receive_event->size = 1024u; |
| 97 cast_environment_->logger()->DispatchPacketEvent(std::move(receive_event)); | 97 cast_environment_->logger()->DispatchPacketEvent(std::move(receive_event)); |
| 98 | 98 |
| 99 std::vector<FrameEvent> frame_events; | 99 std::vector<FrameEvent> frame_events; |
| 100 event_subscriber_.GetFrameEventsAndReset(&frame_events); | 100 event_subscriber_.GetFrameEventsAndReset(&frame_events); |
| 101 EXPECT_EQ(3u, frame_events.size()); | 101 EXPECT_EQ(3u, frame_events.size()); |
| 102 | 102 |
| 103 std::vector<PacketEvent> packet_events; | 103 std::vector<PacketEvent> packet_events; |
| 104 event_subscriber_.GetPacketEventsAndReset(&packet_events); | 104 event_subscriber_.GetPacketEventsAndReset(&packet_events); |
| 105 EXPECT_EQ(2u, packet_events.size()); | 105 EXPECT_EQ(2u, packet_events.size()); |
| 106 | 106 |
| 107 // Calling this function again should result in empty vector because no events | 107 // Calling this function again should result in empty vector because no events |
| 108 // were logged since last call. | 108 // were logged since last call. |
| 109 event_subscriber_.GetFrameEventsAndReset(&frame_events); | 109 event_subscriber_.GetFrameEventsAndReset(&frame_events); |
| 110 event_subscriber_.GetPacketEventsAndReset(&packet_events); | 110 event_subscriber_.GetPacketEventsAndReset(&packet_events); |
| 111 EXPECT_TRUE(frame_events.empty()); | 111 EXPECT_TRUE(frame_events.empty()); |
| 112 EXPECT_TRUE(packet_events.empty()); | 112 EXPECT_TRUE(packet_events.empty()); |
| 113 } | 113 } |
| 114 | 114 |
| 115 } // namespace cast | 115 } // namespace cast |
| 116 } // namespace media | 116 } // namespace media |
| OLD | NEW |