OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "components/variations/study_filtering.h" | 5 #include "components/variations/study_filtering.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/strings/string_split.h" | 9 #include "base/strings/string_split.h" |
10 #include "components/variations/processed_study.h" | 10 #include "components/variations/processed_study.h" |
(...skipping 257 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
268 { "1.*", "2.3.4", false }, | 268 { "1.*", "2.3.4", false }, |
269 }; | 269 }; |
270 | 270 |
271 Study_Filter filter; | 271 Study_Filter filter; |
272 | 272 |
273 // Min/max version not set should result in true. | 273 // Min/max version not set should result in true. |
274 EXPECT_TRUE(internal::CheckStudyVersion(filter, base::Version("1.2.3"))); | 274 EXPECT_TRUE(internal::CheckStudyVersion(filter, base::Version("1.2.3"))); |
275 | 275 |
276 for (size_t i = 0; i < arraysize(min_test_cases); ++i) { | 276 for (size_t i = 0; i < arraysize(min_test_cases); ++i) { |
277 filter.set_min_version(min_test_cases[i].min_version); | 277 filter.set_min_version(min_test_cases[i].min_version); |
278 const bool result = internal::CheckStudyVersion( | 278 const bool result = |
279 filter, base::Version(min_test_cases[i].version)); | 279 internal::CheckStudyVersion(filter, Version(min_test_cases[i].version)); |
280 EXPECT_EQ(min_test_cases[i].expected_result, result) << | 280 EXPECT_EQ(min_test_cases[i].expected_result, result) << |
281 "Min. version case " << i << " failed!"; | 281 "Min. version case " << i << " failed!"; |
282 } | 282 } |
283 filter.clear_min_version(); | 283 filter.clear_min_version(); |
284 | 284 |
285 for (size_t i = 0; i < arraysize(max_test_cases); ++i) { | 285 for (size_t i = 0; i < arraysize(max_test_cases); ++i) { |
286 filter.set_max_version(max_test_cases[i].max_version); | 286 filter.set_max_version(max_test_cases[i].max_version); |
287 const bool result = internal::CheckStudyVersion( | 287 const bool result = |
288 filter, base::Version(max_test_cases[i].version)); | 288 internal::CheckStudyVersion(filter, Version(max_test_cases[i].version)); |
289 EXPECT_EQ(max_test_cases[i].expected_result, result) << | 289 EXPECT_EQ(max_test_cases[i].expected_result, result) << |
290 "Max version case " << i << " failed!"; | 290 "Max version case " << i << " failed!"; |
291 } | 291 } |
292 | 292 |
293 // Check intersection semantics. | 293 // Check intersection semantics. |
294 for (size_t i = 0; i < arraysize(min_test_cases); ++i) { | 294 for (size_t i = 0; i < arraysize(min_test_cases); ++i) { |
295 for (size_t j = 0; j < arraysize(max_test_cases); ++j) { | 295 for (size_t j = 0; j < arraysize(max_test_cases); ++j) { |
296 filter.set_min_version(min_test_cases[i].min_version); | 296 filter.set_min_version(min_test_cases[i].min_version); |
297 filter.set_max_version(max_test_cases[j].max_version); | 297 filter.set_max_version(max_test_cases[j].max_version); |
298 | 298 |
299 if (!min_test_cases[i].expected_result) { | 299 if (!min_test_cases[i].expected_result) { |
300 const bool result = internal::CheckStudyVersion( | 300 const bool result = |
301 filter, base::Version(min_test_cases[i].version)); | 301 internal::CheckStudyVersion( |
| 302 filter, Version(min_test_cases[i].version)); |
302 EXPECT_FALSE(result) << "Case " << i << "," << j << " failed!"; | 303 EXPECT_FALSE(result) << "Case " << i << "," << j << " failed!"; |
303 } | 304 } |
304 | 305 |
305 if (!max_test_cases[j].expected_result) { | 306 if (!max_test_cases[j].expected_result) { |
306 const bool result = internal::CheckStudyVersion( | 307 const bool result = |
307 filter, base::Version(max_test_cases[j].version)); | 308 internal::CheckStudyVersion( |
| 309 filter, Version(max_test_cases[j].version)); |
308 EXPECT_FALSE(result) << "Case " << i << "," << j << " failed!"; | 310 EXPECT_FALSE(result) << "Case " << i << "," << j << " failed!"; |
309 } | 311 } |
310 } | 312 } |
311 } | 313 } |
312 } | 314 } |
313 | 315 |
314 TEST(VariationsStudyFilteringTest, CheckStudyHardwareClass) { | 316 TEST(VariationsStudyFilteringTest, CheckStudyHardwareClass) { |
315 struct { | 317 struct { |
316 const char* hardware_class; | 318 const char* hardware_class; |
317 const char* exclude_hardware_class; | 319 const char* exclude_hardware_class; |
(...skipping 248 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
566 | 568 |
567 default_group->set_name("def"); | 569 default_group->set_name("def"); |
568 EXPECT_TRUE(processed_study.Init(&study, false)); | 570 EXPECT_TRUE(processed_study.Init(&study, false)); |
569 Study_Experiment* repeated_group = study.add_experiment(); | 571 Study_Experiment* repeated_group = study.add_experiment(); |
570 repeated_group->set_name("abc"); | 572 repeated_group->set_name("abc"); |
571 repeated_group->set_probability_weight(1); | 573 repeated_group->set_probability_weight(1); |
572 EXPECT_FALSE(processed_study.Init(&study, false)); | 574 EXPECT_FALSE(processed_study.Init(&study, false)); |
573 } | 575 } |
574 | 576 |
575 } // namespace variations | 577 } // namespace variations |
OLD | NEW |