diff options
author | Sen Jiang <senj@google.com> | 2018-09-18 16:06:57 -0700 |
---|---|---|
committer | Sen Jiang <senj@google.com> | 2018-09-26 16:58:44 -0700 |
commit | d8be4b5f83ce6d907762fda1cfd229ab2ba8dab7 (patch) | |
tree | 2617f46e999a39eafbeabc1f173143b191347b47 /common/proxy_resolver_unittest.cc | |
parent | a8712bcfdd86ffa3f6cf048da29225f041db9de7 (diff) |
Move ProxyResolver to common.
HttpFetcher depends on it and HttpFetcher is in common.
Bug: 28171891
Test: mma
Change-Id: I1783821c4a7d6785ee23df1cde648a3e1ea8fadf
Diffstat (limited to 'common/proxy_resolver_unittest.cc')
-rw-r--r-- | common/proxy_resolver_unittest.cc | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/common/proxy_resolver_unittest.cc b/common/proxy_resolver_unittest.cc new file mode 100644 index 00000000..101bf6bb --- /dev/null +++ b/common/proxy_resolver_unittest.cc @@ -0,0 +1,91 @@ +// +// Copyright (C) 2017 The Android Open Source Project +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. +// + +#include "update_engine/common/proxy_resolver.h" + +#include <deque> +#include <string> + +#include <gtest/gtest.h> + +#include <base/bind.h> +#include <brillo/message_loops/fake_message_loop.h> + +using std::deque; +using std::string; + +namespace chromeos_update_engine { + +class ProxyResolverTest : public ::testing::Test { + protected: + virtual ~ProxyResolverTest() = default; + + void SetUp() override { loop_.SetAsCurrent(); } + + void TearDown() override { EXPECT_FALSE(loop_.PendingTasks()); } + + brillo::FakeMessageLoop loop_{nullptr}; + DirectProxyResolver resolver_; +}; + +TEST_F(ProxyResolverTest, DirectProxyResolverCallbackTest) { + bool called = false; + deque<string> callback_proxies; + auto callback = base::Bind( + [](bool* called, + deque<string>* callback_proxies, + const deque<string>& proxies) { + *called = true; + *callback_proxies = proxies; + }, + &called, + &callback_proxies); + + EXPECT_NE(kProxyRequestIdNull, + resolver_.GetProxiesForUrl("http://foo", callback)); + // Check the callback is not called until the message loop runs. + EXPECT_FALSE(called); + loop_.Run(); + EXPECT_TRUE(called); + EXPECT_EQ(kNoProxy, callback_proxies.front()); +} + +TEST_F(ProxyResolverTest, DirectProxyResolverCancelCallbackTest) { + bool called = false; + auto callback = base::Bind( + [](bool* called, const deque<string>& proxies) { *called = true; }, + &called); + + ProxyRequestId request = resolver_.GetProxiesForUrl("http://foo", callback); + EXPECT_FALSE(called); + EXPECT_TRUE(resolver_.CancelProxyRequest(request)); + loop_.Run(); + EXPECT_FALSE(called); +} + +TEST_F(ProxyResolverTest, DirectProxyResolverSimultaneousCallbacksTest) { + int called = 0; + auto callback = base::Bind( + [](int* called, const deque<string>& proxies) { (*called)++; }, &called); + + resolver_.GetProxiesForUrl("http://foo", callback); + resolver_.GetProxiesForUrl("http://bar", callback); + EXPECT_EQ(0, called); + loop_.Run(); + EXPECT_EQ(2, called); +} + +} // namespace chromeos_update_engine |