Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(314)

Side by Side Diff: media/cast/audio_sender/audio_sender_unittest.cc

Issue 280993002: [Cast] Repair receiver playout time calculations and frame skip logic. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 <stdint.h> 5 #include <stdint.h>
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/memory/scoped_ptr.h" 9 #include "base/memory/scoped_ptr.h"
10 #include "base/test/simple_test_tick_clock.h" 10 #include "base/test/simple_test_tick_clock.h"
11 #include "media/base/media.h" 11 #include "media/base/media.h"
12 #include "media/cast/audio_sender/audio_sender.h" 12 #include "media/cast/audio_sender/audio_sender.h"
13 #include "media/cast/cast_config.h" 13 #include "media/cast/cast_config.h"
14 #include "media/cast/cast_environment.h" 14 #include "media/cast/cast_environment.h"
15 #include "media/cast/rtcp/rtcp.h" 15 #include "media/cast/rtcp/rtcp.h"
16 #include "media/cast/test/fake_single_thread_task_runner.h" 16 #include "media/cast/test/fake_single_thread_task_runner.h"
17 #include "media/cast/test/utility/audio_utility.h" 17 #include "media/cast/test/utility/audio_utility.h"
18 #include "media/cast/transport/cast_transport_config.h" 18 #include "media/cast/transport/cast_transport_config.h"
19 #include "media/cast/transport/cast_transport_sender_impl.h" 19 #include "media/cast/transport/cast_transport_sender_impl.h"
20 #include "testing/gtest/include/gtest/gtest.h" 20 #include "testing/gtest/include/gtest/gtest.h"
21 21
22 namespace media { 22 namespace media {
23 namespace cast { 23 namespace cast {
24 24
25 static const int64 kStartMillisecond = INT64_C(12345678900000);
26
27 class TestPacketSender : public transport::PacketSender { 25 class TestPacketSender : public transport::PacketSender {
28 public: 26 public:
29 TestPacketSender() : number_of_rtp_packets_(0), number_of_rtcp_packets_(0) {} 27 TestPacketSender() : number_of_rtp_packets_(0), number_of_rtcp_packets_(0) {}
30 28
31 virtual bool SendPacket(transport::PacketRef packet, 29 virtual bool SendPacket(transport::PacketRef packet,
32 const base::Closure& cb) OVERRIDE { 30 const base::Closure& cb) OVERRIDE {
33 if (Rtcp::IsRtcpPacket(&packet->data[0], packet->data.size())) { 31 if (Rtcp::IsRtcpPacket(&packet->data[0], packet->data.size())) {
34 ++number_of_rtcp_packets_; 32 ++number_of_rtcp_packets_;
35 } else { 33 } else {
36 // Check that at least one RTCP packet was sent before the first RTP 34 // Check that at least one RTCP packet was sent before the first RTP
(...skipping 16 matching lines...) Expand all
53 int number_of_rtcp_packets_; 51 int number_of_rtcp_packets_;
54 52
55 DISALLOW_COPY_AND_ASSIGN(TestPacketSender); 53 DISALLOW_COPY_AND_ASSIGN(TestPacketSender);
56 }; 54 };
57 55
58 class AudioSenderTest : public ::testing::Test { 56 class AudioSenderTest : public ::testing::Test {
59 protected: 57 protected:
60 AudioSenderTest() { 58 AudioSenderTest() {
61 InitializeMediaLibraryForTesting(); 59 InitializeMediaLibraryForTesting();
62 testing_clock_ = new base::SimpleTestTickClock(); 60 testing_clock_ = new base::SimpleTestTickClock();
63 testing_clock_->Advance( 61 testing_clock_->Advance(base::TimeTicks::Now() - base::TimeTicks());
64 base::TimeDelta::FromMilliseconds(kStartMillisecond));
65 task_runner_ = new test::FakeSingleThreadTaskRunner(testing_clock_); 62 task_runner_ = new test::FakeSingleThreadTaskRunner(testing_clock_);
66 cast_environment_ = 63 cast_environment_ =
67 new CastEnvironment(scoped_ptr<base::TickClock>(testing_clock_).Pass(), 64 new CastEnvironment(scoped_ptr<base::TickClock>(testing_clock_).Pass(),
68 task_runner_, 65 task_runner_,
69 task_runner_, 66 task_runner_,
70 task_runner_); 67 task_runner_);
71 audio_config_.codec = transport::kOpus; 68 audio_config_.codec = transport::kOpus;
72 audio_config_.use_external_encoder = false; 69 audio_config_.use_external_encoder = false;
73 audio_config_.frequency = kDefaultAudioSamplingRate; 70 audio_config_.frequency = kDefaultAudioSamplingRate;
74 audio_config_.channels = 2; 71 audio_config_.channels = 2;
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after
135 base::TimeDelta max_rtcp_timeout = 132 base::TimeDelta max_rtcp_timeout =
136 base::TimeDelta::FromMilliseconds(1 + kDefaultRtcpIntervalMs * 3 / 2); 133 base::TimeDelta::FromMilliseconds(1 + kDefaultRtcpIntervalMs * 3 / 2);
137 testing_clock_->Advance(max_rtcp_timeout); 134 testing_clock_->Advance(max_rtcp_timeout);
138 task_runner_->RunTasks(); 135 task_runner_->RunTasks();
139 EXPECT_LE(1, transport_.number_of_rtp_packets()); 136 EXPECT_LE(1, transport_.number_of_rtp_packets());
140 EXPECT_LE(1, transport_.number_of_rtcp_packets()); 137 EXPECT_LE(1, transport_.number_of_rtcp_packets());
141 } 138 }
142 139
143 } // namespace cast 140 } // namespace cast
144 } // namespace media 141 } // namespace media
OLDNEW
« no previous file with comments | « media/cast/audio_receiver/audio_receiver_unittest.cc ('k') | media/cast/base/clock_drift_smoother.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698