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

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: Added playout_time smoothness checks in End2EndTest. 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 ++number_of_rtp_packets_; 34 ++number_of_rtp_packets_;
(...skipping 10 matching lines...) Expand all
47 int number_of_rtcp_packets_; 45 int number_of_rtcp_packets_;
48 46
49 DISALLOW_COPY_AND_ASSIGN(TestPacketSender); 47 DISALLOW_COPY_AND_ASSIGN(TestPacketSender);
50 }; 48 };
51 49
52 class AudioSenderTest : public ::testing::Test { 50 class AudioSenderTest : public ::testing::Test {
53 protected: 51 protected:
54 AudioSenderTest() { 52 AudioSenderTest() {
55 InitializeMediaLibraryForTesting(); 53 InitializeMediaLibraryForTesting();
56 testing_clock_ = new base::SimpleTestTickClock(); 54 testing_clock_ = new base::SimpleTestTickClock();
57 testing_clock_->Advance( 55 testing_clock_->Advance(base::TimeTicks::Now() - base::TimeTicks());
58 base::TimeDelta::FromMilliseconds(kStartMillisecond));
59 task_runner_ = new test::FakeSingleThreadTaskRunner(testing_clock_); 56 task_runner_ = new test::FakeSingleThreadTaskRunner(testing_clock_);
60 cast_environment_ = 57 cast_environment_ =
61 new CastEnvironment(scoped_ptr<base::TickClock>(testing_clock_).Pass(), 58 new CastEnvironment(scoped_ptr<base::TickClock>(testing_clock_).Pass(),
62 task_runner_, 59 task_runner_,
63 task_runner_, 60 task_runner_,
64 task_runner_); 61 task_runner_);
65 audio_config_.codec = transport::kOpus; 62 audio_config_.codec = transport::kOpus;
66 audio_config_.use_external_encoder = false; 63 audio_config_.use_external_encoder = false;
67 audio_config_.frequency = kDefaultAudioSamplingRate; 64 audio_config_.frequency = kDefaultAudioSamplingRate;
68 audio_config_.channels = 2; 65 audio_config_.channels = 2;
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after
130 base::TimeDelta max_rtcp_timeout = 127 base::TimeDelta max_rtcp_timeout =
131 base::TimeDelta::FromMilliseconds(1 + kDefaultRtcpIntervalMs * 3 / 2); 128 base::TimeDelta::FromMilliseconds(1 + kDefaultRtcpIntervalMs * 3 / 2);
132 testing_clock_->Advance(max_rtcp_timeout); 129 testing_clock_->Advance(max_rtcp_timeout);
133 task_runner_->RunTasks(); 130 task_runner_->RunTasks();
134 EXPECT_GE(transport_.number_of_rtp_packets(), 1); 131 EXPECT_GE(transport_.number_of_rtp_packets(), 1);
135 EXPECT_EQ(transport_.number_of_rtcp_packets(), 1); 132 EXPECT_EQ(transport_.number_of_rtcp_packets(), 1);
136 } 133 }
137 134
138 } // namespace cast 135 } // namespace cast
139 } // namespace media 136 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698