diff options
Diffstat (limited to 'sync/internal_api/syncapi_server_connection_manager_unittest.cc')
-rw-r--r-- | sync/internal_api/syncapi_server_connection_manager_unittest.cc | 115 |
1 files changed, 115 insertions, 0 deletions
diff --git a/sync/internal_api/syncapi_server_connection_manager_unittest.cc b/sync/internal_api/syncapi_server_connection_manager_unittest.cc new file mode 100644 index 0000000..a2f5280 --- /dev/null +++ b/sync/internal_api/syncapi_server_connection_manager_unittest.cc @@ -0,0 +1,115 @@ +// 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 "sync/internal_api/syncapi_server_connection_manager.h" + +#include "base/bind.h" +#include "base/bind_helpers.h" +#include "base/compiler_specific.h" +#include "base/synchronization/waitable_event.h" +#include "base/test/test_timeouts.h" +#include "base/threading/thread.h" +#include "base/time.h" +#include "net/base/net_errors.h" +#include "sync/internal_api/http_post_provider_factory.h" +#include "sync/internal_api/http_post_provider_interface.h" +#include "testing/gtest/include/gtest/gtest.h" + +using base::TimeDelta; +using browser_sync::HttpResponse; +using browser_sync::ServerConnectionManager; +using browser_sync::ScopedServerStatusWatcher; + +namespace sync_api { +namespace { + +class BlockingHttpPost : public HttpPostProviderInterface { + public: + BlockingHttpPost() : wait_for_abort_(false, false) {} + virtual ~BlockingHttpPost() {} + + virtual void SetUserAgent(const char* user_agent) OVERRIDE {} + virtual void SetExtraRequestHeaders(const char* headers) OVERRIDE {} + virtual void SetURL(const char* url, int port) OVERRIDE {} + virtual void SetPostPayload(const char* content_type, + int content_length, + const char* content) OVERRIDE {} + virtual bool MakeSynchronousPost(int* error_code, int* response_code) + OVERRIDE { + wait_for_abort_.TimedWait(TimeDelta::FromMilliseconds( + TestTimeouts::action_max_timeout_ms())); + *error_code = net::ERR_ABORTED; + return false; + } + virtual int GetResponseContentLength() const OVERRIDE { + return 0; + } + virtual const char* GetResponseContent() const OVERRIDE { + return ""; + } + virtual const std::string GetResponseHeaderValue( + const std::string& name) const OVERRIDE { + return ""; + } + virtual void Abort() OVERRIDE { + wait_for_abort_.Signal(); + } + private: + base::WaitableEvent wait_for_abort_; +}; + +class BlockingHttpPostFactory : public HttpPostProviderFactory { + public: + virtual ~BlockingHttpPostFactory() {} + virtual HttpPostProviderInterface* Create() OVERRIDE { + return new BlockingHttpPost(); + } + virtual void Destroy(HttpPostProviderInterface* http) OVERRIDE { + delete http; + } +}; + +} // namespace + +TEST(SyncAPIServerConnectionManagerTest, EarlyAbortPost) { + SyncAPIServerConnectionManager server( + "server", 0, true, "1", new BlockingHttpPostFactory()); + + ServerConnectionManager::PostBufferParams params; + ScopedServerStatusWatcher watcher(&server, ¶ms.response); + + server.TerminateAllIO(); + bool result = server.PostBufferToPath( + ¶ms, "/testpath", "testauth", &watcher); + + EXPECT_FALSE(result); + EXPECT_EQ(HttpResponse::CONNECTION_UNAVAILABLE, + params.response.server_status); +} + +TEST(SyncAPIServerConnectionManagerTest, AbortPost) { + SyncAPIServerConnectionManager server( + "server", 0, true, "1", new BlockingHttpPostFactory()); + + ServerConnectionManager::PostBufferParams params; + ScopedServerStatusWatcher watcher(&server, ¶ms.response); + + base::Thread abort_thread("Test_AbortThread"); + ASSERT_TRUE(abort_thread.Start()); + abort_thread.message_loop()->PostDelayedTask( + FROM_HERE, + base::Bind(&ServerConnectionManager::TerminateAllIO, + base::Unretained(&server)), + TestTimeouts::tiny_timeout()); + + bool result = server.PostBufferToPath( + ¶ms, "/testpath", "testauth", &watcher); + + EXPECT_FALSE(result); + EXPECT_EQ(HttpResponse::CONNECTION_UNAVAILABLE, + params.response.server_status); + abort_thread.Stop(); +} + +} // namespace sync_api |