| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 1 | // Copyright (C) 2017 The Android Open Source Project |
| 2 | // |
| 3 | // Licensed under the Apache License, Version 2.0 (the "License"); |
| 4 | // you may not use this file except in compliance with the License. |
| 5 | // You may obtain a copy of the License at |
| 6 | // |
| 7 | // http://www.apache.org/licenses/LICENSE-2.0 |
| 8 | // |
| 9 | // Unless required by applicable law or agreed to in writing, software |
| 10 | // distributed under the License is distributed on an "AS IS" BASIS, |
| 11 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 12 | // See the License for the specific language governing permissions and |
| 13 | // limitations under the License. |
| 14 | |
| Joe Onorato | 9fc9edf | 2017-10-15 20:08:52 -0700 | [diff] [blame] | 15 | #include "frameworks/base/cmds/statsd/src/statsd_config.pb.h" |
| 16 | #include "matchers/matcher_util.h" |
| 17 | #include "stats_util.h" |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 18 | |
| Yao Chen | 44cf27c | 2017-09-14 22:32:50 -0700 | [diff] [blame] | 19 | #include <gtest/gtest.h> |
| 20 | #include <log/log_event_list.h> |
| 21 | #include <log/log_read.h> |
| 22 | #include <log/logprint.h> |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 23 | |
| 24 | #include <stdio.h> |
| 25 | |
| 26 | using namespace android::os::statsd; |
| 27 | using std::unordered_map; |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 28 | using std::vector; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 29 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 30 | const int TAG_ID = 123; |
| 31 | const int FIELD_ID_1 = 1; |
| 32 | const int FIELD_ID_2 = 2; |
| 33 | const int FIELD_ID_3 = 2; |
| 34 | |
| 35 | // Private API from liblog. |
| 36 | extern "C" void android_log_rewind(android_log_context ctx); |
| Stefan Lafon | cdb1a0e | 2017-09-27 20:24:15 -0700 | [diff] [blame] | 37 | |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 38 | #ifdef __ANDROID__ |
| 39 | TEST(LogEntryMatcherTest, TestSimpleMatcher) { |
| 40 | // Set up the matcher |
| 41 | LogEntryMatcher matcher; |
| 42 | auto simpleMatcher = matcher.mutable_simple_log_entry_matcher(); |
| Yao Chen | 729093d | 2017-10-16 10:33:26 -0700 | [diff] [blame^] | 43 | simpleMatcher->set_tag(TAG_ID); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 44 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 45 | // Set up the event |
| 46 | android_log_event_list list(TAG_ID); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 47 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 48 | // Convert to a LogEvent |
| 49 | list.convert_to_reader(); |
| 50 | LogEvent event(999, &list); |
| 51 | |
| 52 | // Test |
| 53 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 54 | } |
| 55 | |
| 56 | TEST(LogEntryMatcherTest, TestBoolMatcher) { |
| 57 | // Set up the matcher |
| 58 | LogEntryMatcher matcher; |
| 59 | auto simpleMatcher = matcher.mutable_simple_log_entry_matcher(); |
| Yao Chen | 729093d | 2017-10-16 10:33:26 -0700 | [diff] [blame^] | 60 | simpleMatcher->set_tag(TAG_ID); |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 61 | auto keyValue1 = simpleMatcher->add_key_value_matcher(); |
| 62 | keyValue1->mutable_key_matcher()->set_key(FIELD_ID_1); |
| 63 | auto keyValue2 = simpleMatcher->add_key_value_matcher(); |
| 64 | keyValue2->mutable_key_matcher()->set_key(FIELD_ID_2); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 65 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 66 | // Set up the event |
| 67 | android_log_event_list list(TAG_ID); |
| 68 | list << true; |
| 69 | list << false; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 70 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 71 | // Convert to a LogEvent |
| 72 | list.convert_to_reader(); |
| 73 | LogEvent event(999, &list); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 74 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 75 | // Test |
| 76 | keyValue1->set_eq_bool(true); |
| 77 | keyValue2->set_eq_bool(false); |
| 78 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 79 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 80 | keyValue1->set_eq_bool(false); |
| 81 | keyValue2->set_eq_bool(false); |
| 82 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| 83 | |
| 84 | keyValue1->set_eq_bool(true); |
| 85 | keyValue2->set_eq_bool(false); |
| 86 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| 87 | |
| 88 | keyValue1->set_eq_bool(true); |
| 89 | keyValue2->set_eq_bool(true); |
| 90 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 91 | } |
| 92 | |
| 93 | TEST(LogEntryMatcherTest, TestStringMatcher) { |
| 94 | // Set up the matcher |
| 95 | LogEntryMatcher matcher; |
| 96 | auto simpleMatcher = matcher.mutable_simple_log_entry_matcher(); |
| Yao Chen | 729093d | 2017-10-16 10:33:26 -0700 | [diff] [blame^] | 97 | simpleMatcher->set_tag(TAG_ID); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 98 | auto keyValue = simpleMatcher->add_key_value_matcher(); |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 99 | keyValue->mutable_key_matcher()->set_key(FIELD_ID_1); |
| 100 | keyValue->set_eq_string("some value"); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 101 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 102 | // Set up the event |
| 103 | android_log_event_list list(TAG_ID); |
| 104 | list << "some value"; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 105 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 106 | // Convert to a LogEvent |
| 107 | list.convert_to_reader(); |
| 108 | LogEvent event(999, &list); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 109 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 110 | // Test |
| 111 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 112 | } |
| 113 | |
| 114 | TEST(LogEntryMatcherTest, TestIntComparisonMatcher) { |
| 115 | // Set up the matcher |
| 116 | LogEntryMatcher matcher; |
| 117 | auto simpleMatcher = matcher.mutable_simple_log_entry_matcher(); |
| Yao Chen | 729093d | 2017-10-16 10:33:26 -0700 | [diff] [blame^] | 118 | |
| 119 | simpleMatcher->set_tag(TAG_ID); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 120 | auto keyValue = simpleMatcher->add_key_value_matcher(); |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 121 | keyValue->mutable_key_matcher()->set_key(FIELD_ID_1); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 122 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 123 | // Set up the event |
| 124 | android_log_event_list list(TAG_ID); |
| 125 | list << 11; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 126 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 127 | // Convert to a LogEvent |
| 128 | list.convert_to_reader(); |
| 129 | LogEvent event(999, &list); |
| 130 | |
| 131 | // Test |
| 132 | |
| 133 | // eq_int |
| 134 | keyValue->set_eq_int(10); |
| 135 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| 136 | keyValue->set_eq_int(11); |
| 137 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| 138 | keyValue->set_eq_int(12); |
| 139 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| 140 | |
| 141 | // lt_int |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 142 | keyValue->set_lt_int(10); |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 143 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| 144 | keyValue->set_lt_int(11); |
| 145 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| 146 | keyValue->set_lt_int(12); |
| 147 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 148 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 149 | // lte_int |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 150 | keyValue->set_lte_int(10); |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 151 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| 152 | keyValue->set_lte_int(11); |
| 153 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| 154 | keyValue->set_lte_int(12); |
| 155 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 156 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 157 | // gt_int |
| 158 | keyValue->set_gt_int(10); |
| 159 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| 160 | keyValue->set_gt_int(11); |
| 161 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| 162 | keyValue->set_gt_int(12); |
| 163 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| 164 | |
| 165 | // gte_int |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 166 | keyValue->set_gte_int(10); |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 167 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| 168 | keyValue->set_gte_int(11); |
| 169 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| 170 | keyValue->set_gte_int(12); |
| 171 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 172 | } |
| 173 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 174 | #if 0 |
| 175 | |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 176 | TEST(LogEntryMatcherTest, TestFloatComparisonMatcher) { |
| 177 | // Set up the matcher |
| 178 | LogEntryMatcher matcher; |
| 179 | auto simpleMatcher = matcher.mutable_simple_log_entry_matcher(); |
| Yao Chen | 729093d | 2017-10-16 10:33:26 -0700 | [diff] [blame^] | 180 | simpleMatcher->set_tag(TAG_ID); |
| 181 | |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 182 | auto keyValue = simpleMatcher->add_key_value_matcher(); |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 183 | keyValue->mutable_key_matcher()->set_key(FIELD_ID_1); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 184 | |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 185 | LogEvent event; |
| 186 | event.tagId = TAG_ID; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 187 | |
| 188 | keyValue->set_lt_float(10.0); |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 189 | event.floatMap[FIELD_ID_1] = 10.1; |
| 190 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| 191 | event.floatMap[FIELD_ID_1] = 9.9; |
| 192 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 193 | |
| 194 | keyValue->set_gt_float(10.0); |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 195 | event.floatMap[FIELD_ID_1] = 10.1; |
| 196 | EXPECT_TRUE(matchesSimple(*simpleMatcher, event)); |
| 197 | event.floatMap[FIELD_ID_1] = 9.9; |
| 198 | EXPECT_FALSE(matchesSimple(*simpleMatcher, event)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 199 | } |
| Joe Onorato | c4dfae5 | 2017-10-17 23:38:21 -0700 | [diff] [blame] | 200 | #endif |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 201 | |
| 202 | // Helper for the composite matchers. |
| Stefan Lafon | cdb1a0e | 2017-09-27 20:24:15 -0700 | [diff] [blame] | 203 | void addSimpleMatcher(SimpleLogEntryMatcher* simpleMatcher, int tag, int key, int val) { |
| Yao Chen | 729093d | 2017-10-16 10:33:26 -0700 | [diff] [blame^] | 204 | simpleMatcher->set_tag(tag); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 205 | auto keyValue = simpleMatcher->add_key_value_matcher(); |
| 206 | keyValue->mutable_key_matcher()->set_key(key); |
| 207 | keyValue->set_eq_int(val); |
| 208 | } |
| 209 | |
| 210 | TEST(LogEntryMatcherTest, TestAndMatcher) { |
| 211 | // Set up the matcher |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 212 | LogicalOperation operation = LogicalOperation::AND; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 213 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 214 | vector<int> children; |
| 215 | children.push_back(0); |
| 216 | children.push_back(1); |
| 217 | children.push_back(2); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 218 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 219 | vector<MatchingState> matcherResults; |
| 220 | matcherResults.push_back(MatchingState::kMatched); |
| 221 | matcherResults.push_back(MatchingState::kNotMatched); |
| 222 | matcherResults.push_back(MatchingState::kMatched); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 223 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 224 | EXPECT_FALSE(combinationMatch(children, operation, matcherResults)); |
| 225 | |
| 226 | matcherResults.clear(); |
| 227 | matcherResults.push_back(MatchingState::kMatched); |
| 228 | matcherResults.push_back(MatchingState::kMatched); |
| 229 | matcherResults.push_back(MatchingState::kMatched); |
| 230 | |
| 231 | EXPECT_TRUE(combinationMatch(children, operation, matcherResults)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 232 | } |
| 233 | |
| 234 | TEST(LogEntryMatcherTest, TestOrMatcher) { |
| 235 | // Set up the matcher |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 236 | LogicalOperation operation = LogicalOperation::OR; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 237 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 238 | vector<int> children; |
| 239 | children.push_back(0); |
| 240 | children.push_back(1); |
| 241 | children.push_back(2); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 242 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 243 | vector<MatchingState> matcherResults; |
| 244 | matcherResults.push_back(MatchingState::kMatched); |
| 245 | matcherResults.push_back(MatchingState::kNotMatched); |
| 246 | matcherResults.push_back(MatchingState::kMatched); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 247 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 248 | EXPECT_TRUE(combinationMatch(children, operation, matcherResults)); |
| 249 | |
| 250 | matcherResults.clear(); |
| 251 | matcherResults.push_back(MatchingState::kNotMatched); |
| 252 | matcherResults.push_back(MatchingState::kNotMatched); |
| 253 | matcherResults.push_back(MatchingState::kNotMatched); |
| 254 | |
| 255 | EXPECT_FALSE(combinationMatch(children, operation, matcherResults)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 256 | } |
| 257 | |
| 258 | TEST(LogEntryMatcherTest, TestNotMatcher) { |
| 259 | // Set up the matcher |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 260 | LogicalOperation operation = LogicalOperation::NOT; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 261 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 262 | vector<int> children; |
| 263 | children.push_back(0); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 264 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 265 | vector<MatchingState> matcherResults; |
| 266 | matcherResults.push_back(MatchingState::kMatched); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 267 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 268 | EXPECT_FALSE(combinationMatch(children, operation, matcherResults)); |
| 269 | |
| 270 | matcherResults.clear(); |
| 271 | matcherResults.push_back(MatchingState::kNotMatched); |
| 272 | EXPECT_TRUE(combinationMatch(children, operation, matcherResults)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 273 | } |
| 274 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 275 | TEST(LogEntryMatcherTest, TestNandMatcher) { |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 276 | // Set up the matcher |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 277 | LogicalOperation operation = LogicalOperation::NAND; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 278 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 279 | vector<int> children; |
| 280 | children.push_back(0); |
| 281 | children.push_back(1); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 282 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 283 | vector<MatchingState> matcherResults; |
| 284 | matcherResults.push_back(MatchingState::kMatched); |
| 285 | matcherResults.push_back(MatchingState::kNotMatched); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 286 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 287 | EXPECT_TRUE(combinationMatch(children, operation, matcherResults)); |
| 288 | |
| 289 | matcherResults.clear(); |
| 290 | matcherResults.push_back(MatchingState::kNotMatched); |
| 291 | matcherResults.push_back(MatchingState::kNotMatched); |
| 292 | EXPECT_TRUE(combinationMatch(children, operation, matcherResults)); |
| 293 | |
| 294 | matcherResults.clear(); |
| 295 | matcherResults.push_back(MatchingState::kMatched); |
| 296 | matcherResults.push_back(MatchingState::kMatched); |
| 297 | EXPECT_FALSE(combinationMatch(children, operation, matcherResults)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 298 | } |
| 299 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 300 | TEST(LogEntryMatcherTest, TestNorMatcher) { |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 301 | // Set up the matcher |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 302 | LogicalOperation operation = LogicalOperation::NOR; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 303 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 304 | vector<int> children; |
| 305 | children.push_back(0); |
| 306 | children.push_back(1); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 307 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 308 | vector<MatchingState> matcherResults; |
| 309 | matcherResults.push_back(MatchingState::kMatched); |
| 310 | matcherResults.push_back(MatchingState::kNotMatched); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 311 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 312 | EXPECT_FALSE(combinationMatch(children, operation, matcherResults)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 313 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 314 | matcherResults.clear(); |
| 315 | matcherResults.push_back(MatchingState::kNotMatched); |
| 316 | matcherResults.push_back(MatchingState::kNotMatched); |
| 317 | EXPECT_TRUE(combinationMatch(children, operation, matcherResults)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 318 | |
| Yao Chen | caf339d | 2017-10-06 16:01:10 -0700 | [diff] [blame] | 319 | matcherResults.clear(); |
| 320 | matcherResults.push_back(MatchingState::kMatched); |
| 321 | matcherResults.push_back(MatchingState::kMatched); |
| 322 | EXPECT_FALSE(combinationMatch(children, operation, matcherResults)); |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 323 | } |
| Stefan Lafon | cdb1a0e | 2017-09-27 20:24:15 -0700 | [diff] [blame] | 324 | |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 325 | #else |
| Yao Chen | 44cf27c | 2017-09-14 22:32:50 -0700 | [diff] [blame] | 326 | GTEST_LOG_(INFO) << "This test does nothing.\n"; |
| David Chen | dd89694 | 2017-09-26 11:44:40 -0700 | [diff] [blame] | 327 | #endif |