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

Unified Diff: remoting/host/log_to_server_unittest.cc

Issue 320403002: Pull out common code from client and host versions of LogToServer (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix try failures Created 6 years, 6 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 side-by-side diff with in-line comments
Download patch
Index: remoting/host/log_to_server_unittest.cc
diff --git a/remoting/host/log_to_server_unittest.cc b/remoting/host/log_to_server_unittest.cc
deleted file mode 100644
index b131f63a77085f3b91aaf2712846259bfdf2943d..0000000000000000000000000000000000000000
--- a/remoting/host/log_to_server_unittest.cc
+++ /dev/null
@@ -1,256 +0,0 @@
-// Copyright (c) 2012 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "base/message_loop/message_loop.h"
-#include "base/message_loop/message_loop_proxy.h"
-#include "remoting/host/host_status_monitor_fake.h"
-#include "remoting/host/log_to_server.h"
-#include "remoting/jingle_glue/mock_objects.h"
-#include "testing/gmock/include/gmock/gmock.h"
-#include "testing/gmock_mutant.h"
-#include "testing/gtest/include/gtest/gtest.h"
-#include "third_party/libjingle/source/talk/xmllite/xmlelement.h"
-
-using buzz::XmlElement;
-using buzz::QName;
-using testing::_;
-using testing::DeleteArg;
-using testing::InSequence;
-using testing::Return;
-
-namespace remoting {
-
-namespace {
-
-ACTION_P(QuitMainMessageLoop, message_loop) {
- message_loop->PostTask(FROM_HERE, base::MessageLoop::QuitClosure());
-}
-
-const char kJabberClientNamespace[] = "jabber:client";
-const char kChromotingNamespace[] = "google:remoting";
-const char kTestBotJid[] = "remotingunittest@bot.talk.google.com";
-const char kClientJid1[] = "client@domain.com/1234";
-const char kClientJid2[] = "client@domain.com/5678";
-const char kHostJid[] = "host@domain.com/1234";
-
-bool IsLogEntryForConnection(XmlElement* node, const char* connection_type) {
- return (node->Name() == QName(kChromotingNamespace, "entry") &&
- node->Attr(QName(std::string(), "event-name")) == "session-state" &&
- node->Attr(QName(std::string(), "session-state")) == "connected" &&
- node->Attr(QName(std::string(), "role")) == "host" &&
- node->Attr(QName(std::string(), "mode")) == "me2me" &&
- node->Attr(QName(std::string(), "connection-type")) ==
- connection_type);
-}
-
-MATCHER_P(IsClientConnected, connection_type, "") {
- if (arg->Name() != QName(kJabberClientNamespace, "iq")) {
- return false;
- }
- buzz::XmlElement* log_stanza = arg->FirstChild()->AsElement();
- if (log_stanza->Name() !=QName(kChromotingNamespace, "log")) {
- return false;
- }
- if (log_stanza->NextChild()) {
- return false;
- }
- buzz::XmlElement* log_entry = log_stanza->FirstChild()->AsElement();
- if (!IsLogEntryForConnection(log_entry, connection_type)) {
- return false;
- }
- if (log_entry->NextChild()) {
- return false;
- }
- return true;
-}
-
-MATCHER_P2(IsTwoClientsConnected, connection_type1, connection_type2, "") {
- if (arg->Name() != QName(kJabberClientNamespace, "iq")) {
- return false;
- }
- buzz::XmlElement* log_stanza = arg->FirstChild()->AsElement();
- if (log_stanza->Name() !=QName(kChromotingNamespace, "log")) {
- return false;
- }
- if (log_stanza->NextChild()) {
- return false;
- }
- buzz::XmlElement* log_entry = log_stanza->FirstChild()->AsElement();
- if (!IsLogEntryForConnection(log_entry, connection_type1)) {
- return false;
- }
- log_entry = log_entry->NextChild()->AsElement();
- if (!IsLogEntryForConnection(log_entry, connection_type2)) {
- return false;
- }
- if (log_entry->NextChild()) {
- return false;
- }
- return true;
-}
-
-bool IsLogEntryForDisconnection(XmlElement* node) {
- return (node->Name() == QName(kChromotingNamespace, "entry") &&
- node->Attr(QName(std::string(), "event-name")) == "session-state" &&
- node->Attr(QName(std::string(), "session-state")) == "closed" &&
- node->Attr(QName(std::string(), "role")) == "host" &&
- node->Attr(QName(std::string(), "mode")) == "me2me");
-}
-
-MATCHER(IsClientDisconnected, "") {
- if (arg->Name() != QName(kJabberClientNamespace, "iq")) {
- return false;
- }
- buzz::XmlElement* log_stanza = arg->FirstChild()->AsElement();
- if (log_stanza->Name() !=QName(kChromotingNamespace, "log")) {
- return false;
- }
- if (log_stanza->NextChild()) {
- return false;
- }
- buzz::XmlElement* log_entry = log_stanza->FirstChild()->AsElement();
- if (!IsLogEntryForDisconnection(log_entry)) {
- return false;
- }
- if (log_entry->NextChild()) {
- return false;
- }
- return true;
-}
-
-} // namespace
-
-class LogToServerTest : public testing::Test {
- public:
- LogToServerTest() {}
- virtual void SetUp() OVERRIDE {
- message_loop_proxy_ = base::MessageLoopProxy::current();
- EXPECT_CALL(signal_strategy_, AddListener(_));
- log_to_server_.reset(
- new LogToServer(host_status_monitor_.AsWeakPtr(),
- ServerLogEntry::ME2ME,
- &signal_strategy_,
- kTestBotJid));
- EXPECT_CALL(signal_strategy_, RemoveListener(_));
- }
-
- protected:
- base::MessageLoop message_loop_;
- scoped_refptr<base::MessageLoopProxy> message_loop_proxy_;
- MockSignalStrategy signal_strategy_;
- scoped_ptr<LogToServer> log_to_server_;
- HostStatusMonitorFake host_status_monitor_;
-};
-
-TEST_F(LogToServerTest, SendNow) {
- {
- InSequence s;
- EXPECT_CALL(signal_strategy_, GetLocalJid())
- .WillRepeatedly(Return(kHostJid));
- EXPECT_CALL(signal_strategy_, AddListener(_));
- EXPECT_CALL(signal_strategy_, GetNextId());
- EXPECT_CALL(signal_strategy_, SendStanzaPtr(IsClientConnected("direct")))
- .WillOnce(DoAll(DeleteArg<0>(), Return(true)));
- EXPECT_CALL(signal_strategy_, RemoveListener(_))
- .WillOnce(QuitMainMessageLoop(&message_loop_))
- .RetiresOnSaturation();
- }
- log_to_server_->OnSignalStrategyStateChange(SignalStrategy::CONNECTED);
- protocol::TransportRoute route;
- route.type = protocol::TransportRoute::DIRECT;
- log_to_server_->OnClientRouteChange(kClientJid1, "video", route);
- log_to_server_->OnClientAuthenticated(kClientJid1);
- log_to_server_->OnClientConnected(kClientJid1);
- log_to_server_->OnSignalStrategyStateChange(SignalStrategy::DISCONNECTED);
- message_loop_.Run();
-}
-
-TEST_F(LogToServerTest, SendLater) {
- protocol::TransportRoute route;
- route.type = protocol::TransportRoute::DIRECT;
- log_to_server_->OnClientRouteChange(kClientJid1, "video", route);
- log_to_server_->OnClientAuthenticated(kClientJid1);
- log_to_server_->OnClientConnected(kClientJid1);
- {
- InSequence s;
- EXPECT_CALL(signal_strategy_, GetLocalJid())
- .WillRepeatedly(Return(kHostJid));
- EXPECT_CALL(signal_strategy_, AddListener(_));
- EXPECT_CALL(signal_strategy_, GetNextId());
- EXPECT_CALL(signal_strategy_, SendStanzaPtr(IsClientConnected("direct")))
- .WillOnce(DoAll(DeleteArg<0>(), Return(true)));
- EXPECT_CALL(signal_strategy_, RemoveListener(_))
- .WillOnce(QuitMainMessageLoop(&message_loop_))
- .RetiresOnSaturation();
- }
- log_to_server_->OnSignalStrategyStateChange(SignalStrategy::CONNECTED);
- log_to_server_->OnSignalStrategyStateChange(SignalStrategy::DISCONNECTED);
- message_loop_.Run();
-}
-
-TEST_F(LogToServerTest, SendTwoEntriesLater) {
- protocol::TransportRoute route1;
- route1.type = protocol::TransportRoute::DIRECT;
- log_to_server_->OnClientRouteChange(kClientJid1, "video", route1);
- log_to_server_->OnClientAuthenticated(kClientJid1);
- log_to_server_->OnClientConnected(kClientJid1);
- protocol::TransportRoute route2;
- route2.type = protocol::TransportRoute::STUN;
- log_to_server_->OnClientRouteChange(kClientJid2, "video", route2);
- log_to_server_->OnClientAuthenticated(kClientJid2);
- log_to_server_->OnClientConnected(kClientJid2);
- {
- InSequence s;
- EXPECT_CALL(signal_strategy_, GetLocalJid())
- .WillRepeatedly(Return(kHostJid));
- EXPECT_CALL(signal_strategy_, AddListener(_));
- EXPECT_CALL(signal_strategy_, GetNextId());
- EXPECT_CALL(signal_strategy_, SendStanzaPtr(
- IsTwoClientsConnected("direct", "stun")))
- .WillOnce(DoAll(DeleteArg<0>(), Return(true)));
- EXPECT_CALL(signal_strategy_, RemoveListener(_))
- .WillOnce(QuitMainMessageLoop(&message_loop_))
- .RetiresOnSaturation();
- }
- log_to_server_->OnSignalStrategyStateChange(SignalStrategy::CONNECTED);
- log_to_server_->OnSignalStrategyStateChange(SignalStrategy::DISCONNECTED);
- message_loop_.Run();
-}
-
-TEST_F(LogToServerTest, HandleRouteChangeInUnusualOrder) {
- {
- InSequence s;
- EXPECT_CALL(signal_strategy_, GetLocalJid())
- .WillRepeatedly(Return(kHostJid));
- EXPECT_CALL(signal_strategy_, AddListener(_));
- EXPECT_CALL(signal_strategy_, GetNextId());
- EXPECT_CALL(signal_strategy_, SendStanzaPtr(IsClientConnected("direct")))
- .WillOnce(DoAll(DeleteArg<0>(), Return(true)));
- EXPECT_CALL(signal_strategy_, GetNextId());
- EXPECT_CALL(signal_strategy_, SendStanzaPtr(IsClientDisconnected()))
- .WillOnce(DoAll(DeleteArg<0>(), Return(true)));
- EXPECT_CALL(signal_strategy_, GetNextId());
- EXPECT_CALL(signal_strategy_, SendStanzaPtr(IsClientConnected("stun")))
- .WillOnce(DoAll(DeleteArg<0>(), Return(true)));
- EXPECT_CALL(signal_strategy_, RemoveListener(_))
- .WillOnce(QuitMainMessageLoop(&message_loop_))
- .RetiresOnSaturation();
- }
- log_to_server_->OnSignalStrategyStateChange(SignalStrategy::CONNECTED);
- protocol::TransportRoute route1;
- route1.type = protocol::TransportRoute::DIRECT;
- log_to_server_->OnClientRouteChange(kClientJid1, "video", route1);
- log_to_server_->OnClientAuthenticated(kClientJid1);
- log_to_server_->OnClientConnected(kClientJid1);
- protocol::TransportRoute route2;
- route2.type = protocol::TransportRoute::STUN;
- log_to_server_->OnClientRouteChange(kClientJid2, "video", route2);
- log_to_server_->OnClientDisconnected(kClientJid1);
- log_to_server_->OnClientAuthenticated(kClientJid2);
- log_to_server_->OnClientConnected(kClientJid2);
- log_to_server_->OnSignalStrategyStateChange(SignalStrategy::DISCONNECTED);
- message_loop_.Run();
-}
-
-} // namespace remoting

Powered by Google App Engine
This is Rietveld 408576698