All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.github.microcks.util.test.TestRunnerCommons Maven / Gradle / Ivy

The newest version!
/*
 * Copyright The Microcks Authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *  http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package io.github.microcks.util.test;

import io.github.microcks.domain.Header;
import io.github.microcks.domain.Parameter;
import io.github.microcks.domain.Request;
import io.github.microcks.util.el.EvaluableRequest;
import io.github.microcks.util.el.TemplateEngine;
import io.github.microcks.util.el.TemplateEngineFactory;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

/**
 * This class holds commons, utility handlers for different test runner implements (whether it be Soap, OpenAPI,
 * Async...)
 * @author laurent
 */
public class TestRunnerCommons {

   /** A simple logger for diagnostic messages. */
   private static Logger log = LoggerFactory.getLogger(TestRunnerCommons.class);

   /**
    * Render the request content using the Expression Language compatible {@code TemplateEngine} if required. If
    * rendering template fails, we just produce a log error message and stick to templatized content.
    * @param request The request that will be sent for test.
    * @param headers The set of computed headers to use for request body evaluation
    * @return The rendered response body payload.
    */
   public static String renderRequestContent(Request request, Set
headers) { if (request.getContent().contains(TemplateEngine.DEFAULT_EXPRESSION_PREFIX)) { log.debug("Response contains dynamic EL expression, rendering it..."); TemplateEngine engine = TemplateEngineFactory.getTemplateEngine(); // Create and fill an evaluable request object. EvaluableRequest evaluableRequest = new EvaluableRequest(request.getContent(), null); // Adding query parameters... Map evaluableParams = new HashMap<>(); for (Parameter parameter : request.getQueryParameters()) { evaluableParams.put(parameter.getName(), parameter.getValue()); } evaluableRequest.setParams(evaluableParams); // Adding headers... Map evaluableHeaders = new HashMap<>(); for (Header header : request.getHeaders()) { evaluableHeaders.put(header.getName(), String.join(",", header.getValues())); } evaluableRequest.setHeaders(evaluableHeaders); // Register the request variable and evaluate the request body. engine.getContext().setVariable("request", evaluableRequest); try { return engine.getValue(request.getContent()); } catch (Throwable t) { log.error("Failing at evaluating template " + request.getContent(), t); return request.getContent(); } } return request.getContent(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy