json jmeter jsonschema jmeter-plugins

Cómo validar datos JSON utilizando JSONSchema en jMeter



jmeter-plugins (2)

No existe soporte integrado para validar un objeto JSON contra el esquema, por lo que tendrá que hacer algunas secuencias de comandos como se describe en Validar JSON contra el esquema en el artículo de Java . En caso de que el enlace al que se hace referencia muera, necesitará las siguientes bibliotecas en JMeter Classpath

activation-1.1.jar btf-1.2.jar guava-16.0.1.jar jackson-annotations-2.2.3.jar jackson-core-2.2.3.jar jackson-coreutils-1.8.jar jackson-databind-2.2.3.jar joda-time-2.3.jar jopt-simple-4.6.jar json-schema-core-1.2.5.jar json-schema-validator-2.2.6.jar jsr305-3.0.0.jar libphonenumber-6.2.jar mailapi-1.4.3.jar msg-simple-1.1.jar rhino-1.7R4.jar uri-template-0.9.jar

La manera más rápida y fácil de obtenerlos es crear el archivo pom.xml mínimo como:

<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>foo</groupId> <artifactId>bar</artifactId> <version>1.0-SNAPSHOT</version> <dependencies> <!-- https://mvnrepository.com/artifact/com.github.fge/json-schema-validator --> <dependency> <groupId>com.github.fge</groupId> <artifactId>json-schema-validator</artifactId> <version>2.2.6</version> </dependency> <!-- https://mvnrepository.com/artifact/com.github.fge/jackson-coreutils --> <dependency> <groupId>com.github.fge</groupId> <artifactId>jackson-coreutils</artifactId> <version>1.8</version> </dependency> <!-- https://mvnrepository.com/artifact/com.github.fge/json-schema-core --> <dependency> <groupId>com.github.fge</groupId> <artifactId>json-schema-core</artifactId> <version>1.2.5</version> </dependency> </dependencies> </project>

y ejecuta mvn dependency: copy-dependencies command.

Después de eso, podrás usar algo como:

