Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(353)

Side by Side Diff: chrome/common/json_schema_validator_unittest_base.cc

Issue 7647026: base: Add three helper functions to Values API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix a typo Ceate -> Create Created 9 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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 "chrome/common/json_schema_validator_unittest_base.h" 5 #include "chrome/common/json_schema_validator_unittest_base.h"
6 6
7 #include <cfloat> 7 #include <cfloat>
8 #include <cmath> 8 #include <cmath>
9 #include <limits> 9 #include <limits>
10 10
(...skipping 121 matching lines...) Expand 10 before | Expand all | Expand 10 after
132 void JSONSchemaValidatorTestBase::TestEnum() { 132 void JSONSchemaValidatorTestBase::TestEnum() {
133 scoped_ptr<DictionaryValue> schema(LoadDictionary("enum_schema.json")); 133 scoped_ptr<DictionaryValue> schema(LoadDictionary("enum_schema.json"));
134 134
135 ExpectValid(TEST_SOURCE, 135 ExpectValid(TEST_SOURCE,
136 scoped_ptr<Value>(Value::CreateStringValue("foo")).get(), 136 scoped_ptr<Value>(Value::CreateStringValue("foo")).get(),
137 schema.get(), NULL); 137 schema.get(), NULL);
138 ExpectValid(TEST_SOURCE, 138 ExpectValid(TEST_SOURCE,
139 scoped_ptr<Value>(Value::CreateIntegerValue(42)).get(), 139 scoped_ptr<Value>(Value::CreateIntegerValue(42)).get(),
140 schema.get(), NULL); 140 schema.get(), NULL);
141 ExpectValid(TEST_SOURCE, 141 ExpectValid(TEST_SOURCE,
142 scoped_ptr<Value>(Value::CreateBooleanValue(false)).get(), 142 scoped_ptr<Value>(base::FalseValue()).get(),
143 schema.get(), NULL); 143 schema.get(), NULL);
144 144
145 ExpectNotValid(TEST_SOURCE, 145 ExpectNotValid(TEST_SOURCE,
146 scoped_ptr<Value>(Value::CreateStringValue("42")).get(), 146 scoped_ptr<Value>(Value::CreateStringValue("42")).get(),
147 schema.get(), NULL, "", JSONSchemaValidator::kInvalidEnum); 147 schema.get(), NULL, "", JSONSchemaValidator::kInvalidEnum);
148 ExpectNotValid(TEST_SOURCE, 148 ExpectNotValid(TEST_SOURCE,
149 scoped_ptr<Value>(Value::CreateNullValue()).get(), 149 scoped_ptr<Value>(base::NullValue()).get(),
150 schema.get(), NULL, "", JSONSchemaValidator::kInvalidEnum); 150 schema.get(), NULL, "", JSONSchemaValidator::kInvalidEnum);
151 } 151 }
152 152
153 void JSONSchemaValidatorTestBase::TestChoices() { 153 void JSONSchemaValidatorTestBase::TestChoices() {
154 scoped_ptr<DictionaryValue> schema(LoadDictionary("choices_schema.json")); 154 scoped_ptr<DictionaryValue> schema(LoadDictionary("choices_schema.json"));
155 155
156 ExpectValid(TEST_SOURCE, 156 ExpectValid(TEST_SOURCE,
157 scoped_ptr<Value>(Value::CreateNullValue()).get(), 157 scoped_ptr<Value>(base::NullValue()).get(),
158 schema.get(), NULL); 158 schema.get(), NULL);
159 ExpectValid(TEST_SOURCE, 159 ExpectValid(TEST_SOURCE,
160 scoped_ptr<Value>(Value::CreateIntegerValue(42)).get(), 160 scoped_ptr<Value>(Value::CreateIntegerValue(42)).get(),
161 schema.get(), NULL); 161 schema.get(), NULL);
162 162
163 scoped_ptr<DictionaryValue> instance(new DictionaryValue()); 163 scoped_ptr<DictionaryValue> instance(new DictionaryValue());
164 instance->SetString("foo", "bar"); 164 instance->SetString("foo", "bar");
165 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL); 165 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL);
166 166
167 ExpectNotValid(TEST_SOURCE, 167 ExpectNotValid(TEST_SOURCE,
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after
229 DictionaryValue* properties = NULL; 229 DictionaryValue* properties = NULL;
230 DictionaryValue* bar_property = NULL; 230 DictionaryValue* bar_property = NULL;
231 ASSERT_TRUE(schema->GetDictionary("properties", &properties)); 231 ASSERT_TRUE(schema->GetDictionary("properties", &properties));
232 ASSERT_TRUE(properties->GetDictionary("bar", &bar_property)); 232 ASSERT_TRUE(properties->GetDictionary("bar", &bar_property));
233 233
234 bar_property->SetBoolean("optional", true); 234 bar_property->SetBoolean("optional", true);
235 instance->Remove("extra", NULL); 235 instance->Remove("extra", NULL);
236 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL); 236 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL);
237 instance->Remove("bar", NULL); 237 instance->Remove("bar", NULL);
238 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL); 238 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL);
239 instance->Set("bar", Value::CreateNullValue()); 239 instance->Set("bar", base::NullValue());
240 ExpectNotValid(TEST_SOURCE, instance.get(), schema.get(), NULL, 240 ExpectNotValid(TEST_SOURCE, instance.get(), schema.get(), NULL,
241 "bar", JSONSchemaValidator::FormatErrorMessage( 241 "bar", JSONSchemaValidator::FormatErrorMessage(
242 JSONSchemaValidator::kInvalidType, "integer", "null")); 242 JSONSchemaValidator::kInvalidType, "integer", "null"));
243 instance->SetString("bar", "42"); 243 instance->SetString("bar", "42");
244 ExpectNotValid(TEST_SOURCE, instance.get(), schema.get(), NULL, 244 ExpectNotValid(TEST_SOURCE, instance.get(), schema.get(), NULL,
245 "bar", JSONSchemaValidator::FormatErrorMessage( 245 "bar", JSONSchemaValidator::FormatErrorMessage(
246 JSONSchemaValidator::kInvalidType, "integer", "string")); 246 JSONSchemaValidator::kInvalidType, "integer", "string"));
247 } 247 }
248 248
249 void JSONSchemaValidatorTestBase::TestTypeReference() { 249 void JSONSchemaValidatorTestBase::TestTypeReference() {
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after
337 instance->Set(0, Value::CreateStringValue("42")); 337 instance->Set(0, Value::CreateStringValue("42"));
338 instance->Append(Value::CreateStringValue("anything")); 338 instance->Append(Value::CreateStringValue("anything"));
339 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL); 339 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL);
340 instance->Set(2, new ListValue()); 340 instance->Set(2, new ListValue());
341 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL); 341 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL);
342 342
343 additional_properties->SetString("type", "boolean"); 343 additional_properties->SetString("type", "boolean");
344 ExpectNotValid(TEST_SOURCE, instance.get(), schema.get(), NULL, "2", 344 ExpectNotValid(TEST_SOURCE, instance.get(), schema.get(), NULL, "2",
345 JSONSchemaValidator::FormatErrorMessage( 345 JSONSchemaValidator::FormatErrorMessage(
346 JSONSchemaValidator::kInvalidType, "boolean", "array")); 346 JSONSchemaValidator::kInvalidType, "boolean", "array"));
347 instance->Set(2, Value::CreateBooleanValue(false)); 347 instance->Set(2, base::FalseValue());
348 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL); 348 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL);
349 349
350 ListValue* items_schema = NULL; 350 ListValue* items_schema = NULL;
351 DictionaryValue* item0_schema = NULL; 351 DictionaryValue* item0_schema = NULL;
352 ASSERT_TRUE(schema->GetList("items", &items_schema)); 352 ASSERT_TRUE(schema->GetList("items", &items_schema));
353 ASSERT_TRUE(items_schema->GetDictionary(0, &item0_schema)); 353 ASSERT_TRUE(items_schema->GetDictionary(0, &item0_schema));
354 item0_schema->SetBoolean("optional", true); 354 item0_schema->SetBoolean("optional", true);
355 instance->Remove(2, NULL); 355 instance->Remove(2, NULL);
356 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL); 356 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL);
357 // TODO(aa): I think this is inconsistent with the handling of NULL+optional 357 // TODO(aa): I think this is inconsistent with the handling of NULL+optional
358 // for objects. 358 // for objects.
359 instance->Set(0, Value::CreateNullValue()); 359 instance->Set(0, base::NullValue());
360 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL); 360 ExpectValid(TEST_SOURCE, instance.get(), schema.get(), NULL);
361 instance->Set(0, Value::CreateIntegerValue(42)); 361 instance->Set(0, Value::CreateIntegerValue(42));
362 ExpectNotValid(TEST_SOURCE, instance.get(), schema.get(), NULL, "0", 362 ExpectNotValid(TEST_SOURCE, instance.get(), schema.get(), NULL, "0",
363 JSONSchemaValidator::FormatErrorMessage( 363 JSONSchemaValidator::FormatErrorMessage(
364 JSONSchemaValidator::kInvalidType, "string", "integer")); 364 JSONSchemaValidator::kInvalidType, "string", "integer"));
365 } 365 }
366 366
367 void JSONSchemaValidatorTestBase::TestArrayNonTuple() { 367 void JSONSchemaValidatorTestBase::TestArrayNonTuple() {
368 scoped_ptr<DictionaryValue> schema(new DictionaryValue()); 368 scoped_ptr<DictionaryValue> schema(new DictionaryValue());
369 schema->SetString("type", "array"); 369 schema->SetString("type", "array");
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after
453 ExpectNotValid( 453 ExpectNotValid(
454 TEST_SOURCE, 454 TEST_SOURCE,
455 scoped_ptr<Value>(Value::CreateDoubleValue(100.1)).get(), 455 scoped_ptr<Value>(Value::CreateDoubleValue(100.1)).get(),
456 schema.get(), NULL, "", 456 schema.get(), NULL, "",
457 JSONSchemaValidator::FormatErrorMessage( 457 JSONSchemaValidator::FormatErrorMessage(
458 JSONSchemaValidator::kNumberMaximum, "100")); 458 JSONSchemaValidator::kNumberMaximum, "100"));
459 } 459 }
460 460
461 void JSONSchemaValidatorTestBase::TestTypeClassifier() { 461 void JSONSchemaValidatorTestBase::TestTypeClassifier() {
462 EXPECT_EQ("boolean", JSONSchemaValidator::GetJSONSchemaType( 462 EXPECT_EQ("boolean", JSONSchemaValidator::GetJSONSchemaType(
463 scoped_ptr<Value>(Value::CreateBooleanValue(true)).get())); 463 scoped_ptr<Value>(base::TrueValue()).get()));
464 EXPECT_EQ("boolean", JSONSchemaValidator::GetJSONSchemaType( 464 EXPECT_EQ("boolean", JSONSchemaValidator::GetJSONSchemaType(
465 scoped_ptr<Value>(Value::CreateBooleanValue(false)).get())); 465 scoped_ptr<Value>(base::FalseValue()).get()));
466 466
467 // It doesn't matter whether the C++ type is 'integer' or 'real'. If the 467 // It doesn't matter whether the C++ type is 'integer' or 'real'. If the
468 // number is integral and within the representable range of integers in 468 // number is integral and within the representable range of integers in
469 // double, it's classified as 'integer'. 469 // double, it's classified as 'integer'.
470 EXPECT_EQ("integer", JSONSchemaValidator::GetJSONSchemaType( 470 EXPECT_EQ("integer", JSONSchemaValidator::GetJSONSchemaType(
471 scoped_ptr<Value>(Value::CreateIntegerValue(42)).get())); 471 scoped_ptr<Value>(Value::CreateIntegerValue(42)).get()));
472 EXPECT_EQ("integer", JSONSchemaValidator::GetJSONSchemaType( 472 EXPECT_EQ("integer", JSONSchemaValidator::GetJSONSchemaType(
473 scoped_ptr<Value>(Value::CreateIntegerValue(0)).get())); 473 scoped_ptr<Value>(Value::CreateIntegerValue(0)).get()));
474 EXPECT_EQ("integer", JSONSchemaValidator::GetJSONSchemaType( 474 EXPECT_EQ("integer", JSONSchemaValidator::GetJSONSchemaType(
475 scoped_ptr<Value>(Value::CreateDoubleValue(42)).get())); 475 scoped_ptr<Value>(Value::CreateDoubleValue(42)).get()));
(...skipping 15 matching lines...) Expand all
491 scoped_ptr<Value>(Value::CreateDoubleValue( 491 scoped_ptr<Value>(Value::CreateDoubleValue(
492 pow(-2.0, DBL_MANT_DIG) * 2)).get())); 492 pow(-2.0, DBL_MANT_DIG) * 2)).get()));
493 493
494 EXPECT_EQ("string", JSONSchemaValidator::GetJSONSchemaType( 494 EXPECT_EQ("string", JSONSchemaValidator::GetJSONSchemaType(
495 scoped_ptr<Value>(Value::CreateStringValue("foo")).get())); 495 scoped_ptr<Value>(Value::CreateStringValue("foo")).get()));
496 EXPECT_EQ("array", JSONSchemaValidator::GetJSONSchemaType( 496 EXPECT_EQ("array", JSONSchemaValidator::GetJSONSchemaType(
497 scoped_ptr<Value>(new ListValue()).get())); 497 scoped_ptr<Value>(new ListValue()).get()));
498 EXPECT_EQ("object", JSONSchemaValidator::GetJSONSchemaType( 498 EXPECT_EQ("object", JSONSchemaValidator::GetJSONSchemaType(
499 scoped_ptr<Value>(new DictionaryValue()).get())); 499 scoped_ptr<Value>(new DictionaryValue()).get()));
500 EXPECT_EQ("null", JSONSchemaValidator::GetJSONSchemaType( 500 EXPECT_EQ("null", JSONSchemaValidator::GetJSONSchemaType(
501 scoped_ptr<Value>(Value::CreateNullValue()).get())); 501 scoped_ptr<Value>(base::NullValue()).get()));
502 } 502 }
503 503
504 void JSONSchemaValidatorTestBase::TestTypes() { 504 void JSONSchemaValidatorTestBase::TestTypes() {
505 scoped_ptr<DictionaryValue> schema(new DictionaryValue()); 505 scoped_ptr<DictionaryValue> schema(new DictionaryValue());
506 506
507 // valid 507 // valid
508 schema->SetString("type", "object"); 508 schema->SetString("type", "object");
509 ExpectValid(TEST_SOURCE, scoped_ptr<Value>(new DictionaryValue()).get(), 509 ExpectValid(TEST_SOURCE, scoped_ptr<Value>(new DictionaryValue()).get(),
510 schema.get(), NULL); 510 schema.get(), NULL);
511 511
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
546 scoped_ptr<Value>( 546 scoped_ptr<Value>(
547 Value::CreateDoubleValue(pow(2.0, DBL_MANT_DIG))).get(), 547 Value::CreateDoubleValue(pow(2.0, DBL_MANT_DIG))).get(),
548 schema.get(), NULL); 548 schema.get(), NULL);
549 ExpectValid(TEST_SOURCE, 549 ExpectValid(TEST_SOURCE,
550 scoped_ptr<Value>( 550 scoped_ptr<Value>(
551 Value::CreateDoubleValue(pow(-2.0, DBL_MANT_DIG))).get(), 551 Value::CreateDoubleValue(pow(-2.0, DBL_MANT_DIG))).get(),
552 schema.get(), NULL); 552 schema.get(), NULL);
553 553
554 schema->SetString("type", "boolean"); 554 schema->SetString("type", "boolean");
555 ExpectValid(TEST_SOURCE, 555 ExpectValid(TEST_SOURCE,
556 scoped_ptr<Value>(Value::CreateBooleanValue(false)).get(), 556 scoped_ptr<Value>(base::FalseValue()).get(),
557 schema.get(), NULL); 557 schema.get(), NULL);
558 ExpectValid(TEST_SOURCE, 558 ExpectValid(TEST_SOURCE,
559 scoped_ptr<Value>(Value::CreateBooleanValue(true)).get(), 559 scoped_ptr<Value>(base::TrueValue()).get(),
560 schema.get(), NULL); 560 schema.get(), NULL);
561 561
562 schema->SetString("type", "null"); 562 schema->SetString("type", "null");
563 ExpectValid(TEST_SOURCE, 563 ExpectValid(TEST_SOURCE,
564 scoped_ptr<Value>(Value::CreateNullValue()).get(), 564 scoped_ptr<Value>(base::NullValue()).get(),
565 schema.get(), NULL); 565 schema.get(), NULL);
566 566
567 // not valid 567 // not valid
568 schema->SetString("type", "object"); 568 schema->SetString("type", "object");
569 ExpectNotValid(TEST_SOURCE, scoped_ptr<Value>(new ListValue()).get(), 569 ExpectNotValid(TEST_SOURCE, scoped_ptr<Value>(new ListValue()).get(),
570 schema.get(), NULL, "", 570 schema.get(), NULL, "",
571 JSONSchemaValidator::FormatErrorMessage( 571 JSONSchemaValidator::FormatErrorMessage(
572 JSONSchemaValidator::kInvalidType, "object", "array")); 572 JSONSchemaValidator::kInvalidType, "object", "array"));
573 573
574 schema->SetString("type", "object"); 574 schema->SetString("type", "object");
575 ExpectNotValid(TEST_SOURCE, scoped_ptr<Value>(Value::CreateNullValue()).get(), 575 ExpectNotValid(TEST_SOURCE, scoped_ptr<Value>(base::NullValue()).get(),
576 schema.get(), NULL, "", 576 schema.get(), NULL, "",
577 JSONSchemaValidator::FormatErrorMessage( 577 JSONSchemaValidator::FormatErrorMessage(
578 JSONSchemaValidator::kInvalidType, "object", "null")); 578 JSONSchemaValidator::kInvalidType, "object", "null"));
579 579
580 schema->SetString("type", "array"); 580 schema->SetString("type", "array");
581 ExpectNotValid(TEST_SOURCE, 581 ExpectNotValid(TEST_SOURCE,
582 scoped_ptr<Value>(Value::CreateIntegerValue(42)).get(), 582 scoped_ptr<Value>(Value::CreateIntegerValue(42)).get(),
583 schema.get(), NULL, "", 583 schema.get(), NULL, "",
584 JSONSchemaValidator::FormatErrorMessage( 584 JSONSchemaValidator::FormatErrorMessage(
585 JSONSchemaValidator::kInvalidType, "array", "integer")); 585 JSONSchemaValidator::kInvalidType, "array", "integer"));
(...skipping 28 matching lines...) Expand all
614 614
615 schema->SetString("type", "boolean"); 615 schema->SetString("type", "boolean");
616 ExpectNotValid(TEST_SOURCE, 616 ExpectNotValid(TEST_SOURCE,
617 scoped_ptr<Value>(Value::CreateIntegerValue(1)).get(), 617 scoped_ptr<Value>(Value::CreateIntegerValue(1)).get(),
618 schema.get(), NULL, "", 618 schema.get(), NULL, "",
619 JSONSchemaValidator::FormatErrorMessage( 619 JSONSchemaValidator::FormatErrorMessage(
620 JSONSchemaValidator::kInvalidType, "boolean", "integer")); 620 JSONSchemaValidator::kInvalidType, "boolean", "integer"));
621 621
622 schema->SetString("type", "null"); 622 schema->SetString("type", "null");
623 ExpectNotValid(TEST_SOURCE, 623 ExpectNotValid(TEST_SOURCE,
624 scoped_ptr<Value>(Value::CreateBooleanValue(false)).get(), 624 scoped_ptr<Value>(base::FalseValue()).get(),
625 schema.get(), NULL, "", 625 schema.get(), NULL, "",
626 JSONSchemaValidator::FormatErrorMessage( 626 JSONSchemaValidator::FormatErrorMessage(
627 JSONSchemaValidator::kInvalidType, "null", "boolean")); 627 JSONSchemaValidator::kInvalidType, "null", "boolean"));
628 } 628 }
OLDNEW
« no previous file with comments | « chrome/common/json_pref_store_unittest.cc ('k') | chrome/test/webdriver/commands/set_timeout_commands_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698