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

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

Issue 10824002: JSON Schema Compiler supports functions as PropertyTypes. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Created 8 years, 5 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/functions_as_parameters_unittest.cc
diff --git a/tools/json_schema_compiler/test/functions_as_parameters_unittest.cc b/tools/json_schema_compiler/test/functions_as_parameters_unittest.cc
new file mode 100644
index 0000000000000000000000000000000000000000..f53e434f153bf6a890276438ded4cb4edf939951
--- /dev/null
+++ b/tools/json_schema_compiler/test/functions_as_parameters_unittest.cc
@@ -0,0 +1,94 @@
+// Copyright (c) 2012 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/functions_as_parameters.h"
+
+#include "testing/gtest/include/gtest/gtest.h"
+
+using namespace test::api::functions_as_parameters;
+
+TEST(JsonSchemaCompilerFunctionsAsParametersTest, PopulateRequiredFunction) {
+ // The expectation is that if any value is set for the function, then
+ // the function is "present".
+ {
+ DictionaryValue empty_value;
+ FunctionType out;
+ EXPECT_FALSE(FunctionType::Populate(empty_value, &out));
+ }
+ {
+ DictionaryValue value;
+ DictionaryValue function_dict;
+ value.Set("event_callback", function_dict.DeepCopy());
+ FunctionType out;
+ ASSERT_TRUE(FunctionType::Populate(value, &out));
+ EXPECT_TRUE(out.event_callback.empty());
+ }
+}
+
+TEST(JsonSchemaCompilerFunctionsAsParametersTest, RequiredFunctionToValue) {
+ {
+ DictionaryValue value;
+ DictionaryValue function_dict;
+ value.Set("event_callback", function_dict.DeepCopy());
+
+ FunctionType out;
+ ASSERT_TRUE(FunctionType::Populate(value, &out));
+ EXPECT_TRUE(value.Equals(out.ToValue().get()));
+ }
+ {
+ DictionaryValue value;
+ DictionaryValue expected_value;
+ DictionaryValue function_dict;
+ value.Set("event_callback", function_dict.DeepCopy());
+ expected_value.Set("event_callback", function_dict.DeepCopy());
+
+ FunctionType out;
+ ASSERT_TRUE(FunctionType::Populate(value, &out));
+ EXPECT_TRUE(expected_value.Equals(out.ToValue().get()));
+ }
+}
+
+TEST(JsonSchemaCompilerFunctionsAsParametersTest, PopulateOptionalFunction) {
+ {
+ DictionaryValue empty_value;
+ OptionalFunctionType out;
+ ASSERT_TRUE(OptionalFunctionType::Populate(empty_value, &out));
+ EXPECT_FALSE(out.event_callback.get());
+ }
+ {
+ DictionaryValue value;
+ DictionaryValue function_value;
+ value.Set("event_callback", function_value.DeepCopy());
+ OptionalFunctionType out;
+ ASSERT_TRUE(OptionalFunctionType::Populate(value, &out));
+ EXPECT_TRUE(out.event_callback.get());
+ }
+ {
+ DictionaryValue value;
+ DictionaryValue function_value;
+ value.Set("event_callback", function_value.DeepCopy());
+ OptionalFunctionType out;
+ ASSERT_TRUE(OptionalFunctionType::Populate(value, &out));
+ EXPECT_TRUE(out.event_callback.get());
+ }
+}
+
+TEST(JsonSchemaCompilerFunctionsAsParametersTest, OptionalFunctionToValue) {
+ {
+ DictionaryValue empty_value;
+ OptionalFunctionType out;
+ ASSERT_TRUE(OptionalFunctionType::Populate(empty_value, &out));
+ // event_callback should not be set in the return from ToValue.
+ EXPECT_TRUE(empty_value.Equals(out.ToValue().get()));
+ }
+ {
+ DictionaryValue value;
+ DictionaryValue function_value;
+ value.Set("event_callback", function_value.DeepCopy());
+
+ OptionalFunctionType out;
+ ASSERT_TRUE(OptionalFunctionType::Populate(value, &out));
+ EXPECT_TRUE(value.Equals(out.ToValue().get()));
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698