import java.io.File; import java.io.IOException; import java.net.URL; import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.node.ObjectNode; import com.github.fge.jackson.JsonLoader; import com.github.fge.jsonschema.core.exceptions.ProcessingException; import com.github.fge.jsonschema.core.report.ProcessingMessage; import com.github.fge.jsonschema.core.report.ProcessingReport; import com.github.fge.jsonschema.main.JsonSchema; import com.github.fge.jsonschema.main.JsonSchemaFactory; public class ValidationUtils { public static final String JSON_V4_SCHEMA_IDENTIFIER = "http://json-schema.org/draft-04/schema#"; public static final String JSON_SCHEMA_IDENTIFIER_ELEMENT = "$schema"; public static JsonNode getJsonNode(String jsonText) throws IOException { return JsonLoader.fromString(jsonText); } // getJsonNode(text) ends public static JsonNode getJsonNode(File jsonFile) throws IOException { return JsonLoader.fromFile(jsonFile); } // getJsonNode(File) ends public static JsonNode getJsonNode(URL url) throws IOException { return JsonLoader.fromURL(url); } // getJsonNode(URL) ends public static JsonNode getJsonNodeFromResource(String resource) throws IOException { return JsonLoader.fromResource(resource); } // getJsonNode(Resource) ends public static JsonSchema getSchemaNode(String schemaText) throws IOException, ProcessingException { final JsonNode schemaNode = getJsonNode(schemaText); return _getSchemaNode(schemaNode); } // getSchemaNode(text) ends public static JsonSchema getSchemaNode(File schemaFile) throws IOException, ProcessingException { final JsonNode schemaNode = getJsonNode(schemaFile); return _getSchemaNode(schemaNode); } // getSchemaNode(File) ends public static JsonSchema getSchemaNode(URL schemaFile) throws IOException, ProcessingException { final JsonNode schemaNode = getJsonNode(schemaFile); return _getSchemaNode(schemaNode); } // getSchemaNode(URL) ends public static JsonSchema getSchemaNodeFromResource(String resource) throws IOException, ProcessingException { final JsonNode schemaNode = getJsonNodeFromResource(resource); return _getSchemaNode(schemaNode); } // getSchemaNode() ends public static void validateJson(JsonSchema jsonSchemaNode, JsonNode jsonNode) throws ProcessingException { ProcessingReport report = jsonSchemaNode.validate(jsonNode); if (!report.isSuccess()) { for (ProcessingMessage processingMessage : report) { throw new ProcessingException(processingMessage); } } } // validateJson(Node) ends public static boolean isJsonValid(JsonSchema jsonSchemaNode, JsonNode jsonNode) throws ProcessingException { ProcessingReport report = jsonSchemaNode.validate(jsonNode); return report.isSuccess(); } // validateJson(Node) ends public static boolean isJsonValid(String schemaText, String jsonText) throws ProcessingException, IOException { final JsonSchema schemaNode = getSchemaNode(schemaText); final JsonNode jsonNode = getJsonNode(jsonText); return isJsonValid(schemaNode, jsonNode); } // validateJson(Node) ends public static boolean isJsonValid(File schemaFile, File jsonFile) throws ProcessingException, IOException { final JsonSchema schemaNode = getSchemaNode(schemaFile); final JsonNode jsonNode = getJsonNode(jsonFile); return isJsonValid(schemaNode, jsonNode); } // validateJson(Node) ends public static boolean isJsonValid(URL schemaURL, URL jsonURL) throws ProcessingException, IOException { final JsonSchema schemaNode = getSchemaNode(schemaURL); final JsonNode jsonNode = getJsonNode(jsonURL); return isJsonValid(schemaNode, jsonNode); } // validateJson(Node) ends public static void validateJson(String schemaText, String jsonText) throws IOException, ProcessingException{ final JsonSchema schemaNode = getSchemaNode(schemaText); final JsonNode jsonNode = getJsonNode(jsonText); validateJson(schemaNode, jsonNode); } // validateJson(text) ends public static void validateJson(File schemaFile, File jsonFile) throws IOException, ProcessingException{ final JsonSchema schemaNode = getSchemaNode(schemaFile); final JsonNode jsonNode = getJsonNode(jsonFile); validateJson(schemaNode, jsonNode); } // validateJson(File) ends public static void validateJson(URL schemaDocument, URL jsonDocument) throws IOException, ProcessingException{ final JsonSchema schemaNode = getSchemaNode(schemaDocument); final JsonNode jsonNode = getJsonNode(jsonDocument); validateJson(schemaNode, jsonNode); } // validateJson(URL) ends public static void validateJsonResource(String schemaResource, String jsonResource) throws IOException, ProcessingException{ final JsonSchema schemaNode = getSchemaNode(schemaResource); final JsonNode jsonNode = getJsonNodeFromResource(jsonResource); validateJson(schemaNode, jsonNode); } // validateJsonResource() ends private static JsonSchema _getSchemaNode(JsonNode jsonNode) throws ProcessingException { final JsonNode schemaIdentifier = jsonNode.get(JSON_SCHEMA_IDENTIFIER_ELEMENT); if (null == schemaIdentifier){ ((ObjectNode) jsonNode).put(JSON_SCHEMA_IDENTIFIER_ELEMENT, JSON_V4_SCHEMA_IDENTIFIER); } final JsonSchemaFactory factory = JsonSchemaFactory.byDefault(); return factory.getJsonSchema(jsonNode); } // _getSchemaNode() ends }

en JSR223 Afirmación .

Por mi solicitud, recibo la respuesta json . Entonces, quería usar JSONSchema para la validación estructural y de datos en jMeter .

¿Cómo puedo lograr esto de la mejor manera?
¿Hay algún complemento disponible en jMeter para realizar este tipo de tareas?

Ejemplo :

Respuesta Json es

{ "id": "60D5B6D2-9607-4E23-91D0-14EB5EA806EA", "imp": [ { "id": "1", "tagid": "759926", "banner": { "w": 300, "h": 250, "topframe": 1, "api": [ 5 ] } } ] }

JSONSchema es

{ "$schema": "http://json-schema.org/draft-04/schema#", "type": "object", "properties": { "id": { "type": "string" }, "imp": { "type": "array", "items": { "type": "object", "properties": { "id": { "type": "string" }, "tagid": { "type": "string" }, "banner": { "type": "object", "properties": { "w": { "type": "integer", "minimim": 10, "maximum": 150 }, "h": { "type": "integer", "minimim": 10, "maximum": 150 }, "topframe": { "type": "integer", "minimim": 10, "maximum": 150 }, "api": { "type": "array", "items": { "type": "integer" } } }, "additionalProperties": false, "required": [ "w", "h", "topframe", "api" ] } }, "additionalProperties": false, "required": [ "id", "tagid", "banner" ] } } }, "additionalProperties": false, "required": [ "id", "imp" ] }


prueba el plugin JSON Path Assertion JMeter que te permite realizar validaciones de documentos JSON (como estructura, valores, tipo uno a la vez), pero no para la validación del esquema.

Puede descargar usando JMeter-plugin Manager O

Descargue manualmente el jar, /lib/ext carpeta /lib/ext y reinicie JMeter.

De Docs:

Este componente le permite realizar validaciones de documentos JSON.

Primero, analizará el JSON y fallará si los datos no son JSON.

En segundo lugar, buscará una ruta especificada, utilizando la sintaxis de Jayway JsonPath 1.2.0. Si la ruta no se encuentra, fallará.

En tercer lugar, si se encontró la ruta JSON en el documento y se solicitó la validación contra el valor esperado, se realizará la validación. Para el valor nulo, hay una casilla de verificación especial en la GUI.