| Left: | ||
| Right: |
| OLD | NEW |
|---|---|
| 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 = std::tr1::make_shared<FilterEngine>(jsEngine); | 40 filterEngine = |
| 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.
| |
| 41 } | 42 } |
| 42 | 43 |
| 43 void AddNotification(const std::string& notification) | 44 void AddNotification(const std::string& notification) |
| 44 { | 45 { |
| 45 jsEngine->Evaluate("(function()" | 46 jsEngine->Evaluate("(function()" |
| 46 "{" | 47 "{" |
| 47 "require('notification').Notification.addNotification(" + notification + ");" | 48 "require('notification').Notification.addNotification(" + notification + ");" |
| 48 "})();"); | 49 "})();"); |
| 49 } | 50 } |
| 50 }; | 51 }; |
| (...skipping 22 matching lines...) Expand all Loading... | |
| 73 }; | 74 }; |
| 74 | 75 |
| 75 #ifdef NotificationMockWebRequestTest_ENABLED | 76 #ifdef NotificationMockWebRequestTest_ENABLED |
| 76 class NotificationMockWebRequestTest : public BaseJsTest | 77 class NotificationMockWebRequestTest : public BaseJsTest |
| 77 { | 78 { |
| 78 protected: | 79 protected: |
| 79 FilterEnginePtr filterEngine; | 80 FilterEnginePtr filterEngine; |
| 80 void SetUp() override | 81 void SetUp() override |
| 81 { | 82 { |
| 82 BaseJsTest::SetUp(); | 83 BaseJsTest::SetUp(); |
| 83 jsEngine->SetFileSystem(std::tr1::make_shared<LazyFileSystem>()); | 84 jsEngine->SetFileSystem( |
| 85 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.
| |
| 84 const char* responseJsonText = "{" | 86 const char* responseJsonText = "{" |
| 85 "\"notifications\": [{" | 87 "\"notifications\": [{" |
| 86 "\"id\": \"some id\"," | 88 "\"id\": \"some id\"," |
| 87 "\"type\": \"information\"," | 89 "\"type\": \"information\"," |
| 88 "\"message\": {" | 90 "\"message\": {" |
| 89 "\"en-US\": \"message\"" | 91 "\"en-US\": \"message\"" |
| 90 "}," | 92 "}," |
| 91 "\"title\": \"Title\"" | 93 "\"title\": \"Title\"" |
| 92 "}]" | 94 "}]" |
| 93 "}"; | 95 "}"; |
| 94 jsEngine->SetWebRequest(std::tr1::make_shared<MockWebRequest>(responseJson Text)); | 96 jsEngine->SetWebRequest(std::tr1::shared_ptr<MockWebRequest>( |
| 97 new MockWebRequest(responseJsonText))); | |
| 95 jsEngine->SetLogSystem(LogSystemPtr(new DefaultLogSystem())); | 98 jsEngine->SetLogSystem(LogSystemPtr(new DefaultLogSystem())); |
| 96 filterEngine = std::tr1::make_shared<FilterEngine>(jsEngine); | 99 filterEngine = |
| 100 std::tr1::shared_ptr<FilterEngine>(new FilterEngine(jsEngine)); | |
| 97 } | 101 } |
| 98 }; | 102 }; |
| 99 #endif | 103 #endif |
| 100 } | 104 } |
| 101 | 105 |
| 102 TEST_F(NotificationTest, NoNotifications) | 106 TEST_F(NotificationTest, NoNotifications) |
| 103 { | 107 { |
| 104 NotificationPtr notification = filterEngine->GetNextNotificationToShow(); | 108 NotificationPtr notification = filterEngine->GetNextNotificationToShow(); |
| 105 EXPECT_EQ(NULL, notification.get()); | 109 EXPECT_EQ(NULL, notification.get()); |
| 106 } | 110 } |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 159 | 163 |
| 160 TEST_F(NotificationTest, MarkAsShown) | 164 TEST_F(NotificationTest, MarkAsShown) |
| 161 { | 165 { |
| 162 AddNotification("{ id: 'id', type: 'question' }"); | 166 AddNotification("{ id: 'id', type: 'question' }"); |
| 163 NotificationPtr notification = filterEngine->GetNextNotificationToShow(); | 167 NotificationPtr notification = filterEngine->GetNextNotificationToShow(); |
| 164 EXPECT_TRUE(notification); | 168 EXPECT_TRUE(notification); |
| 165 notification = filterEngine->GetNextNotificationToShow(); | 169 notification = filterEngine->GetNextNotificationToShow(); |
| 166 ASSERT_TRUE(notification); | 170 ASSERT_TRUE(notification); |
| 167 notification->MarkAsShown(); | 171 notification->MarkAsShown(); |
| 168 EXPECT_EQ(NULL, filterEngine->GetNextNotificationToShow().get()); | 172 EXPECT_EQ(NULL, filterEngine->GetNextNotificationToShow().get()); |
| 169 } | 173 } |
| OLD | NEW |