mirror of
https://github.com/tristanpenman/valijson.git
synced 2025-01-19 00:46:03 +01:00
a30ef97465
This patch adds support for a new Cmake option, VALIJSON_USE_EXCEPTIONS. If specified and set to `0`, Valijson will disable all exception throwing, add the `-fno-exceptions` compiler flag, and print to std::err and abort where exceptions would have been thrown. NOTE: to set the value of a CMake option, the easiest way is to modify the appropriate source line in the <build folder>/CMakeCache.txt file. Bug: #106
101 lines
3.4 KiB
C++
101 lines
3.4 KiB
C++
#include <iostream>
|
|
|
|
#include <gtest/gtest.h>
|
|
|
|
#include <valijson/adapters/rapidjson_adapter.hpp>
|
|
#include <valijson/utils/rapidjson_utils.hpp>
|
|
#include <valijson/schema.hpp>
|
|
#include <valijson/schema_parser.hpp>
|
|
#include <valijson/validation_results.hpp>
|
|
#include <valijson/validator.hpp>
|
|
|
|
#define TEST_DATA_DIR "../tests/data"
|
|
|
|
using std::string;
|
|
|
|
using valijson::adapters::AdapterTraits;
|
|
using valijson::adapters::RapidJsonAdapter;
|
|
using valijson::utils::loadDocument;
|
|
using valijson::Schema;
|
|
using valijson::SchemaParser;
|
|
using valijson::Validator;
|
|
using valijson::ValidationResults;
|
|
|
|
class TestValidationErrors : public ::testing::Test
|
|
{
|
|
|
|
};
|
|
|
|
TEST_F(TestValidationErrors, AllOfConstraintFailure)
|
|
{
|
|
// Load schema document
|
|
rapidjson::Document schemaDocument;
|
|
ASSERT_TRUE( loadDocument(TEST_DATA_DIR "/schemas/allof_integers_and_numbers.schema.json", schemaDocument) );
|
|
RapidJsonAdapter schemaAdapter(schemaDocument);
|
|
|
|
// Parse schema document
|
|
Schema schema;
|
|
SchemaParser schemaParser;
|
|
#if VALIJSON_USE_EXCEPTIONS
|
|
ASSERT_NO_THROW(schemaParser.populateSchema(schemaAdapter, schema));
|
|
#else
|
|
schemaParser.populateSchema(schemaAdapter, schema);
|
|
#endif
|
|
|
|
// Load test document
|
|
rapidjson::Document testDocument;
|
|
ASSERT_TRUE( loadDocument(TEST_DATA_DIR "/documents/array_doubles_1_2_3.json", testDocument) );
|
|
RapidJsonAdapter testAdapter(testDocument);
|
|
|
|
Validator validator;
|
|
ValidationResults results;
|
|
EXPECT_FALSE( validator.validate(schema, testAdapter, &results) );
|
|
|
|
ValidationResults::Error error;
|
|
|
|
EXPECT_TRUE( results.popError(error) );
|
|
EXPECT_EQ( size_t(2), error.context.size() );
|
|
EXPECT_EQ( "<root>", error.context[0] );
|
|
EXPECT_EQ( "[0]", error.context[1] );
|
|
EXPECT_EQ( "Value type not permitted by 'type' constraint.", error.description );
|
|
|
|
EXPECT_TRUE( results.popError(error) );
|
|
EXPECT_EQ( size_t(1), error.context.size() );
|
|
EXPECT_EQ( "<root>", error.context[0] );
|
|
EXPECT_EQ( "Failed to validate item #0 in array.", error.description );
|
|
|
|
EXPECT_TRUE( results.popError(error) );
|
|
EXPECT_EQ( size_t(2), error.context.size() );
|
|
EXPECT_EQ( "<root>", error.context[0] );
|
|
EXPECT_EQ( "[1]", error.context[1] );
|
|
EXPECT_EQ( "Value type not permitted by 'type' constraint.", error.description );
|
|
|
|
EXPECT_TRUE( results.popError(error) );
|
|
EXPECT_EQ( size_t(1), error.context.size() );
|
|
EXPECT_EQ( "<root>", error.context[0] );
|
|
EXPECT_EQ( "Failed to validate item #1 in array.", error.description );
|
|
|
|
EXPECT_TRUE( results.popError(error) );
|
|
EXPECT_EQ( size_t(2), error.context.size() );
|
|
EXPECT_EQ( "<root>", error.context[0] );
|
|
EXPECT_EQ( "[2]", error.context[1] );
|
|
EXPECT_EQ( "Value type not permitted by 'type' constraint.", error.description );
|
|
|
|
EXPECT_TRUE( results.popError(error) );
|
|
EXPECT_EQ( size_t(1), error.context.size() );
|
|
EXPECT_EQ( "<root>", error.context[0] );
|
|
EXPECT_EQ( "Failed to validate item #2 in array.", error.description );
|
|
|
|
EXPECT_TRUE( results.popError(error) );
|
|
EXPECT_EQ( size_t(1), error.context.size() );
|
|
EXPECT_EQ( "<root>", error.context[0] );
|
|
EXPECT_EQ( "Failed to validate against child schema #0.", error.description );
|
|
|
|
EXPECT_FALSE( results.popError(error) );
|
|
|
|
while (results.popError(error)) {
|
|
//std::cerr << error.context << std::endl;
|
|
std::cerr << error.description << std::endl;
|
|
}
|
|
}
|