Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code

Side by Side Diff: test/FilterEngineStubs.cpp

Issue 10213003: Make JsEngine::Evaluate() return a wrapper for v8::Value to accessdifferent variable types easily (Closed)
Patch Set: Unbitrotted patch Created April 16, 2013, 3:30 p.m.
Left:
Right:
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View unified diff | Download patch
« no previous file with comments | « test/FileSystemJsObject.cpp ('k') | test/GlobalJsObject.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 }
OLDNEW
« no previous file with comments | « test/FileSystemJsObject.cpp ('k') | test/GlobalJsObject.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld