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

Side by Side Diff: apps/shell/browser/dns_apitest.cc

Issue 394103004: Move DnsApiTest.DnsResolveIPLiteral and DnsApiTest.DnsResolveHostname to app_shell_browsertests. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 6 years, 5 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
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "apps/shell/test/shell_test.h"
6 #include "base/macros.h"
7 #include "base/memory/ref_counted.h"
8 #include "base/memory/scoped_ptr.h"
9 #include "base/values.h"
10 #include "extensions/browser/api/dns/dns_api.h"
11 #include "extensions/browser/api/dns/host_resolver_wrapper.h"
12 #include "extensions/browser/api/dns/mock_host_resolver_creator.h"
13 #include "extensions/browser/api_test_utils.h"
14 #include "extensions/browser/extension_function_dispatcher.h"
15 #include "extensions/common/extension.h"
16 #include "extensions/common/extension_builder.h"
17 #include "net/base/net_errors.h"
18 #include "net/dns/mock_host_resolver.h"
19
20 using extensions::ExtensionFunctionDispatcher;
21 using extensions::api_test_utils::RunFunctionAndReturnSingleResult;
22
23 namespace {
24
25 class TestFunctionDispatcherDelegate
26 : public ExtensionFunctionDispatcher::Delegate {
27 public:
28 TestFunctionDispatcherDelegate() {}
29 virtual ~TestFunctionDispatcherDelegate() {}
30
31 // NULL implementation.
32 private:
33 DISALLOW_COPY_AND_ASSIGN(TestFunctionDispatcherDelegate);
34 };
35
36 } // namespace
37
38 class DnsApiTest : public apps::AppShellTest {
39 public:
40 DnsApiTest() : resolver_creator_(new extensions::MockHostResolverCreator()) {}
41
42 private:
43 virtual void SetUpOnMainThread() OVERRIDE {
44 apps::AppShellTest::SetUpOnMainThread();
45 extensions::HostResolverWrapper::GetInstance()->SetHostResolverForTesting(
46 resolver_creator_->CreateMockHostResolver());
47 }
48
49 virtual void TearDownOnMainThread() OVERRIDE {
50 extensions::HostResolverWrapper::GetInstance()->SetHostResolverForTesting(
51 NULL);
52 resolver_creator_->DeleteMockHostResolver();
53 apps::AppShellTest::TearDownOnMainThread();
54 }
55
56 // The MockHostResolver asserts that it's used on the same thread on which
57 // it's created, which is actually a stronger rule than its real counterpart.
58 // But that's fine; it's good practice.
59 scoped_refptr<extensions::MockHostResolverCreator> resolver_creator_;
60 };
61
62 IN_PROC_BROWSER_TEST_F(DnsApiTest, DnsResolveIPLiteral) {
63 scoped_refptr<extensions::DnsResolveFunction> resolve_function(
64 new extensions::DnsResolveFunction());
65 scoped_refptr<extensions::Extension> empty_extension(
66 extensions::ExtensionBuilder()
67 .SetManifest(extensions::DictionaryBuilder().Set("name", "Test").Set(
68 "version", "1.0"))
69 .Build());
70
71 resolve_function->set_extension(empty_extension.get());
72 resolve_function->set_has_callback(true);
73
74 TestFunctionDispatcherDelegate delegate;
75 scoped_ptr<ExtensionFunctionDispatcher> dispatcher(
76 new ExtensionFunctionDispatcher(browser_context(), &delegate));
77
78 scoped_ptr<base::Value> result(
79 RunFunctionAndReturnSingleResult(resolve_function.get(),
80 "[\"127.0.0.1\"]",
81 browser_context(),
82 dispatcher.Pass()));
83 base::DictionaryValue* dict = NULL;
84 ASSERT_TRUE(result->GetAsDictionary(&dict));
85
86 int result_code;
James Cook 2014/07/18 20:32:48 nit: Init to 0 just so you don't read uninitialize
Yoyo Zhou 2014/07/22 00:10:31 Done.
87 EXPECT_TRUE(dict->GetInteger("resultCode", &result_code));
88 EXPECT_EQ(net::OK, result_code);
89
90 std::string address;
91 EXPECT_TRUE(dict->GetString("address", &address));
92 EXPECT_EQ("127.0.0.1", address);
93 }
94
95 IN_PROC_BROWSER_TEST_F(DnsApiTest, DnsResolveHostname) {
96 scoped_refptr<extensions::DnsResolveFunction> resolve_function(
97 new extensions::DnsResolveFunction());
98 scoped_refptr<extensions::Extension> empty_extension(
99 extensions::ExtensionBuilder()
100 .SetManifest(extensions::DictionaryBuilder().Set("name", "Test").Set(
101 "version", "1.0"))
102 .Build());
103
104 resolve_function->set_extension(empty_extension.get());
105 resolve_function->set_has_callback(true);
106
107 TestFunctionDispatcherDelegate delegate;
108 scoped_ptr<ExtensionFunctionDispatcher> dispatcher(
109 new ExtensionFunctionDispatcher(browser_context(), &delegate));
110
111 std::string function_arguments("[\"");
112 function_arguments += extensions::MockHostResolverCreator::kHostname;
113 function_arguments += "\"]";
114 scoped_ptr<base::Value> result(
115 RunFunctionAndReturnSingleResult(resolve_function.get(),
116 function_arguments,
117 browser_context(),
118 dispatcher.Pass()));
119 base::DictionaryValue* dict = NULL;
120 ASSERT_TRUE(result->GetAsDictionary(&dict));
121
122 int result_code;
James Cook 2014/07/18 20:32:48 ditto
123 EXPECT_TRUE(dict->GetInteger("resultCode", &result_code));
124 EXPECT_EQ(net::OK, result_code);
125
126 std::string address;
127 EXPECT_TRUE(dict->GetString("address", &address));
128 EXPECT_EQ(extensions::MockHostResolverCreator::kAddress, address);
129 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698