diff options
Diffstat (limited to 'src/test/java/com/networknt/schema/Issue650Test.java')
-rw-r--r-- | src/test/java/com/networknt/schema/Issue650Test.java | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/src/test/java/com/networknt/schema/Issue650Test.java b/src/test/java/com/networknt/schema/Issue650Test.java new file mode 100644 index 0000000..02bffbf --- /dev/null +++ b/src/test/java/com/networknt/schema/Issue650Test.java @@ -0,0 +1,83 @@ +package com.networknt.schema; + +import java.io.InputStream; +import java.util.Set; +import org.junit.jupiter.api.Assertions; +import org.junit.jupiter.api.Test; +import com.fasterxml.jackson.annotation.JsonInclude; +import com.fasterxml.jackson.databind.DeserializationFeature; +import com.fasterxml.jackson.databind.JsonNode; +import com.fasterxml.jackson.databind.ObjectMapper; +import com.fasterxml.jackson.databind.SerializationFeature; +import com.fasterxml.jackson.databind.node.BinaryNode; + +/** + * + * created at 07.02.2023 + * + * @author k-oliver + * @since 1.0.77 + */ +public class Issue650Test { + + /** + * Test using a Java model with a byte[] property which jackson converts to a BASE64 encoded string automatically. Then convert into + * a jackson tree. The resulting node is of type {@link BinaryNode}. This test checks if validation handles the {@link BinaryNode} as string + * when validating. + * + * @throws Exception + * @since 1.0.77 + */ + @Test + public void testBinaryNode() throws Exception { + final ObjectMapper mapper = new ObjectMapper(); + mapper.setSerializationInclusion(JsonInclude.Include.NON_EMPTY); + mapper.configure(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES, false); + mapper.configure(SerializationFeature.FAIL_ON_EMPTY_BEANS, false); + + // schema with data property of type string: + InputStream schemaInputStream = getClass().getResourceAsStream("/draft7/issue650.json"); + JsonSchema schema = JsonSchemaFactory.getInstance(SpecVersion.VersionFlag.V7).getSchema(schemaInputStream); + + // create model first: + Issue650Test.Model model = new Issue650Test.Model(); + model.setData("content".getBytes("UTF-8")); + // now convert to tree. The resulting type of the data property is BinaryNode now: + JsonNode node = mapper.valueToTree(model); + + // validate: + Set<ValidationMessage> errors = schema.validate(node); + + // check result: + Assertions.assertTrue(errors.isEmpty()); + } + + /** + * created at 07.02.2023 + * + * @author Oliver Kelling + * @since 1.0.77 + */ + private static class Model { + private byte[] data; + + + /** + * @return the data + * @since 1.0.77 + */ + public byte[] getData() { + return this.data; + } + + + /** + * @param data the data to set + * @since 1.0.77 + */ + public void setData(byte[] data) { + this.data = data; + } + + } +} |