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

Unified Diff: tools/json_schema_compiler/test/enums_unittest.cc

Issue 10828407: JSON Schema Compiler supports Enums as types. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: more testing of optional enums Created 8 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 side-by-side diff with in-line comments
Download patch
Index: tools/json_schema_compiler/test/enums_unittest.cc
diff --git a/tools/json_schema_compiler/test/enums_unittest.cc b/tools/json_schema_compiler/test/enums_unittest.cc
index 6037874c62370ce59cf2a5b251bb6732dd697556..b9fec70e0e3d40ff8a637bc9ba555b47795e053f 100644
--- a/tools/json_schema_compiler/test/enums_unittest.cc
+++ b/tools/json_schema_compiler/test/enums_unittest.cc
@@ -10,18 +10,46 @@ using namespace test::api::enums;
TEST(JsonSchemaCompilerEnumsTest, EnumTypePopulate) {
{
- scoped_ptr<EnumType> enum_type(new EnumType());
- scoped_ptr<DictionaryValue> value(new DictionaryValue());
- value->Set("type", Value::CreateStringValue("one"));
- EXPECT_TRUE(EnumType::Populate(*value, enum_type.get()));
- EXPECT_EQ(EnumType::TYPE_ONE, enum_type->type);
- EXPECT_TRUE(value->Equals(enum_type->ToValue().get()));
+ EnumType enum_type;
+ DictionaryValue value;
+ value.Set("type", Value::CreateStringValue("one"));
+ EXPECT_TRUE(EnumType::Populate(value, &enum_type));
+ EXPECT_EQ(EnumType::TYPE_ONE, enum_type.type);
+ EXPECT_TRUE(value.Equals(enum_type.ToValue().get()));
}
{
- scoped_ptr<EnumType> enum_type(new EnumType());
- scoped_ptr<DictionaryValue> value(new DictionaryValue());
- value->Set("type", Value::CreateStringValue("invalid"));
- EXPECT_FALSE(EnumType::Populate(*value, enum_type.get()));
+ EnumType enum_type;
+ DictionaryValue value;
+ value.Set("type", Value::CreateStringValue("invalid"));
+ EXPECT_FALSE(EnumType::Populate(value, &enum_type));
+ }
+}
+
+TEST(JsonSchemaCompilerEnumsTest, EnumsAsTypes) {
+ {
+ ListValue args;
+ args.Append(Value::CreateStringValue("one"));
+
+ scoped_ptr<TakesEnumAsType::Params> params(
+ TakesEnumAsType::Params::Create(args));
+ ASSERT_TRUE(params.get());
+ EXPECT_EQ(ENUMERATION_ONE, params->enumeration);
+
+ EXPECT_TRUE(args.Equals(ReturnsEnumAsType::Results::Create(
+ ENUMERATION_ONE).get()));
+ }
+ {
+ HasEnumeration enumeration;
+ DictionaryValue value;
+ ASSERT_FALSE(HasEnumeration::Populate(value, &enumeration));
+
+ value.Set("enumeration", Value::CreateStringValue("one"));
+ ASSERT_TRUE(HasEnumeration::Populate(value, &enumeration));
+ EXPECT_TRUE(value.Equals(enumeration.ToValue().get()));
+
+ value.Set("optional_enumeration", Value::CreateStringValue("two"));
+ ASSERT_TRUE(HasEnumeration::Populate(value, &enumeration));
+ EXPECT_TRUE(value.Equals(enumeration.ToValue().get()));
}
}
@@ -55,105 +83,105 @@ TEST(JsonSchemaCompilerEnumsTest, ReturnsTwoEnumsCreate) {
TEST(JsonSchemaCompilerEnumsTest, OptionalEnumTypePopulate) {
{
- scoped_ptr<OptionalEnumType> enum_type(new OptionalEnumType());
- scoped_ptr<DictionaryValue> value(new DictionaryValue());
- value->Set("type", Value::CreateStringValue("two"));
- EXPECT_TRUE(OptionalEnumType::Populate(*value, enum_type.get()));
- EXPECT_EQ(OptionalEnumType::TYPE_TWO, enum_type->type);
- EXPECT_TRUE(value->Equals(enum_type->ToValue().get()));
+ OptionalEnumType enum_type;
+ DictionaryValue value;
+ value.Set("type", Value::CreateStringValue("two"));
+ EXPECT_TRUE(OptionalEnumType::Populate(value, &enum_type));
+ EXPECT_EQ(OptionalEnumType::TYPE_TWO, enum_type.type);
+ EXPECT_TRUE(value.Equals(enum_type.ToValue().get()));
}
{
- scoped_ptr<OptionalEnumType> enum_type(new OptionalEnumType());
- scoped_ptr<DictionaryValue> value(new DictionaryValue());
- EXPECT_TRUE(OptionalEnumType::Populate(*value, enum_type.get()));
- EXPECT_EQ(OptionalEnumType::TYPE_NONE, enum_type->type);
- EXPECT_TRUE(value->Equals(enum_type->ToValue().get()));
+ OptionalEnumType enum_type;
+ DictionaryValue value;
+ EXPECT_TRUE(OptionalEnumType::Populate(value, &enum_type));
+ EXPECT_EQ(OptionalEnumType::TYPE_NONE, enum_type.type);
+ EXPECT_TRUE(value.Equals(enum_type.ToValue().get()));
}
{
- scoped_ptr<OptionalEnumType> enum_type(new OptionalEnumType());
- scoped_ptr<DictionaryValue> value(new DictionaryValue());
- value->Set("type", Value::CreateStringValue("invalid"));
- EXPECT_FALSE(OptionalEnumType::Populate(*value, enum_type.get()));
+ OptionalEnumType enum_type;
+ DictionaryValue value;
+ value.Set("type", Value::CreateStringValue("invalid"));
+ EXPECT_FALSE(OptionalEnumType::Populate(value, &enum_type));
}
}
TEST(JsonSchemaCompilerEnumsTest, TakesEnumParamsCreate) {
{
- scoped_ptr<ListValue> params_value(new ListValue());
- params_value->Append(Value::CreateStringValue("baz"));
+ ListValue params_value;
+ params_value.Append(Value::CreateStringValue("baz"));
scoped_ptr<TakesEnum::Params> params(
- TakesEnum::Params::Create(*params_value));
+ TakesEnum::Params::Create(params_value));
EXPECT_TRUE(params.get());
EXPECT_EQ(TakesEnum::Params::STATE_BAZ, params->state);
}
{
- scoped_ptr<ListValue> params_value(new ListValue());
- params_value->Append(Value::CreateStringValue("invalid"));
+ ListValue params_value;
+ params_value.Append(Value::CreateStringValue("invalid"));
scoped_ptr<TakesEnum::Params> params(
- TakesEnum::Params::Create(*params_value));
+ TakesEnum::Params::Create(params_value));
EXPECT_FALSE(params.get());
}
}
TEST(JsonSchemaCompilerEnumsTest, TakesOptionalEnumParamsCreate) {
{
- scoped_ptr<ListValue> params_value(new ListValue());
- params_value->Append(Value::CreateStringValue("baz"));
+ ListValue params_value;
+ params_value.Append(Value::CreateStringValue("baz"));
scoped_ptr<TakesOptionalEnum::Params> params(
- TakesOptionalEnum::Params::Create(*params_value));
+ TakesOptionalEnum::Params::Create(params_value));
EXPECT_TRUE(params.get());
EXPECT_EQ(TakesOptionalEnum::Params::STATE_BAZ, params->state);
}
{
- scoped_ptr<ListValue> params_value(new ListValue());
+ ListValue params_value;
scoped_ptr<TakesOptionalEnum::Params> params(
- TakesOptionalEnum::Params::Create(*params_value));
+ TakesOptionalEnum::Params::Create(params_value));
EXPECT_TRUE(params.get());
EXPECT_EQ(TakesOptionalEnum::Params::STATE_NONE, params->state);
}
{
- scoped_ptr<ListValue> params_value(new ListValue());
- params_value->Append(Value::CreateStringValue("invalid"));
+ ListValue params_value;
+ params_value.Append(Value::CreateStringValue("invalid"));
scoped_ptr<TakesOptionalEnum::Params> params(
- TakesOptionalEnum::Params::Create(*params_value));
+ TakesOptionalEnum::Params::Create(params_value));
EXPECT_FALSE(params.get());
}
}
TEST(JsonSchemaCompilerEnumsTest, TakesMultipleOptionalEnumsParamsCreate) {
{
- scoped_ptr<ListValue> params_value(new ListValue());
- params_value->Append(Value::CreateStringValue("foo"));
- params_value->Append(Value::CreateStringValue("foo"));
+ ListValue params_value;
+ params_value.Append(Value::CreateStringValue("foo"));
+ params_value.Append(Value::CreateStringValue("foo"));
scoped_ptr<TakesMultipleOptionalEnums::Params> params(
- TakesMultipleOptionalEnums::Params::Create(*params_value));
+ TakesMultipleOptionalEnums::Params::Create(params_value));
EXPECT_TRUE(params.get());
EXPECT_EQ(TakesMultipleOptionalEnums::Params::STATE_FOO, params->state);
EXPECT_EQ(TakesMultipleOptionalEnums::Params::TYPE_FOO, params->type);
}
{
- scoped_ptr<ListValue> params_value(new ListValue());
- params_value->Append(Value::CreateStringValue("foo"));
+ ListValue params_value;
+ params_value.Append(Value::CreateStringValue("foo"));
scoped_ptr<TakesMultipleOptionalEnums::Params> params(
- TakesMultipleOptionalEnums::Params::Create(*params_value));
+ TakesMultipleOptionalEnums::Params::Create(params_value));
EXPECT_TRUE(params.get());
EXPECT_EQ(TakesMultipleOptionalEnums::Params::STATE_FOO, params->state);
EXPECT_EQ(TakesMultipleOptionalEnums::Params::TYPE_NONE, params->type);
}
{
- scoped_ptr<ListValue> params_value(new ListValue());
+ ListValue params_value;
scoped_ptr<TakesMultipleOptionalEnums::Params> params(
- TakesMultipleOptionalEnums::Params::Create(*params_value));
+ TakesMultipleOptionalEnums::Params::Create(params_value));
EXPECT_TRUE(params.get());
EXPECT_EQ(TakesMultipleOptionalEnums::Params::STATE_NONE, params->state);
EXPECT_EQ(TakesMultipleOptionalEnums::Params::TYPE_NONE, params->type);
}
{
- scoped_ptr<ListValue> params_value(new ListValue());
- params_value->Append(Value::CreateStringValue("baz"));
- params_value->Append(Value::CreateStringValue("invalid"));
+ ListValue params_value;
+ params_value.Append(Value::CreateStringValue("baz"));
+ params_value.Append(Value::CreateStringValue("invalid"));
scoped_ptr<TakesMultipleOptionalEnums::Params> params(
- TakesMultipleOptionalEnums::Params::Create(*params_value));
+ TakesMultipleOptionalEnums::Params::Create(params_value));
EXPECT_FALSE(params.get());
}
}
« tools/json_schema_compiler/h_generator.py ('K') | « tools/json_schema_compiler/test/enums.json ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698