/* * libjingle * Copyright 2011, Google Inc. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * 3. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include #include #include "talk/base/faketaskrunner.h" #include "talk/base/gunit.h" #include "talk/base/sigslot.h" #include "talk/xmllite/xmlelement.h" #include "talk/xmpp/constants.h" #include "talk/xmpp/fakexmppclient.h" #include "talk/xmpp/mucroomdiscoverytask.h" class MucRoomDiscoveryListener : public sigslot::has_slots<> { public: MucRoomDiscoveryListener() : error_count(0) {} void OnResult(buzz::MucRoomDiscoveryTask* task, bool exists, const std::string& name, const std::set& features, const std::map& extended_info) { last_exists = exists; last_name = name; last_features = features; last_extended_info = extended_info; } void OnError(buzz::IqTask* task, const buzz::XmlElement* error) { ++error_count; } bool last_exists; std::string last_name; std::set last_features; std::map last_extended_info; int error_count; }; class MucRoomDiscoveryTaskTest : public testing::Test { public: MucRoomDiscoveryTaskTest() : room_jid("muc-jid-ponies@domain.com"), room_name("ponies") { } virtual void SetUp() { runner = new talk_base::FakeTaskRunner(); xmpp_client = new buzz::FakeXmppClient(runner); listener = new MucRoomDiscoveryListener(); } virtual void TearDown() { delete listener; // delete xmpp_client; Deleted by deleting runner. delete runner; } talk_base::FakeTaskRunner* runner; buzz::FakeXmppClient* xmpp_client; MucRoomDiscoveryListener* listener; buzz::Jid room_jid; std::string room_name; }; TEST_F(MucRoomDiscoveryTaskTest, TestDiscovery) { ASSERT_EQ(0U, xmpp_client->sent_stanzas().size()); buzz::MucRoomDiscoveryTask* task = new buzz::MucRoomDiscoveryTask( xmpp_client, room_jid); task->SignalResult.connect(listener, &MucRoomDiscoveryListener::OnResult); task->Start(); std::string expected_iq = "" "" ""; ASSERT_EQ(1U, xmpp_client->sent_stanzas().size()); EXPECT_EQ(expected_iq, xmpp_client->sent_stanzas()[0]->Str()); EXPECT_EQ("", listener->last_name); std::string response_iq = "" " " " " " " " " " " " " " " " " " " ""; xmpp_client->HandleStanza(buzz::XmlElement::ForStr(response_iq)); EXPECT_EQ(true, listener->last_exists); EXPECT_EQ(room_name, listener->last_name); EXPECT_EQ(2U, listener->last_features.size()); EXPECT_EQ(1U, listener->last_features.count("feature1")); EXPECT_EQ(2U, listener->last_extended_info.size()); EXPECT_EQ("value1", listener->last_extended_info["var1"]); EXPECT_EQ(0, listener->error_count); } TEST_F(MucRoomDiscoveryTaskTest, TestMissingName) { buzz::MucRoomDiscoveryTask* task = new buzz::MucRoomDiscoveryTask( xmpp_client, room_jid); task->SignalError.connect(listener, &MucRoomDiscoveryListener::OnError); task->Start(); std::string error_iq = "" " " " " " " ""; EXPECT_EQ(0, listener->error_count); xmpp_client->HandleStanza(buzz::XmlElement::ForStr(error_iq)); EXPECT_EQ(0, listener->error_count); }