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

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

Issue 22228002: Add optional schema compiler error messages (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Code clean up, fixed tests, improved errors. Created 7 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/error_generation_unittest.cc
diff --git a/tools/json_schema_compiler/test/error_generation_unittest.cc b/tools/json_schema_compiler/test/error_generation_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..0848d47d40c56fda04a4331780f0b7281a889c23
--- /dev/null
+++ b/tools/json_schema_compiler/test/error_generation_unittest.cc
@@ -0,0 +1,202 @@
+// Copyright 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "tools/json_schema_compiler/test/error_generation.h"
+
+#include "base/json/json_writer.h"
+#include "testing/gtest/include/gtest/gtest.h"
+#include "tools/json_schema_compiler/test/test_util.h"
+
+using namespace test::api::error_generation;
+using base::FundamentalValue;
+using json_schema_compiler::test_util::Dictionary;
+using json_schema_compiler::test_util::List;
+
+// GenerateTypePopulate errors
+
+TEST(JsonSchemaCompilerErrorTest, RequiredPropertyPopulate) {
+ {
+ scoped_ptr<DictionaryValue> value = Dictionary(
+ "string", new StringValue("bling"));
+ EXPECT_TRUE(TestType::Populate(*value, new TestType()));
+ }
+ {
+ scoped_ptr<base::BinaryValue> value(new base::BinaryValue());
+ std::string error;
+ EXPECT_FALSE(TestType::Populate(*value, new TestType(), &error));
not at google - send to devlin 2013/08/09 18:20:58 (new TestType()) looks leaky... other tests like t
dhnishi (use Chromium) 2013/08/09 20:50:48 Valgrind suggests an 4-16 byte leak for all of tho
+ EXPECT_EQ(error, "expected dictionary, got binary");
+ }
+}
+
+TEST(JsonSchemaCompilerErrorTest, UnexpectedTypePopulation) {
+ {
+ scoped_ptr<base::ListValue> good_value(new base::ListValue());
+ EXPECT_TRUE(ChoiceType::Integers::Populate(*good_value,
+ new ChoiceType::Integers()));
+ }
+ {
+ scoped_ptr<base::BinaryValue> bad_value(new base::BinaryValue());
+ std::string error;
+ EXPECT_FALSE(ChoiceType::Integers::Populate(*bad_value,
+ new ChoiceType::Integers(),
+ &error));
+ EXPECT_EQ(error, "expected integers or integer, got binary");
+ }
+}
+
+// GenerateTypePopulateProperty errors
+
+TEST(JsonSchemaCompilerErrorTest, TypeIsRequired) {
+ {
+ scoped_ptr<DictionaryValue> value = Dictionary(
+ "integers", new FundamentalValue(5));
+ EXPECT_TRUE(ChoiceType::Populate(*value, new ChoiceType()));
+ }
+ {
+ scoped_ptr<base::DictionaryValue> bad_value(new base::DictionaryValue());
+ std::string error;
+ EXPECT_FALSE(ChoiceType::Populate(*bad_value, new ChoiceType(), &error));
+ EXPECT_EQ(error, "'integers' is required");
+ }
+}
+
+// GenerateParamsCheck errors
+
+TEST(JsonSchemaCompilerErrorTest, TooManyParameters) {
+ {
+ scoped_ptr<base::ListValue> params_value = List(
+ new FundamentalValue(5));
+ EXPECT_TRUE(TestFunction::Params::Create(*params_value));
+ }
+ {
+ scoped_ptr<base::ListValue> params_value = List(
+ new FundamentalValue(5),
+ new FundamentalValue(5));
+ std::string error;
+ EXPECT_FALSE(TestFunction::Params::Create(*params_value, &error));
+ EXPECT_EQ(error, "expected 1 arguments, got 2");
+ }
+}
+
+// GenerateFunctionParamsCreate errors
+
+TEST(JsonSchemaCompilerErrorTest, ParamIsRequired) {
+ {
+ scoped_ptr<base::ListValue> params_value = List(
+ new FundamentalValue(5));
+ EXPECT_TRUE(TestFunction::Params::Create(*params_value));
+ }
+ {
+ scoped_ptr<base::ListValue> params_value = List(
+ Value::CreateNullValue());
+ std::string error;
+ EXPECT_FALSE(TestFunction::Params::Create(*params_value, &error));
+ EXPECT_EQ(error, "'num' is required");
+ }
+}
+
+// GeneratePopulateVariableFromValue errors
+
+TEST(JsonSchemaCompilerErrorTest, WrongPropertyValueType) {
+ {
+ scoped_ptr<DictionaryValue> value = Dictionary(
+ "string", new StringValue("yes");
+ EXPECT_TRUE(TestType::Populate(*value, new TestType()));
+ }
+ {
+ scoped_ptr<DictionaryValue> value = Dictionary(
+ "string", new FundamentalValue(1.1));
+ std::string error;
+ EXPECT_FALSE(TestType::Populate(*value, new TestType(), &error));
+ EXPECT_EQ(error, "'string': expected std::string, got number");
not at google - send to devlin 2013/08/09 18:20:58 s/std::string/string/
dhnishi (use Chromium) 2013/08/09 20:50:48 Done. Using the underlying_type now, rather than t
not at google - send to devlin 2013/08/09 21:13:01 Yeah these errors are for displaying to extension
+ }
+}
+
+TEST(JsonSchemaCompilerErrorTest, WrongParameterCreationType) {
+ {
+ scoped_ptr<base::ListValue> params_value = List(
+ new StringValue("Yeah!"));
+ EXPECT_TRUE(TestString::Params::Create(*params_value));
+ }
+ {
+ scoped_ptr<base::ListValue> params_value = List(
+ new FundamentalValue(5));
+ std::string error;
+ EXPECT_FALSE(TestTypeInObject::Params::Create(*params_value, &error));
+ EXPECT_EQ(error,
+ "'paramObject': expected dictionary, got integer");
+ }
+}
+
+TEST(JsonSchemaCompilerErrorTest, WrongTypeValueType) {
+ {
+ scoped_ptr<base::DictionaryValue> value(new base::DictionaryValue());
+ EXPECT_TRUE(ObjectType::Populate(*value, new ObjectType()));
+ }
+ {
+ scoped_ptr<DictionaryValue> value = Dictionary(
+ "otherType", new FundamentalValue(1.1));
+ std::string error;
+ EXPECT_FALSE(ObjectType::Populate(*value, new ObjectType(), &error));
+ EXPECT_EQ(error,
+ "'otherType': expected dictionary, got number");
+ }
+}
+
+TEST(JsonSchemaCompilerErrorTest, UnableToPopulateArray) {
+ {
+ scoped_ptr<base::ListValue> params_value = List(
+ new FundamentalValue(5));
+ EXPECT_TRUE(ChoiceType::Integers::Populate(*params_value,
+ new ChoiceType::Integers()));
+ }
+ {
+ scoped_ptr<base::ListValue> params_value = List(
+ new FundamentalValue(5),
+ new FundamentalValue(false));
+ std::string error;
+ EXPECT_FALSE(ChoiceType::Integers::Populate(*params_value,
+ new ChoiceType::Integers(),
+ &error));
+ EXPECT_EQ(error, "unable to populate array 'integers'");
+ }
+}
+
+TEST(JsonSchemaCompilerErrorTest, BinaryTypeExpected) {
+ {
+ scoped_ptr<DictionaryValue> value = Dictionary(
+ "data", new base::BinaryValue());
+ EXPECT_TRUE(BinaryData::Populate(*value,
+ new BinaryData()));
+ }
+ {
+ scoped_ptr<DictionaryValue> value = Dictionary(
+ "data", new FundamentalValue(1.1));
+ std::string error;
+ EXPECT_FALSE(BinaryData::Populate(*value, new BinaryData(), &error));
+ EXPECT_EQ(error, "'data': expected binary, got number");
+ }
+}
+
+// GenerateStringToEnumConversion errors
+
+TEST(JsonSchemaCompilerErrorTest, BadEnumValue) {
+ {
+ scoped_ptr<DictionaryValue> value = Dictionary(
+ "enumeration", new StringValue("one"));
+ EXPECT_TRUE(HasEnumeration::Populate(*value,
+ new HasEnumeration()));
+ }
+ {
+ scoped_ptr<DictionaryValue> value = Dictionary(
+ "enumeration", new StringValue("bad sauce"));
+ std::string error;
+ EXPECT_FALSE(HasEnumeration::Populate(*value,
+ new HasEnumeration(),
+ &error));
+ EXPECT_EQ(error,
+ "'enumeration': expected \"one\" or \"two\" or \"three\", "
+ "got \"bad sauce\"");
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698