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.