/* * Copyright (c) 2014, Francis Galiegue (fgaliegue@gmail.com) * * This software is dual-licensed under: * * - the Lesser General Public License (LGPL) version 3.0 or, at your option, any * later version; * - the Apache Software License (ASL) version 2.0. * * The text of both licenses is available under the src/resources/ directory of * this project (under the names LGPL-3.0.txt and ASL-2.0.txt respectively). * * Direct link to the sources: * * - LGPL 3.0: https://www.gnu.org/licenses/lgpl-3.0.txt * - ASL 2.0: http://www.apache.org/licenses/LICENSE-2.0.txt */ package com.github.fge.jsonschema.examples; import com.fasterxml.jackson.databind.JsonNode; import com.github.fge.jsonschema.core.exceptions.ProcessingException; import com.github.fge.jsonschema.core.report.ProcessingReport; import com.github.fge.jsonschema.main.JsonSchema; import com.github.fge.jsonschema.main.JsonSchemaFactory; import java.io.IOException; /** * First example: basic usage * *
* *This shows a basic usage example. The schema used for validation is * here, which conforms to draft v4, which is * the default version. You will notice that a JSON Pointer ({@code * #/definitions/mntent}) is used to address a subschema defining a mount entry. *
* *This example uses {@link JsonSchemaFactory#byDefault()}, and uses * {@link JsonSchemaFactory#getJsonSchema(JsonNode)} to create the {@link * JsonSchema} instance.
* *The first sample (here) validates * successfully.
* *The second sample (here) fails to * validate. Please note that the failure occurs at the structural level * (required entry {@code swap} is missing). Validation therefore stops here, * and does not attempt to validate the {@code /} member of the instance, which * is itself invalid.
* *The third sample (here) fails to * validate as well. This time, the problem is with the member values:
* *