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

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: bool function; becomes bool has_function; 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..f63e729bcd5d2ec6302995c3d4a7358ebf35aa6a
--- /dev/null
+++ b/tools/json_schema_compiler/test/functions_as_parameters_unittest.cc
@@ -0,0 +1,98 @@
+// 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 dict_with_boolean;
+ dict_with_boolean.Set("event_callback", Value::CreateBooleanValue(true));
+ FunctionType out;
+ ASSERT_TRUE(FunctionType::Populate(dict_with_boolean, &out));
+ EXPECT_TRUE(out.has_event_callback);
+ }
+ {
+ DictionaryValue dict_with_string;
+ dict_with_string.Set("event_callback", Value::CreateStringValue("string"));
+ FunctionType out;
+ ASSERT_TRUE(FunctionType::Populate(dict_with_string, &out));
+ EXPECT_TRUE(out.has_event_callback);
+ }
+}
+
+TEST(JsonSchemaCompilerFunctionsAsParametersTest, RequiredFunctionToValue) {
+ {
+ DictionaryValue value;
+ value.Set("event_callback", Value::CreateBooleanValue(true));
+
+ FunctionType out;
+ ASSERT_TRUE(FunctionType::Populate(value, &out));
+ EXPECT_TRUE(value.Equals(out.ToValue().get()));
+ }
+ {
+ DictionaryValue value;
+ DictionaryValue expected_value;
+ value.Set("event_callback", Value::CreateBooleanValue(false));
+ expected_value.Set("event_callback", Value::CreateBooleanValue(true));
+
+ 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.has_event_callback);
+ }
+ {
+ DictionaryValue dict_with_boolean;
+ dict_with_boolean.Set("event_callback", Value::CreateBooleanValue(true));
+ OptionalFunctionType out;
+ ASSERT_TRUE(OptionalFunctionType::Populate(dict_with_boolean, &out));
+ EXPECT_TRUE(out.has_event_callback);
+ }
+ {
+ DictionaryValue value;
+ value.Set("event_callback", Value::CreateBooleanValue(false));
+ OptionalFunctionType out;
+ ASSERT_TRUE(OptionalFunctionType::Populate(value, &out));
+ EXPECT_TRUE(out.has_event_callback);
+ }
+}
+
+TEST(JsonSchemaCompilerFunctionsAsParametersTest, OptionalFunctionToValue) {
+ {
+ DictionaryValue empty_value;
+ DictionaryValue expected_value;
+ expected_value.Set("event_callback", Value::CreateBooleanValue(false));
+
+ OptionalFunctionType out;
+ ASSERT_TRUE(OptionalFunctionType::Populate(empty_value, &out));
+ // event_callback should be set to false in the return from ToValue.
+ EXPECT_TRUE(expected_value.Equals(out.ToValue().get()));
+ }
+ {
+ DictionaryValue value;
+ value.Set("event_callback", Value::CreateBooleanValue(true));
+
+ OptionalFunctionType out;
+ ASSERT_TRUE(OptionalFunctionType::Populate(value, &out));
+ EXPECT_TRUE(value.Equals(out.ToValue().get()));
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698