Merge pull request #1279 from bogaotory/master
Avoid `MissingProperty` Error from `SchemaValidator` when a none-zero length value is given as `default` for the property
This commit is contained in:
commit
c0daf75475
@ -440,7 +440,8 @@ public:
|
|||||||
minLength_(0),
|
minLength_(0),
|
||||||
maxLength_(~SizeType(0)),
|
maxLength_(~SizeType(0)),
|
||||||
exclusiveMinimum_(false),
|
exclusiveMinimum_(false),
|
||||||
exclusiveMaximum_(false)
|
exclusiveMaximum_(false),
|
||||||
|
defaultValueLength_(0)
|
||||||
{
|
{
|
||||||
typedef typename SchemaDocumentType::ValueType ValueType;
|
typedef typename SchemaDocumentType::ValueType ValueType;
|
||||||
typedef typename ValueType::ConstValueIterator ConstValueIterator;
|
typedef typename ValueType::ConstValueIterator ConstValueIterator;
|
||||||
@ -635,6 +636,12 @@ public:
|
|||||||
if (const ValueType* v = GetMember(value, GetMultipleOfString()))
|
if (const ValueType* v = GetMember(value, GetMultipleOfString()))
|
||||||
if (v->IsNumber() && v->GetDouble() > 0.0)
|
if (v->IsNumber() && v->GetDouble() > 0.0)
|
||||||
multipleOf_.CopyFrom(*v, *allocator_);
|
multipleOf_.CopyFrom(*v, *allocator_);
|
||||||
|
|
||||||
|
// Default
|
||||||
|
if (const ValueType* v = GetMember(value, GetDefaultValueString()))
|
||||||
|
if (v->IsString())
|
||||||
|
defaultValueLength_ = v->GetStringLength();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
~Schema() {
|
~Schema() {
|
||||||
@ -936,6 +943,7 @@ public:
|
|||||||
context.error_handler.StartMissingProperties();
|
context.error_handler.StartMissingProperties();
|
||||||
for (SizeType index = 0; index < propertyCount_; index++)
|
for (SizeType index = 0; index < propertyCount_; index++)
|
||||||
if (properties_[index].required && !context.propertyExist[index])
|
if (properties_[index].required && !context.propertyExist[index])
|
||||||
|
if (properties_[index].schema->defaultValueLength_ == 0 )
|
||||||
context.error_handler.AddMissingProperty(properties_[index].name);
|
context.error_handler.AddMissingProperty(properties_[index].name);
|
||||||
if (context.error_handler.EndMissingProperties())
|
if (context.error_handler.EndMissingProperties())
|
||||||
RAPIDJSON_INVALID_KEYWORD_RETURN(GetRequiredString());
|
RAPIDJSON_INVALID_KEYWORD_RETURN(GetRequiredString());
|
||||||
@ -1046,6 +1054,7 @@ public:
|
|||||||
RAPIDJSON_STRING_(ExclusiveMinimum, 'e', 'x', 'c', 'l', 'u', 's', 'i', 'v', 'e', 'M', 'i', 'n', 'i', 'm', 'u', 'm')
|
RAPIDJSON_STRING_(ExclusiveMinimum, 'e', 'x', 'c', 'l', 'u', 's', 'i', 'v', 'e', 'M', 'i', 'n', 'i', 'm', 'u', 'm')
|
||||||
RAPIDJSON_STRING_(ExclusiveMaximum, 'e', 'x', 'c', 'l', 'u', 's', 'i', 'v', 'e', 'M', 'a', 'x', 'i', 'm', 'u', 'm')
|
RAPIDJSON_STRING_(ExclusiveMaximum, 'e', 'x', 'c', 'l', 'u', 's', 'i', 'v', 'e', 'M', 'a', 'x', 'i', 'm', 'u', 'm')
|
||||||
RAPIDJSON_STRING_(MultipleOf, 'm', 'u', 'l', 't', 'i', 'p', 'l', 'e', 'O', 'f')
|
RAPIDJSON_STRING_(MultipleOf, 'm', 'u', 'l', 't', 'i', 'p', 'l', 'e', 'O', 'f')
|
||||||
|
RAPIDJSON_STRING_(DefaultValue, 'd', 'e', 'f', 'a', 'u', 'l', 't')
|
||||||
|
|
||||||
#undef RAPIDJSON_STRING_
|
#undef RAPIDJSON_STRING_
|
||||||
|
|
||||||
@ -1426,6 +1435,8 @@ private:
|
|||||||
SValue multipleOf_;
|
SValue multipleOf_;
|
||||||
bool exclusiveMinimum_;
|
bool exclusiveMinimum_;
|
||||||
bool exclusiveMaximum_;
|
bool exclusiveMaximum_;
|
||||||
|
|
||||||
|
SizeType defaultValueLength_;
|
||||||
};
|
};
|
||||||
|
|
||||||
template<typename Stack, typename Ch>
|
template<typename Stack, typename Ch>
|
||||||
|
@ -1049,6 +1049,33 @@ TEST(SchemaValidator, Object_Required) {
|
|||||||
"}}");
|
"}}");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(SchemaValidator, Object_Required_PassWithDefault) {
|
||||||
|
Document sd;
|
||||||
|
sd.Parse(
|
||||||
|
"{"
|
||||||
|
" \"type\": \"object\","
|
||||||
|
" \"properties\" : {"
|
||||||
|
" \"name\": { \"type\": \"string\", \"default\": \"William Shakespeare\" },"
|
||||||
|
" \"email\" : { \"type\": \"string\", \"default\": \"\" },"
|
||||||
|
" \"address\" : { \"type\": \"string\" },"
|
||||||
|
" \"telephone\" : { \"type\": \"string\" }"
|
||||||
|
" },"
|
||||||
|
" \"required\":[\"name\", \"email\"]"
|
||||||
|
"}");
|
||||||
|
SchemaDocument s(sd);
|
||||||
|
|
||||||
|
VALIDATE(s, "{ \"email\" : \"bill@stratford-upon-avon.co.uk\", \"address\" : \"Henley Street, Stratford-upon-Avon, Warwickshire, England\", \"authorship\" : \"in question\"}", true);
|
||||||
|
INVALIDATE(s, "{ \"name\": \"William Shakespeare\", \"address\" : \"Henley Street, Stratford-upon-Avon, Warwickshire, England\" }", "", "required", "",
|
||||||
|
"{ \"required\": {"
|
||||||
|
" \"instanceRef\": \"#\", \"schemaRef\": \"#\","
|
||||||
|
" \"missing\": [\"email\"]"
|
||||||
|
"}}");
|
||||||
|
INVALIDATE(s, "{}", "", "required", "",
|
||||||
|
"{ \"required\": {"
|
||||||
|
" \"instanceRef\": \"#\", \"schemaRef\": \"#\","
|
||||||
|
" \"missing\": [\"email\"]"
|
||||||
|
"}}");
|
||||||
|
}
|
||||||
|
|
||||||
TEST(SchemaValidator, Object_PropertiesRange) {
|
TEST(SchemaValidator, Object_PropertiesRange) {
|
||||||
Document sd;
|
Document sd;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user