diff --git a/CHANGELOG.md b/CHANGELOG.md index 743055d..74da5ce 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,6 @@ +# 0.2.8 (20/08/2016) +- Bug fixes + # 0.2.8 (29/07/2016) - Added request routing feature diff --git a/README.md b/README.md index fadd76e..261fb4b 100644 --- a/README.md +++ b/README.md @@ -14,7 +14,7 @@ WSSimulator is an open source library that easily allows for you to simulate ext **Getting Started** * Java 8 -* The dependency from JCenter or the Standalone [distro](https://github.com/CognitiveJ/wssimulator/releases/download/0.2.8/wssimulator-0.2.8.zip "Download Standalone Version") +* The dependency from JCenter or the Standalone [distro](https://github.com/CognitiveJ/wssimulator/releases/download/0.2.9/wssimulator-0.2.9.zip "Download Standalone Version") To simulate web service calls, you first need to describe the simulation. This process is very easy as Simulations are created in a YAML format and you don't need to 'simulate' much to get start as the only required field for you to define is _path_ and WSSimulator will default the other options. @@ -54,7 +54,7 @@ There are 2 ways to use WSSimulator; as a standalone application or as an embedd WSSimulator is packaged here and supports been executed on both *nix & windows systems; * For *nix systems - - Unizip the ws-simulator-0.2.8.zip file to a local directory + - Unizip the ws-simulator-0.2.9.zip file to a local directory - Then Call: ```shell @@ -62,7 +62,7 @@ WSSimulator is packaged here and supports been executed on both *nix & windows s ``` * For Windows - - Unizip the ws-simulator-0.2.8.zip file to a local directory + - Unizip the ws-simulator-0.2.9.zip file to a local directory - Then Call: ```shell ./wssimulator.bat @@ -96,7 +96,7 @@ repositories { } dependencies { - compile "cognitivej:wssimulator:0.2.8" + compile "cognitivej:wssimulator:0.2.9" ... } @@ -107,7 +107,7 @@ repositories { cognitivej wssimulator - 0.2.8 + 0.2.9 pom ``` diff --git a/src/main/java/wssimulator/WSSimulator.java b/src/main/java/wssimulator/WSSimulator.java index da6f19b..18a90cd 100644 --- a/src/main/java/wssimulator/WSSimulator.java +++ b/src/main/java/wssimulator/WSSimulator.java @@ -226,6 +226,7 @@ public final class WSSimulator { * @param yamlString YAML as a String */ public static void addSimulation(@NotNull String yamlString) { + LOG.info("adding simulation string: {}", yamlString); YamlToSimulation yamlToSimulation = new YamlToSimulation(yamlString); wsSimulatorServiceManager.add(yamlToSimulation.simulatorSimulation()); } @@ -237,6 +238,7 @@ public static void addSimulation(@NotNull String yamlString) { * @param classpathLocation YAML location on classpath */ public static void addSimulationOnClasspath(@NotNull String classpathLocation) { + LOG.info("adding simulation on classpath: {}", classpathLocation); YamlToSimulation yamlToSimulation = new YamlToSimulation(new File(WSSimulator.class.getResource(classpathLocation).getFile())); wsSimulatorServiceManager.add(yamlToSimulation.simulatorSimulation()); } @@ -259,6 +261,7 @@ public static int addSimulation(@NotNull WSSimulation WSSimulation) { * @return the id of this simulation */ public static int addSimulation(@NotNull File echoSimulationAsYaml) { + LOG.info("adding simulation file: {}", echoSimulationAsYaml); YamlToSimulation yamlToSimulation = new YamlToSimulation(echoSimulationAsYaml); return addSimulation(yamlToSimulation.simulatorSimulation()); } @@ -267,6 +270,7 @@ public static int addSimulation(@NotNull File echoSimulationAsYaml) { * Shuts down the simulator */ public static void shutdown() { + LOG.info("Shutting down server"); wsSimulatorServiceManager.shutdown(); } @@ -276,6 +280,7 @@ public static void shutdown() { * @param port the port number */ public static void setPort(int port) { + LOG.info("setting port to {}", port); Spark.port(port); } diff --git a/src/main/java/wssimulator/WSSimulatorServiceManager.java b/src/main/java/wssimulator/WSSimulatorServiceManager.java index 4d8a62b..64ece76 100644 --- a/src/main/java/wssimulator/WSSimulatorServiceManager.java +++ b/src/main/java/wssimulator/WSSimulatorServiceManager.java @@ -218,6 +218,7 @@ import java.util.HashMap; import java.util.List; import java.util.Map; +import java.util.concurrent.locks.ReentrantLock; import static spark.Spark.*; @@ -227,6 +228,7 @@ public class WSSimulatorServiceManager { private int counter = 0; private Map handlers = new HashMap<>(); + private Map validSimulations = new HashMap<>(); private static final org.slf4j.Logger LOG = org.slf4j.LoggerFactory.getLogger(WSSimulatorServiceManager.class); @@ -268,7 +270,7 @@ private static WSSimulatorServiceManager startup() { return new WSSimulatorServiceManager(); } - private Map validSimulations = new HashMap<>(); + /** * Adds and starts a web service simulator simulation @@ -340,9 +342,10 @@ else if ("application/json".equals(wsSimulation.consumes)) * Shuts down the simulator. */ public void shutdown() { - LOG.info("Shutting down server"); Spark.stop(); validSimulations.clear(); + handlers.clear(); + counter=0; } /** diff --git a/src/main/resources/wssimulator-version.txt b/src/main/resources/wssimulator-version.txt index 08456a4..d81f1c3 100644 --- a/src/main/resources/wssimulator-version.txt +++ b/src/main/resources/wssimulator-version.txt @@ -1 +1 @@ -0.2.8 \ No newline at end of file +0.2.9 \ No newline at end of file diff --git a/src/test/groovy/wssimulator/RouteFilterSimulationSpecification.groovy b/src/test/groovy/wssimulator/RouteFilterSimulationSpecification.groovy index 109e56f..53f37d5 100644 --- a/src/test/groovy/wssimulator/RouteFilterSimulationSpecification.groovy +++ b/src/test/groovy/wssimulator/RouteFilterSimulationSpecification.groovy @@ -206,42 +206,54 @@ package wssimulator import io.restassured.http.ContentType +import org.slf4j.Logger import spock.lang.Specification import static io.restassured.RestAssured.given import static org.hamcrest.core.IsEqual.equalTo +import static org.slf4j.LoggerFactory.* /** * Tests reading all yaml files for XML files. */ class RouteFilterSimulationSpecification extends Specification { + private static final Logger LOG = getLogger(RouteFilterSimulationSpecification.class); def "Validate the route filter feature"() { setup: + LOG.info("Validate the route filter feature:setup") int port = TestUtils.randomPort() - when: WSSimulator.setPort(port) + when: WSSimulator.addSimulation(new File(getClass().getResource("/route/route1.yml").toURI())) WSSimulator.addSimulation(new File(getClass().getResource("/route/route2.yml").toURI())) WSSimulator.addSimulation(new File(getClass().getResource("/route/route3.yml").toURI())) then: + LOG.info("Validate the route filter feature:then") + given().port(port) .contentType(ContentType.XML) .body("This is just random test with Action1 contained within it") .post("/publish").then().assertThat() .statusCode(200).and().body(equalTo("FilteredByAction1")) + LOG.info("Validate the route filter feature:then-1") + given().port(port) .contentType(ContentType.XML) .body("This is just random test with Action2 contained within it") .post("/publish").then().assertThat() .statusCode(200).and().body(equalTo("FilteredByAction2")) + LOG.info("Validate the route filter feature:then-2") + given().port(port) .contentType(ContentType.XML) .body("This is just random test with Action3 contained within it") .post("/publish").then().assertThat() .statusCode(200).and().body(equalTo("FilteredByAction3")) + LOG.info("Validate the route filter feature:end") cleanup: + LOG.info("Validate the route filter feature:cleanup") WSSimulator.shutdown() } diff --git a/src/test/groovy/wssimulator/SOAPTestSpecification.groovy b/src/test/groovy/wssimulator/SOAPTestSpecification.groovy index 7c372e3..258ddcb 100644 --- a/src/test/groovy/wssimulator/SOAPTestSpecification.groovy +++ b/src/test/groovy/wssimulator/SOAPTestSpecification.groovy @@ -226,10 +226,7 @@ class SOAPTestSpecification extends Specification { .body(new File(getClass().getResource("/soap/payload.xml").toURI())) .post("/CurrencyConvertor.asmx").then().assertThat() .statusCode(200) - println "THEN FINISHED!!" cleanup: - println "CLEANUP STARTEE!!" - WSSimulator.shutdown() }