| OLD | NEW |
| 1 #include <AdblockPlus.h> | 1 #include <AdblockPlus.h> |
| 2 #include <gtest/gtest.h> | 2 #include <gtest/gtest.h> |
| 3 | 3 |
| 4 TEST(FilterEngineStubsTest, FilterCreation) | 4 TEST(FilterEngineStubsTest, FilterCreation) |
| 5 { | 5 { |
| 6 AdblockPlus::JsEngine jsEngine(0, 0, 0); | 6 AdblockPlus::JsEngine jsEngine(0, 0, 0); |
| 7 AdblockPlus::FilterEngine filterEngine(jsEngine); | 7 AdblockPlus::FilterEngine filterEngine(jsEngine); |
| 8 | 8 |
| 9 AdblockPlus::FilterPtr filter1 = filterEngine.GetFilter("foo"); | 9 AdblockPlus::FilterPtr filter1 = filterEngine.GetFilter("foo"); |
| 10 ASSERT_EQ(filter1->GetProperty("type", -1), AdblockPlus::Filter::TYPE_BLOCKING
); | 10 ASSERT_EQ(AdblockPlus::Filter::TYPE_BLOCKING, filter1->GetProperty("type", -1)
); |
| 11 AdblockPlus::FilterPtr filter2 = filterEngine.GetFilter("@@foo"); | 11 AdblockPlus::FilterPtr filter2 = filterEngine.GetFilter("@@foo"); |
| 12 ASSERT_EQ(filter2->GetProperty("type", -1), AdblockPlus::Filter::TYPE_EXCEPTIO
N); | 12 ASSERT_EQ(AdblockPlus::Filter::TYPE_EXCEPTION, filter2->GetProperty("type", -1
)); |
| 13 AdblockPlus::FilterPtr filter3 = filterEngine.GetFilter("example.com##foo"); | 13 AdblockPlus::FilterPtr filter3 = filterEngine.GetFilter("example.com##foo"); |
| 14 ASSERT_EQ(filter3->GetProperty("type", -1), AdblockPlus::Filter::TYPE_ELEMHIDE
); | 14 ASSERT_EQ(AdblockPlus::Filter::TYPE_ELEMHIDE, filter3->GetProperty("type", -1)
); |
| 15 AdblockPlus::FilterPtr filter4 = filterEngine.GetFilter("example.com#@#foo"); | 15 AdblockPlus::FilterPtr filter4 = filterEngine.GetFilter("example.com#@#foo"); |
| 16 ASSERT_EQ(filter4->GetProperty("type", -1), AdblockPlus::Filter::TYPE_ELEMHIDE
_EXCEPTION); | 16 ASSERT_EQ(AdblockPlus::Filter::TYPE_ELEMHIDE_EXCEPTION, filter4->GetProperty("
type", -1)); |
| 17 AdblockPlus::FilterPtr filter5 = filterEngine.GetFilter(" foo "); | 17 AdblockPlus::FilterPtr filter5 = filterEngine.GetFilter(" foo "); |
| 18 ASSERT_EQ(filter5, filter1); | 18 ASSERT_EQ(*filter1, *filter5); |
| 19 } | 19 } |
| 20 | 20 |
| 21 TEST(FilterEngineStubsTest, FilterProperties) | 21 TEST(FilterEngineStubsTest, FilterProperties) |
| 22 { | 22 { |
| 23 AdblockPlus::JsEngine jsEngine(0, 0, 0); | 23 AdblockPlus::JsEngine jsEngine(0, 0, 0); |
| 24 AdblockPlus::FilterEngine filterEngine(jsEngine); | 24 AdblockPlus::FilterEngine filterEngine(jsEngine); |
| 25 AdblockPlus::FilterPtr filter = filterEngine.GetFilter("foo"); | 25 AdblockPlus::FilterPtr filter = filterEngine.GetFilter("foo"); |
| 26 | 26 |
| 27 ASSERT_EQ(filter->GetProperty("stringFoo", "x"), "x"); | 27 ASSERT_EQ("x", filter->GetProperty("stringFoo", "x")); |
| 28 ASSERT_EQ(filter->GetProperty("intFoo", 42), 42); | 28 ASSERT_EQ(42, filter->GetProperty("intFoo", 42)); |
| 29 ASSERT_EQ(filter->GetProperty("boolFoo", false), false); | 29 ASSERT_FALSE(filter->GetProperty("boolFoo", false)); |
| 30 | 30 |
| 31 filter->SetProperty("stringFoo", "y"); | 31 filter->SetProperty("stringFoo", "y"); |
| 32 filter->SetProperty("intFoo", 24); | 32 filter->SetProperty("intFoo", 24); |
| 33 filter->SetProperty("boolFoo", true); | 33 filter->SetProperty("boolFoo", true); |
| 34 ASSERT_EQ(filter->GetProperty("stringFoo", "x"), "y"); | 34 ASSERT_EQ("y", filter->GetProperty("stringFoo", "x")); |
| 35 ASSERT_EQ(filter->GetProperty("intFoo", 42), 24); | 35 ASSERT_EQ(24, filter->GetProperty("intFoo", 42)); |
| 36 ASSERT_EQ(filter->GetProperty("boolFoo", false), true); | 36 ASSERT_TRUE(filter->GetProperty("boolFoo", false)); |
| 37 } | 37 } |
| 38 | 38 |
| 39 TEST(FilterEngineStubsTest, AddRemoveFilters) | 39 TEST(FilterEngineStubsTest, AddRemoveFilters) |
| 40 { | 40 { |
| 41 AdblockPlus::JsEngine jsEngine(0, 0, 0); | 41 AdblockPlus::JsEngine jsEngine(0, 0, 0); |
| 42 AdblockPlus::FilterEngine filterEngine(jsEngine); | 42 AdblockPlus::FilterEngine filterEngine(jsEngine); |
| 43 ASSERT_EQ(filterEngine.GetListedFilters().size(), 0u); | 43 ASSERT_EQ(0u, filterEngine.GetListedFilters().size()); |
| 44 AdblockPlus::FilterPtr filter = filterEngine.GetFilter("foo"); | 44 AdblockPlus::FilterPtr filter = filterEngine.GetFilter("foo"); |
| 45 ASSERT_EQ(filterEngine.GetListedFilters().size(), 0u); | 45 ASSERT_EQ(0u, filterEngine.GetListedFilters().size()); |
| 46 filter->AddToList(); | 46 filter->AddToList(); |
| 47 ASSERT_EQ(filterEngine.GetListedFilters().size(), 1u); | 47 ASSERT_EQ(1u, filterEngine.GetListedFilters().size()); |
| 48 ASSERT_EQ(filterEngine.GetListedFilters()[0], filter); | 48 ASSERT_EQ(*filter, *filterEngine.GetListedFilters()[0]); |
| 49 filter->AddToList(); | 49 filter->AddToList(); |
| 50 ASSERT_EQ(filterEngine.GetListedFilters().size(), 1u); | 50 ASSERT_EQ(1u, filterEngine.GetListedFilters().size()); |
| 51 ASSERT_EQ(filterEngine.GetListedFilters()[0], filter); | 51 ASSERT_EQ(*filter, *filterEngine.GetListedFilters()[0]); |
| 52 filter->RemoveFromList(); | 52 filter->RemoveFromList(); |
| 53 ASSERT_EQ(filterEngine.GetListedFilters().size(), 0u); | 53 ASSERT_EQ(0u, filterEngine.GetListedFilters().size()); |
| 54 filter->RemoveFromList(); | 54 filter->RemoveFromList(); |
| 55 ASSERT_EQ(filterEngine.GetListedFilters().size(), 0u); | 55 ASSERT_EQ(0u, filterEngine.GetListedFilters().size()); |
| 56 } | 56 } |
| 57 | 57 |
| 58 TEST(FilterEngineStubsTest, SubscriptionProperties) | 58 TEST(FilterEngineStubsTest, SubscriptionProperties) |
| 59 { | 59 { |
| 60 AdblockPlus::JsEngine jsEngine(0, 0, 0); | 60 AdblockPlus::JsEngine jsEngine(0, 0, 0); |
| 61 AdblockPlus::FilterEngine filterEngine(jsEngine); | 61 AdblockPlus::FilterEngine filterEngine(jsEngine); |
| 62 AdblockPlus::SubscriptionPtr subscription = filterEngine.GetSubscription("foo"
); | 62 AdblockPlus::SubscriptionPtr subscription = filterEngine.GetSubscription("foo"
); |
| 63 | 63 |
| 64 ASSERT_EQ(subscription->GetProperty("stringFoo", "x"), "x"); | 64 ASSERT_EQ("x", subscription->GetProperty("stringFoo", "x")); |
| 65 ASSERT_EQ(subscription->GetProperty("intFoo", 42), 42); | 65 ASSERT_EQ(42, subscription->GetProperty("intFoo", 42)); |
| 66 ASSERT_EQ(subscription->GetProperty("boolFoo", false), false); | 66 ASSERT_FALSE(subscription->GetProperty("boolFoo", false)); |
| 67 | 67 |
| 68 subscription->SetProperty("stringFoo", "y"); | 68 subscription->SetProperty("stringFoo", "y"); |
| 69 subscription->SetProperty("intFoo", 24); | 69 subscription->SetProperty("intFoo", 24); |
| 70 subscription->SetProperty("boolFoo", true); | 70 subscription->SetProperty("boolFoo", true); |
| 71 ASSERT_EQ(subscription->GetProperty("stringFoo", "x"), "y"); | 71 ASSERT_EQ("y", subscription->GetProperty("stringFoo", "x")); |
| 72 ASSERT_EQ(subscription->GetProperty("intFoo", 42), 24); | 72 ASSERT_EQ(24, subscription->GetProperty("intFoo", 42)); |
| 73 ASSERT_EQ(subscription->GetProperty("boolFoo", false), true); | 73 ASSERT_TRUE(subscription->GetProperty("boolFoo", false)); |
| 74 } | 74 } |
| 75 | 75 |
| 76 TEST(FilterEngineStubsTest, AddRemoveSubscriptions) | 76 TEST(FilterEngineStubsTest, AddRemoveSubscriptions) |
| 77 { | 77 { |
| 78 AdblockPlus::JsEngine jsEngine(0, 0, 0); | 78 AdblockPlus::JsEngine jsEngine(0, 0, 0); |
| 79 AdblockPlus::FilterEngine filterEngine(jsEngine); | 79 AdblockPlus::FilterEngine filterEngine(jsEngine); |
| 80 ASSERT_EQ(filterEngine.GetListedSubscriptions().size(), 0u); | 80 ASSERT_EQ(0u, filterEngine.GetListedSubscriptions().size()); |
| 81 AdblockPlus::SubscriptionPtr subscription = filterEngine.GetSubscription("foo"
); | 81 AdblockPlus::SubscriptionPtr subscription = filterEngine.GetSubscription("foo"
); |
| 82 ASSERT_EQ(filterEngine.GetListedSubscriptions().size(), 0u); | 82 ASSERT_EQ(0u, filterEngine.GetListedSubscriptions().size()); |
| 83 subscription->AddToList(); | 83 subscription->AddToList(); |
| 84 ASSERT_EQ(filterEngine.GetListedSubscriptions().size(), 1u); | 84 ASSERT_EQ(1u, filterEngine.GetListedSubscriptions().size()); |
| 85 ASSERT_EQ(filterEngine.GetListedSubscriptions()[0], subscription); | 85 ASSERT_EQ(*subscription, *filterEngine.GetListedSubscriptions()[0]); |
| 86 subscription->AddToList(); | 86 subscription->AddToList(); |
| 87 ASSERT_EQ(filterEngine.GetListedSubscriptions().size(), 1u); | 87 ASSERT_EQ(1u, filterEngine.GetListedSubscriptions().size()); |
| 88 ASSERT_EQ(filterEngine.GetListedSubscriptions()[0], subscription); | 88 ASSERT_EQ(*subscription, *filterEngine.GetListedSubscriptions()[0]); |
| 89 subscription->RemoveFromList(); | 89 subscription->RemoveFromList(); |
| 90 ASSERT_EQ(filterEngine.GetListedSubscriptions().size(), 0u); | 90 ASSERT_EQ(0u, filterEngine.GetListedSubscriptions().size()); |
| 91 subscription->RemoveFromList(); | 91 subscription->RemoveFromList(); |
| 92 ASSERT_EQ(filterEngine.GetListedSubscriptions().size(), 0u); | 92 ASSERT_EQ(0u, filterEngine.GetListedSubscriptions().size()); |
| 93 } |
| 94 |
| 95 TEST(FilterEngineStubsTest, SubscriptionUpdates) |
| 96 { |
| 97 AdblockPlus::JsEngine jsEngine(0, 0, 0); |
| 98 AdblockPlus::FilterEngine filterEngine(jsEngine); |
| 99 AdblockPlus::SubscriptionPtr subscription = filterEngine.GetSubscription("foo"
); |
| 100 ASSERT_FALSE(subscription->IsUpdating()); |
| 101 |
| 102 //TODO: This currently crashes due to errors reported on a different thread |
| 103 //subscription->UpdateFilters(); |
| 93 } | 104 } |
| 94 | 105 |
| 95 TEST(FilterEngineStubsTest, Matches) | 106 TEST(FilterEngineStubsTest, Matches) |
| 96 { | 107 { |
| 97 AdblockPlus::JsEngine jsEngine(0, 0, 0); | 108 AdblockPlus::JsEngine jsEngine(0, 0, 0); |
| 98 AdblockPlus::FilterEngine filterEngine(jsEngine); | 109 AdblockPlus::FilterEngine filterEngine(jsEngine); |
| 99 AdblockPlus::SubscriptionPtr subscription = filterEngine.GetSubscription("foo"
); | |
| 100 subscription->AddToList(); | |
| 101 | 110 |
| 102 AdblockPlus::FilterPtr match1 = filterEngine.Matches("http://example.org", "",
""); | 111 filterEngine.GetFilter("adbanner.gif")->AddToList(); |
| 112 filterEngine.GetFilter("@@notbanner.gif")->AddToList(); |
| 113 |
| 114 AdblockPlus::FilterPtr match1 = filterEngine.Matches("http://example.org/fooba
r.gif", "IMAGE", ""); |
| 103 ASSERT_FALSE(match1); | 115 ASSERT_FALSE(match1); |
| 104 | 116 |
| 105 AdblockPlus::FilterPtr match2 = filterEngine.Matches("http://example.org/adban
ner.gif", "", ""); | 117 AdblockPlus::FilterPtr match2 = filterEngine.Matches("http://example.org/adban
ner.gif", "IMAGE", ""); |
| 106 ASSERT_TRUE(match2); | 118 ASSERT_TRUE(match2); |
| 107 ASSERT_EQ(match2->GetProperty("type", -1), AdblockPlus::Filter::TYPE_BLOCKING)
; | 119 ASSERT_EQ(AdblockPlus::Filter::TYPE_BLOCKING, match2->GetProperty("type", -1))
; |
| 108 | 120 |
| 109 AdblockPlus::FilterPtr match3 = filterEngine.Matches("http://example.org/notba
nner.gif", "", ""); | 121 AdblockPlus::FilterPtr match3 = filterEngine.Matches("http://example.org/notba
nner.gif", "IMAGE", ""); |
| 110 ASSERT_TRUE(match3); | 122 ASSERT_TRUE(match3); |
| 111 ASSERT_EQ(match3->GetProperty("type", -1), AdblockPlus::Filter::TYPE_EXCEPTION
); | 123 ASSERT_EQ(AdblockPlus::Filter::TYPE_EXCEPTION, match3->GetProperty("type", -1)
); |
| 112 | 124 |
| 113 AdblockPlus::FilterPtr match4 = filterEngine.Matches("http://example.org/notba
nner.gif", "", ""); | 125 AdblockPlus::FilterPtr match4 = filterEngine.Matches("http://example.org/notba
nner.gif", "IMAGE", ""); |
| 114 ASSERT_TRUE(match4); | 126 ASSERT_TRUE(match4); |
| 115 ASSERT_EQ(match4->GetProperty("type", -1), AdblockPlus::Filter::TYPE_EXCEPTION
); | 127 ASSERT_EQ(AdblockPlus::Filter::TYPE_EXCEPTION, match4->GetProperty("type", -1)
); |
| 116 } | 128 } |
| OLD | NEW |