Index: tools/json_schema_compiler/test/crossref_unittest.cc |
diff --git a/tools/json_schema_compiler/test/crossref_unittest.cc b/tools/json_schema_compiler/test/crossref_unittest.cc |
index 7d8879d0f2062e283e5a504000e5a14d369341e4..cc2067513878dea5575388b9a9d46f11e9788030 100644 |
--- a/tools/json_schema_compiler/test/crossref_unittest.cc |
+++ b/tools/json_schema_compiler/test/crossref_unittest.cc |
@@ -7,63 +7,72 @@ |
#include "testing/gtest/include/gtest/gtest.h" |
-using namespace test::api::crossref; |
+using namespace test::api; |
namespace { |
-static scoped_ptr<base::DictionaryValue> CreateTestTypeDictionary() { |
+scoped_ptr<base::DictionaryValue> CreateTestTypeValue() { |
base::DictionaryValue* value(new base::DictionaryValue()); |
- value->SetWithoutPathExpansion("number", new base::FundamentalValue(1.1)); |
- value->SetWithoutPathExpansion("integer", new base::FundamentalValue(4)); |
- value->SetWithoutPathExpansion("string", new base::StringValue("bling")); |
- value->SetWithoutPathExpansion("boolean", new base::FundamentalValue(true)); |
+ value->Set("number", new base::FundamentalValue(1.1)); |
+ value->Set("integer", new base::FundamentalValue(4)); |
+ value->Set("string", new base::StringValue("bling")); |
+ value->Set("boolean", new base::FundamentalValue(true)); |
return scoped_ptr<base::DictionaryValue>(value); |
} |
} // namespace |
-TEST(JsonSchemaCompilerCrossrefTest, CrossrefTypePopulate) { |
- scoped_ptr<CrossrefType> crossref_type(new CrossrefType()); |
- scoped_ptr<base::DictionaryValue> value(new base::DictionaryValue()); |
- value->Set("testType", CreateTestTypeDictionary().release()); |
- EXPECT_TRUE(CrossrefType::Populate(*value, crossref_type.get())); |
- EXPECT_TRUE(crossref_type->test_type.get()); |
- EXPECT_TRUE(CreateTestTypeDictionary()->Equals( |
- crossref_type->test_type->ToValue().get())); |
- EXPECT_TRUE(value->Equals(crossref_type->ToValue().get())); |
+TEST(JsonSchemaCompilerCrossrefTest, CrossrefTypePopulateAndToValue) { |
+ base::DictionaryValue crossref_orig; |
+ crossref_orig.Set("testType", CreateTestTypeValue().release()); |
+ crossref_orig.Set("testEnumRequired", new base::StringValue("one")); |
+ crossref_orig.Set("testEnumOptional", new base::StringValue("two")); |
+ |
+ // Test Populate of the value --> compiled type. |
+ crossref::CrossrefType crossref_type; |
+ ASSERT_TRUE(crossref::CrossrefType::Populate(crossref_orig, &crossref_type)); |
+ EXPECT_EQ(1.1, crossref_type.test_type.number); |
+ EXPECT_EQ(4, crossref_type.test_type.integer); |
+ EXPECT_EQ("bling", crossref_type.test_type.string); |
+ EXPECT_EQ(true, crossref_type.test_type.boolean); |
+ EXPECT_EQ(simple_api::TEST_ENUM_ONE, crossref_type.test_enum_required); |
+ EXPECT_EQ(simple_api::TEST_ENUM_TWO, crossref_type.test_enum_optional); |
+ EXPECT_EQ(simple_api::TEST_ENUM_NONE, crossref_type.test_enum_optional_extra); |
+ |
+ // Test ToValue of the compiled type --> value. |
+ scoped_ptr<base::DictionaryValue> crossref_value = crossref_type.ToValue(); |
+ ASSERT_TRUE(crossref_value); |
+ EXPECT_TRUE(crossref_orig.Equals(crossref_value.get())); |
} |
TEST(JsonSchemaCompilerCrossrefTest, TestTypeOptionalParamCreate) { |
scoped_ptr<base::ListValue> params_value(new base::ListValue()); |
- params_value->Append(CreateTestTypeDictionary().release()); |
- scoped_ptr<TestTypeOptionalParam::Params> params( |
- TestTypeOptionalParam::Params::Create(*params_value)); |
+ params_value->Append(CreateTestTypeValue().release()); |
+ scoped_ptr<crossref::TestTypeOptionalParam::Params> params( |
+ crossref::TestTypeOptionalParam::Params::Create(*params_value)); |
EXPECT_TRUE(params.get()); |
EXPECT_TRUE(params->test_type.get()); |
EXPECT_TRUE( |
- CreateTestTypeDictionary()->Equals(params->test_type->ToValue().get())); |
+ CreateTestTypeValue()->Equals(params->test_type->ToValue().get())); |
} |
TEST(JsonSchemaCompilerCrossrefTest, TestTypeOptionalParamFail) { |
scoped_ptr<base::ListValue> params_value(new base::ListValue()); |
- scoped_ptr<base::DictionaryValue> test_type_value = |
- CreateTestTypeDictionary(); |
+ scoped_ptr<base::DictionaryValue> test_type_value = CreateTestTypeValue(); |
test_type_value->RemoveWithoutPathExpansion("number", NULL); |
params_value->Append(test_type_value.release()); |
- scoped_ptr<TestTypeOptionalParam::Params> params( |
- TestTypeOptionalParam::Params::Create(*params_value)); |
+ scoped_ptr<crossref::TestTypeOptionalParam::Params> params( |
+ crossref::TestTypeOptionalParam::Params::Create(*params_value)); |
EXPECT_FALSE(params.get()); |
} |
TEST(JsonSchemaCompilerCrossrefTest, GetTestType) { |
- scoped_ptr<base::DictionaryValue> value = CreateTestTypeDictionary(); |
- scoped_ptr<test::api::simple_api::TestType> test_type( |
- new test::api::simple_api::TestType()); |
- EXPECT_TRUE( |
- test::api::simple_api::TestType::Populate(*value, test_type.get())); |
+ scoped_ptr<base::DictionaryValue> value = CreateTestTypeValue(); |
+ scoped_ptr<simple_api::TestType> test_type(new simple_api::TestType()); |
+ EXPECT_TRUE(simple_api::TestType::Populate(*value, test_type.get())); |
scoped_ptr<base::ListValue> results = |
- GetTestType::Results::Create(*test_type); |
+ crossref::GetTestType::Results::Create(*test_type); |
base::DictionaryValue* result_dict = NULL; |
results->GetDictionary(0, &result_dict); |
EXPECT_TRUE(value->Equals(result_dict)); |
@@ -74,16 +83,16 @@ TEST(JsonSchemaCompilerCrossrefTest, TestTypeInObjectParamsCreate) { |
scoped_ptr<base::ListValue> params_value(new base::ListValue()); |
scoped_ptr<base::DictionaryValue> param_object_value( |
new base::DictionaryValue()); |
- param_object_value->Set("testType", CreateTestTypeDictionary().release()); |
+ param_object_value->Set("testType", CreateTestTypeValue().release()); |
param_object_value->Set("boolean", new base::FundamentalValue(true)); |
params_value->Append(param_object_value.release()); |
- scoped_ptr<TestTypeInObject::Params> params( |
- TestTypeInObject::Params::Create(*params_value)); |
+ scoped_ptr<crossref::TestTypeInObject::Params> params( |
+ crossref::TestTypeInObject::Params::Create(*params_value)); |
EXPECT_TRUE(params.get()); |
EXPECT_TRUE(params->param_object.test_type.get()); |
EXPECT_TRUE(params->param_object.boolean); |
- EXPECT_TRUE(CreateTestTypeDictionary()->Equals( |
- params->param_object.test_type->ToValue().get())); |
+ EXPECT_TRUE(CreateTestTypeValue()->Equals( |
+ params->param_object.test_type->ToValue().get())); |
} |
{ |
scoped_ptr<base::ListValue> params_value(new base::ListValue()); |
@@ -91,8 +100,8 @@ TEST(JsonSchemaCompilerCrossrefTest, TestTypeInObjectParamsCreate) { |
new base::DictionaryValue()); |
param_object_value->Set("boolean", new base::FundamentalValue(true)); |
params_value->Append(param_object_value.release()); |
- scoped_ptr<TestTypeInObject::Params> params( |
- TestTypeInObject::Params::Create(*params_value)); |
+ scoped_ptr<crossref::TestTypeInObject::Params> params( |
+ crossref::TestTypeInObject::Params::Create(*params_value)); |
EXPECT_TRUE(params.get()); |
EXPECT_FALSE(params->param_object.test_type.get()); |
EXPECT_TRUE(params->param_object.boolean); |
@@ -104,18 +113,18 @@ TEST(JsonSchemaCompilerCrossrefTest, TestTypeInObjectParamsCreate) { |
param_object_value->Set("testType", new base::StringValue("invalid")); |
param_object_value->Set("boolean", new base::FundamentalValue(true)); |
params_value->Append(param_object_value.release()); |
- scoped_ptr<TestTypeInObject::Params> params( |
- TestTypeInObject::Params::Create(*params_value)); |
+ scoped_ptr<crossref::TestTypeInObject::Params> params( |
+ crossref::TestTypeInObject::Params::Create(*params_value)); |
EXPECT_FALSE(params.get()); |
} |
{ |
scoped_ptr<base::ListValue> params_value(new base::ListValue()); |
scoped_ptr<base::DictionaryValue> param_object_value( |
new base::DictionaryValue()); |
- param_object_value->Set("testType", CreateTestTypeDictionary().release()); |
+ param_object_value->Set("testType", CreateTestTypeValue().release()); |
params_value->Append(param_object_value.release()); |
- scoped_ptr<TestTypeInObject::Params> params( |
- TestTypeInObject::Params::Create(*params_value)); |
+ scoped_ptr<crossref::TestTypeInObject::Params> params( |
+ crossref::TestTypeInObject::Params::Create(*params_value)); |
EXPECT_FALSE(params.get()); |
} |
} |