OLD | NEW |
---|---|
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "components/open_from_clipboard/clipboard_recent_content_ios.h" | 5 #include "components/open_from_clipboard/clipboard_recent_content_ios.h" |
6 | 6 |
7 #import <CoreGraphics/CoreGraphics.h> | 7 #import <CoreGraphics/CoreGraphics.h> |
8 #import <UIKit/UIKit.h> | 8 #import <UIKit/UIKit.h> |
9 | 9 |
10 #include <memory> | 10 #include <memory> |
11 | 11 |
12 #import "components/open_from_clipboard/clipboard_recent_content_ios_impl.h" | |
12 #include "testing/gtest/include/gtest/gtest.h" | 13 #include "testing/gtest/include/gtest/gtest.h" |
13 #include "testing/platform_test.h" | 14 #include "testing/platform_test.h" |
14 | 15 |
15 namespace { | 16 namespace { |
16 | 17 |
17 UIImage* TestUIImage() { | 18 UIImage* TestUIImage() { |
18 CGRect frame = CGRectMake(0, 0, 1.0, 1.0); | 19 CGRect frame = CGRectMake(0, 0, 1.0, 1.0); |
19 UIGraphicsBeginImageContext(frame.size); | 20 UIGraphicsBeginImageContext(frame.size); |
20 | 21 |
21 CGContextRef context = UIGraphicsGetCurrentContext(); | 22 CGContextRef context = UIGraphicsGetCurrentContext(); |
(...skipping 16 matching lines...) Expand all Loading... | |
38 forPasteboardType:@"public.plain-text"]; | 39 forPasteboardType:@"public.plain-text"]; |
39 } | 40 } |
40 const char kUnrecognizedURL[] = "ftp://foo/"; | 41 const char kUnrecognizedURL[] = "ftp://foo/"; |
41 const char kRecognizedURL[] = "http://bar/"; | 42 const char kRecognizedURL[] = "http://bar/"; |
42 const char kRecognizedURL2[] = "http://bar/2"; | 43 const char kRecognizedURL2[] = "http://bar/2"; |
43 const char kAppSpecificURL[] = "test://qux/"; | 44 const char kAppSpecificURL[] = "test://qux/"; |
44 const char kAppSpecificScheme[] = "test"; | 45 const char kAppSpecificScheme[] = "test"; |
45 NSTimeInterval kSevenHours = 60 * 60 * 7; | 46 NSTimeInterval kSevenHours = 60 * 60 * 7; |
46 } // namespace | 47 } // namespace |
47 | 48 |
49 @interface ClipboardRecentContentIOSImplWithFakeUptime | |
50 : ClipboardRecentContentIOSImpl | |
51 @property(nonatomic) NSTimeInterval fakeUptime; | |
52 | |
53 - (instancetype)initWithDelegate: | |
54 (id<ClipboardRecentContentMetricsDelegate>)delegate | |
55 authorizedSchemes:(NSArray*)authorizedSchemes | |
56 userDefaults:(NSUserDefaults*)groupUserDefaults | |
57 uptime:(NSTimeInterval)uptime; | |
58 | |
59 @end | |
60 | |
61 @implementation ClipboardRecentContentIOSImplWithFakeUptime | |
62 | |
63 @synthesize fakeUptime = _fakeUptime; | |
64 | |
65 - (instancetype)initWithDelegate: | |
66 (id<ClipboardRecentContentMetricsDelegate>)delegate | |
67 authorizedSchemes:(NSArray*)authorizedSchemes | |
68 userDefaults:(NSUserDefaults*)groupUserDefaults | |
69 uptime:(NSTimeInterval)uptime { | |
70 self = [super initWithDelegate:delegate | |
71 authorizedSchemes:authorizedSchemes | |
72 userDefaults:groupUserDefaults]; | |
73 if (self) { | |
74 _fakeUptime = uptime; | |
75 } | |
76 return self; | |
77 } | |
78 | |
79 - (NSTimeInterval)uptime { | |
sdefresne
2017/04/03 09:27:17
I would change this to a public property instead (
| |
80 return self.fakeUptime; | |
81 } | |
82 | |
83 @end | |
84 | |
48 class ClipboardRecentContentIOSWithFakeUptime | 85 class ClipboardRecentContentIOSWithFakeUptime |
49 : public ClipboardRecentContentIOS { | 86 : public ClipboardRecentContentIOS { |
50 public: | 87 public: |
51 ClipboardRecentContentIOSWithFakeUptime(const std::string& application_scheme, | 88 ClipboardRecentContentIOSWithFakeUptime(const std::string& application_scheme, |
52 NSUserDefaults* group_user_defaults) | 89 NSUserDefaults* group_user_defaults) |
53 : ClipboardRecentContentIOS(application_scheme, group_user_defaults) {} | 90 : ClipboardRecentContentIOS(application_scheme, group_user_defaults) {} |
54 // Sets the uptime. | |
55 void SetUptime(base::TimeDelta uptime) { uptime_ = uptime; } | |
56 | |
57 protected: | |
58 base::TimeDelta Uptime() const override { return uptime_; } | |
59 | |
60 private: | |
61 base::TimeDelta uptime_; | |
62 }; | 91 }; |
63 | 92 |
64 class ClipboardRecentContentIOSTest : public ::testing::Test { | 93 class ClipboardRecentContentIOSTest : public ::testing::Test { |
65 protected: | 94 protected: |
66 ClipboardRecentContentIOSTest() { | 95 ClipboardRecentContentIOSTest() { |
67 // By default, set that the device booted 10 days ago. | 96 // By default, set that the device booted 10 days ago. |
68 ResetClipboardRecentContent(kAppSpecificScheme, | 97 ResetClipboardRecentContent(kAppSpecificScheme, |
69 base::TimeDelta::FromDays(10)); | 98 base::TimeDelta::FromDays(10)); |
70 } | 99 } |
71 | 100 |
72 void SimulateDeviceRestart() { | 101 void SimulateDeviceRestart() { |
73 ResetClipboardRecentContent(kAppSpecificScheme, | 102 ResetClipboardRecentContent(kAppSpecificScheme, |
74 base::TimeDelta::FromSeconds(0)); | 103 base::TimeDelta::FromSeconds(0)); |
75 } | 104 } |
76 | 105 |
77 void ResetClipboardRecentContent(const std::string& application_scheme, | 106 void ResetClipboardRecentContent(const std::string& application_scheme, |
78 base::TimeDelta time_delta) { | 107 base::TimeDelta time_delta) { |
79 clipboard_content_.reset(new ClipboardRecentContentIOSWithFakeUptime( | 108 clipboard_content_.reset(new ClipboardRecentContentIOSWithFakeUptime( |
80 application_scheme, [NSUserDefaults standardUserDefaults])); | 109 application_scheme, [NSUserDefaults standardUserDefaults])); |
81 clipboard_content_->SetUptime(time_delta); | 110 |
111 clipboard_content_->implementation_.reset( | |
sdefresne
2017/04/03 09:27:17
This is exactly how you should not write test. Ins
sdefresne
2017/04/03 09:37:32
Sorry, this comment tone is too negative. I should
lody
2017/04/04 13:42:19
Done.
| |
112 [[ClipboardRecentContentIOSImplWithFakeUptime alloc] | |
113 initWithDelegate:nil | |
114 authorizedSchemes:clipboard_content_->GetAuthorizedSchemeList( | |
sdefresne
2017/04/03 09:27:17
Just inject a know list/set of schemes here, no ne
lody
2017/04/04 13:42:19
Done.
| |
115 application_scheme) | |
116 userDefaults:[NSUserDefaults standardUserDefaults] | |
117 uptime:time_delta.InSecondsF()]); | |
82 } | 118 } |
83 | 119 |
84 void SetStoredPasteboardChangeDate(NSDate* changeDate) { | 120 void SetStoredPasteboardChangeDate(NSDate* change_date) { |
85 clipboard_content_->last_pasteboard_change_date_.reset([changeDate copy]); | 121 clipboard_content_->SetLastPasteboardChangeDate([change_date copy]); |
sdefresne
2017/04/03 09:27:17
Can't you simulate this by instead manipulating th
lody
2017/04/04 13:42:19
I don't think so? There's two things, one is the u
| |
86 clipboard_content_->SaveToUserDefaults(); | 122 clipboard_content_->SaveToUserDefaults(); |
87 } | 123 } |
88 | 124 |
89 void SetStoredPasteboardChangeCount(NSInteger newChangeCount) { | |
90 clipboard_content_->last_pasteboard_change_count_ = newChangeCount; | |
91 clipboard_content_->SaveToUserDefaults(); | |
92 } | |
93 | |
94 protected: | 125 protected: |
95 std::unique_ptr<ClipboardRecentContentIOSWithFakeUptime> clipboard_content_; | 126 std::unique_ptr<ClipboardRecentContentIOSWithFakeUptime> clipboard_content_; |
96 }; | 127 }; |
97 | 128 |
98 TEST_F(ClipboardRecentContentIOSTest, SchemeFiltering) { | 129 TEST_F(ClipboardRecentContentIOSTest, SchemeFiltering) { |
99 GURL gurl; | 130 GURL gurl; |
100 | 131 |
101 // Test unrecognized URL. | 132 // Test unrecognized URL. |
102 SetPasteboardContent(kUnrecognizedURL); | 133 SetPasteboardContent(kUnrecognizedURL); |
103 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); | 134 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
157 // Check that the pasteboard content is suppressed. | 188 // Check that the pasteboard content is suppressed. |
158 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); | 189 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); |
159 | 190 |
160 // Create a new clipboard content to test persistence. | 191 // Create a new clipboard content to test persistence. |
161 ResetClipboardRecentContent(kAppSpecificScheme, | 192 ResetClipboardRecentContent(kAppSpecificScheme, |
162 base::TimeDelta::FromDays(10)); | 193 base::TimeDelta::FromDays(10)); |
163 | 194 |
164 // Check that the pasteboard content is still suppressed. | 195 // Check that the pasteboard content is still suppressed. |
165 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); | 196 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); |
166 | 197 |
167 // Check that the even if the device is restarted, pasteboard content is | 198 // Check that even if the device is restarted, pasteboard content is |
168 // still suppressed. | 199 // still suppressed. |
169 SimulateDeviceRestart(); | 200 SimulateDeviceRestart(); |
170 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); | 201 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); |
171 | 202 |
172 // Check that if the pasteboard changes, the new content is not | 203 // Check that if the pasteboard changes, the new content is not |
173 // supressed anymore. | 204 // supressed anymore. |
174 SetPasteboardContent(kRecognizedURL2); | 205 SetPasteboardContent(kRecognizedURL2); |
175 EXPECT_TRUE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); | 206 EXPECT_TRUE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); |
176 } | 207 } |
177 | 208 |
(...skipping 12 matching lines...) Expand all Loading... | |
190 SetPasteboardImage(TestUIImage()); | 221 SetPasteboardImage(TestUIImage()); |
191 | 222 |
192 // Pasteboard should appear empty. | 223 // Pasteboard should appear empty. |
193 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); | 224 EXPECT_FALSE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); |
194 | 225 |
195 // Tests that if URL is added again, pasteboard provides it normally. | 226 // Tests that if URL is added again, pasteboard provides it normally. |
196 SetPasteboardContent(kRecognizedURL); | 227 SetPasteboardContent(kRecognizedURL); |
197 EXPECT_TRUE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); | 228 EXPECT_TRUE(clipboard_content_->GetRecentURLFromClipboard(&gurl)); |
198 EXPECT_STREQ(kRecognizedURL, gurl.spec().c_str()); | 229 EXPECT_STREQ(kRecognizedURL, gurl.spec().c_str()); |
199 } | 230 } |
OLD | NEW |