Left: | ||
Right: |
LEFT | RIGHT |
---|---|
1 /* | 1 /* |
2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
3 * Copyright (C) 2006-2015 Eyeo GmbH | 3 * Copyright (C) 2006-2015 Eyeo GmbH |
4 * | 4 * |
5 * Adblock Plus is free software: you can redistribute it and/or modify | 5 * Adblock Plus is free software: you can redistribute it and/or modify |
6 * it under the terms of the GNU General Public License version 3 as | 6 * it under the terms of the GNU General Public License version 3 as |
7 * published by the Free Software Foundation. | 7 * published by the Free Software Foundation. |
8 * | 8 * |
9 * Adblock Plus is distributed in the hope that it will be useful, | 9 * Adblock Plus is distributed in the hope that it will be useful, |
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
(...skipping 19 matching lines...) Expand all Loading... | |
30 class NotificationTest : public BaseJsTest | 30 class NotificationTest : public BaseJsTest |
31 { | 31 { |
32 protected: | 32 protected: |
33 FilterEnginePtr filterEngine; | 33 FilterEnginePtr filterEngine; |
34 void SetUp() override | 34 void SetUp() override |
35 { | 35 { |
36 BaseJsTest::SetUp(); | 36 BaseJsTest::SetUp(); |
37 jsEngine->SetFileSystem(FileSystemPtr(new LazyFileSystem())); | 37 jsEngine->SetFileSystem(FileSystemPtr(new LazyFileSystem())); |
38 jsEngine->SetWebRequest(WebRequestPtr(new LazyWebRequest())); | 38 jsEngine->SetWebRequest(WebRequestPtr(new LazyWebRequest())); |
39 jsEngine->SetLogSystem(LogSystemPtr(new DefaultLogSystem())); | 39 jsEngine->SetLogSystem(LogSystemPtr(new DefaultLogSystem())); |
40 filterEngine = | 40 filterEngine.reset(new FilterEngine(jsEngine)); |
41 std::tr1::shared_ptr<FilterEngine>(new FilterEngine(jsEngine)); | |
René Jeschke
2015/01/29 14:22:22
std::tr1::make_shared<T>(...) is not available on
Felix Dahlke
2015/01/29 16:49:25
We can actually go for the shorter:
filterEngine.
René Jeschke
2015/01/29 17:07:53
Done.
| |
42 } | 41 } |
43 | 42 |
44 void AddNotification(const std::string& notification) | 43 void AddNotification(const std::string& notification) |
45 { | 44 { |
46 jsEngine->Evaluate("(function()" | 45 jsEngine->Evaluate("(function()" |
47 "{" | 46 "{" |
48 "require('notification').Notification.addNotification(" + notification + ");" | 47 "require('notification').Notification.addNotification(" + notification + ");" |
49 "})();"); | 48 "})();"); |
50 } | 49 } |
51 }; | 50 }; |
(...skipping 23 matching lines...) Expand all Loading... | |
75 | 74 |
76 #ifdef NotificationMockWebRequestTest_ENABLED | 75 #ifdef NotificationMockWebRequestTest_ENABLED |
77 class NotificationMockWebRequestTest : public BaseJsTest | 76 class NotificationMockWebRequestTest : public BaseJsTest |
78 { | 77 { |
79 protected: | 78 protected: |
80 FilterEnginePtr filterEngine; | 79 FilterEnginePtr filterEngine; |
81 void SetUp() override | 80 void SetUp() override |
82 { | 81 { |
83 BaseJsTest::SetUp(); | 82 BaseJsTest::SetUp(); |
84 jsEngine->SetFileSystem( | 83 jsEngine->SetFileSystem( |
85 std::tr1::shared_ptr<LazyFileSystem>(new LazyFileSystem())); | 84 std::tr1::shared_ptr<LazyFileSystem>(new LazyFileSystem())); |
Felix Dahlke
2015/01/29 16:49:25
Next line indent is generally 2 spaces, apparent a
René Jeschke
2015/01/29 17:07:53
Done.
| |
86 const char* responseJsonText = "{" | 85 const char* responseJsonText = "{" |
87 "\"notifications\": [{" | 86 "\"notifications\": [{" |
88 "\"id\": \"some id\"," | 87 "\"id\": \"some id\"," |
89 "\"type\": \"information\"," | 88 "\"type\": \"information\"," |
90 "\"message\": {" | 89 "\"message\": {" |
91 "\"en-US\": \"message\"" | 90 "\"en-US\": \"message\"" |
92 "}," | 91 "}," |
93 "\"title\": \"Title\"" | 92 "\"title\": \"Title\"" |
94 "}]" | 93 "}]" |
95 "}"; | 94 "}"; |
96 jsEngine->SetWebRequest(std::tr1::shared_ptr<MockWebRequest>( | 95 jsEngine->SetWebRequest(std::tr1::shared_ptr<MockWebRequest>( |
97 new MockWebRequest(responseJsonText))); | 96 new MockWebRequest(responseJsonText))); |
98 jsEngine->SetLogSystem(LogSystemPtr(new DefaultLogSystem())); | 97 jsEngine->SetLogSystem(LogSystemPtr(new DefaultLogSystem())); |
99 filterEngine = | 98 filterEngine.reset(new FilterEngine(jsEngine)); |
100 std::tr1::shared_ptr<FilterEngine>(new FilterEngine(jsEngine)); | |
101 } | 99 } |
102 }; | 100 }; |
103 #endif | 101 #endif |
104 } | 102 } |
105 | 103 |
106 TEST_F(NotificationTest, NoNotifications) | 104 TEST_F(NotificationTest, NoNotifications) |
107 { | 105 { |
108 NotificationPtr notification = filterEngine->GetNextNotificationToShow(); | 106 NotificationPtr notification = filterEngine->GetNextNotificationToShow(); |
109 EXPECT_EQ(NULL, notification.get()); | 107 EXPECT_EQ(NULL, notification.get()); |
110 } | 108 } |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
164 TEST_F(NotificationTest, MarkAsShown) | 162 TEST_F(NotificationTest, MarkAsShown) |
165 { | 163 { |
166 AddNotification("{ id: 'id', type: 'question' }"); | 164 AddNotification("{ id: 'id', type: 'question' }"); |
167 NotificationPtr notification = filterEngine->GetNextNotificationToShow(); | 165 NotificationPtr notification = filterEngine->GetNextNotificationToShow(); |
168 EXPECT_TRUE(notification); | 166 EXPECT_TRUE(notification); |
169 notification = filterEngine->GetNextNotificationToShow(); | 167 notification = filterEngine->GetNextNotificationToShow(); |
170 ASSERT_TRUE(notification); | 168 ASSERT_TRUE(notification); |
171 notification->MarkAsShown(); | 169 notification->MarkAsShown(); |
172 EXPECT_EQ(NULL, filterEngine->GetNextNotificationToShow().get()); | 170 EXPECT_EQ(NULL, filterEngine->GetNextNotificationToShow().get()); |
173 } | 171 } |
LEFT | RIGHT |