[Lada-commits] [PATCH 1 of 3] Added test for zusatzwert service
Wald Commits
scm-commit at wald.intevation.org
Wed Feb 18 14:42:00 CET 2015
# HG changeset patch
# User Raimund Renkert <raimund.renkert at intevation.de>
# Date 1424266941 -3600
# Node ID 4adca0e92d989e39afcf4035d05c65011acf79af
# Parent c1b0f421748873c889f6ec27e08d5f45084e1471
Added test for zusatzwert service.
diff -r c1b0f4217488 -r 4adca0e92d98 src/test/java/de/intevation/lada/LadaTest.java
--- a/src/test/java/de/intevation/lada/LadaTest.java Wed Feb 18 13:57:20 2015 +0100
+++ b/src/test/java/de/intevation/lada/LadaTest.java Wed Feb 18 14:42:21 2015 +0100
@@ -34,6 +34,7 @@
import de.intevation.lada.test.Probe;
import de.intevation.lada.test.Query;
import de.intevation.lada.test.Status;
+import de.intevation.lada.test.Zusatzwert;
/**
@@ -59,6 +60,7 @@
private Messwert messwertTest;
private Ort ortTest;
private Status statusTest;
+ private Zusatzwert zusatzwertTest;
private static List<Protocol> testProtocol;
@@ -71,6 +73,7 @@
messwertTest = new Messwert();
ortTest = new Ort();
statusTest = new Status();
+ zusatzwertTest = new Zusatzwert();
testProtocol = new ArrayList<Protocol>();
}
@@ -319,6 +322,35 @@
}
/**
+ * Testing GET Services.
+ */
+ @Test
+ @RunAsClient
+ public final void testA_ZusatzwertGetAllServices(@ArquillianResource URL baseUrl)
+ throws Exception {
+ this.zusatzwertTest.getAllService(baseUrl, testProtocol);
+ }
+
+ /**
+ * Testing GET Services.
+ */
+ @Test
+ @RunAsClient
+ public final void testA_ZusatzwertGetByIdServices(@ArquillianResource URL baseUrl)
+ throws Exception {
+ this.zusatzwertTest.getByIdService(baseUrl, testProtocol);
+ }
+
+ /**
+ * Testing GET Services.
+ */
+ @Test
+ @RunAsClient
+ public final void testA_ZusatzwertGetFilterServices(@ArquillianResource URL baseUrl)
+ throws Exception {
+ this.zusatzwertTest.filterService(baseUrl, testProtocol);
+ }
+ /**
* Testing CREATE services.
*/
@Test
@@ -339,6 +371,10 @@
baseUrl,
testProtocol,
this.probeTest.getCreatedProbeId());
+ this.zusatzwertTest.createService(
+ baseUrl,
+ testProtocol,
+ this.probeTest.getCreatedProbeId());
Assert.assertNotNull(this.messungTest.getCreatedMessungId());
this.kommentarMTest.createService(
baseUrl,
@@ -438,6 +474,8 @@
@RunAsClient
public final void testD_DeleteServices(@ArquillianResource URL baseUrl)
throws Exception {
+ Assert.assertNotNull(this.zusatzwertTest.getCreatedId());
+ this.zusatzwertTest.deleteService(baseUrl, testProtocol);
Assert.assertNotNull(this.statusTest.getCreatedId());
this.statusTest.deleteService(baseUrl, testProtocol);
Assert.assertNotNull(this.ortTest.getCreatedId());
diff -r c1b0f4217488 -r 4adca0e92d98 src/test/java/de/intevation/lada/test/Zusatzwert.java
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/src/test/java/de/intevation/lada/test/Zusatzwert.java Wed Feb 18 14:42:21 2015 +0100
@@ -0,0 +1,319 @@
+/* Copyright (C) 2013 by Bundesamt fuer Strahlenschutz
+ * Software engineering by Intevation GmbH
+ *
+ * This file is Free Software under the GNU GPL (v>=3)
+ * and comes with ABSOLUTELY NO WARRANTY! Check out
+ * the documentation coming with IMIS-Labordaten-Application for details.
+ */
+package de.intevation.lada.test;
+
+import java.io.StringReader;
+import java.net.URL;
+import java.util.List;
+
+import javax.json.Json;
+import javax.json.JsonException;
+import javax.json.JsonObject;
+import javax.json.JsonReader;
+import javax.ws.rs.client.Client;
+import javax.ws.rs.client.ClientBuilder;
+import javax.ws.rs.client.Entity;
+import javax.ws.rs.client.WebTarget;
+import javax.ws.rs.core.MediaType;
+import javax.ws.rs.core.Response;
+
+import org.junit.Assert;
+
+import de.intevation.lada.Protocol;
+
+/**
+ * Class containing test cases for zusatzwert objects.
+ *
+ * @author <a href="mailto:rrenkert at intevation.de">Raimund Renkert</a>
+ */
+public class Zusatzwert {
+
+ private static final String COMPARE =
+ "{\"id\":1,\"letzteAenderung\":1335177176000,\"messfehler\":48.0," +
+ "\"messwertPzs\":7.5,\"nwgZuMesswert\":null,\"probeId\":84," +
+ "\"pzsId\":\"A76\"}";
+
+ private static final String CREATE =
+ "{\"letzteAenderung\":1335177176000,\"messfehler\":18.0," +
+ "\"messwertPzs\":3.5,\"nwgZuMesswert\":null,\"probeId\":PID," +
+ "\"pzsId\":\"A76\"}";
+
+ private List<Protocol> protocol;
+
+ private static Integer createdId;
+
+ public Integer getCreatedId() {
+ return createdId;
+ }
+
+ /**
+ * @return The test protocol
+ */
+ public List<Protocol> getProtocol() {
+ return protocol;
+ }
+
+ /**
+ * Test the GET Service by requesting all objects.
+ *
+ * @param baseUrl The url pointing to the test deployment.
+ */
+ public final void getAllService(URL baseUrl, List<Protocol> protocol)
+ throws Exception {
+ System.out.print(".");
+ Protocol prot = new Protocol();
+ prot.setName("ZusatzwertService");
+ prot.setType("get all");
+ prot.setPassed(false);
+ protocol.add(prot);
+ /* Create a client*/
+ Client client = ClientBuilder.newClient();
+ WebTarget target = client.target(baseUrl + "zusatzwert");
+ /* Request all objects*/
+ Response response = target.request().get();
+ String entity = response.readEntity(String.class);
+ try{
+ /* Try to parse the response*/
+ JsonReader reader = Json.createReader(new StringReader(entity));
+ JsonObject content = reader.readObject();
+ /* Verify the response*/
+ Assert.assertTrue(content.getBoolean("success"));
+ prot.addInfo("success", content.getBoolean("success"));
+ Assert.assertEquals("200", content.getString("message"));
+ prot.addInfo("message", content.getString("message"));
+ Assert.assertNotNull(content.getJsonArray("data"));
+ prot.addInfo("objects", content.getJsonArray("data").size());
+ }
+ catch(JsonException je) {
+ prot.addInfo("exception", je.getMessage());
+ Assert.fail(je.getMessage());
+ }
+ prot.setPassed(true);
+ }
+
+ /**
+ * Test the GET Service by requesting a single object by id.
+ *
+ * @param baseUrl The url pointing to the test deployment.
+ */
+ public final void getByIdService(URL baseUrl, List<Protocol> protocol)
+ throws Exception {
+ System.out.print(".");
+ Protocol prot = new Protocol();
+ prot.setName("ZusatzwertService");
+ prot.setType("get by Id");
+ prot.setPassed(false);
+ protocol.add(prot);
+ try {
+ /* Create a json object from static string*/
+ JsonReader fromStringRreader =
+ Json.createReader(new StringReader(COMPARE));
+ JsonObject staticMessung = fromStringRreader.readObject();
+ /* Create a client*/
+ Client client = ClientBuilder.newClient();
+ WebTarget target = client.target(baseUrl + "zusatzwert/1");
+ prot.addInfo("zustzwertId", 1);
+ /* Request a object by id*/
+ Response response = target.request().get();
+ String entity = response.readEntity(String.class);
+ /* Try to parse the response*/
+ JsonReader fromServiceReader =
+ Json.createReader(new StringReader(entity));
+ JsonObject content = fromServiceReader.readObject();
+ /* Verify the response*/
+ Assert.assertTrue(content.getBoolean("success"));
+ prot.addInfo("success", content.getBoolean("success"));
+ Assert.assertEquals("200", content.getString("message"));
+ prot.addInfo("message", content.getString("message"));
+ Assert.assertEquals(staticMessung,
+ content.getJsonObject("data"));
+ prot.addInfo("object", "equals");
+ }
+ catch(JsonException je) {
+ prot.addInfo("exception", je.getMessage());
+ Assert.fail(je.getMessage());
+ }
+ prot.setPassed(true);
+ }
+
+ /**
+ * Test the GET service using filters.
+ *
+ * @param baseUrl The url poining to the test deployment.
+ */
+ public final void filterService(URL baseUrl, List<Protocol> protocol) {
+ System.out.print(".");
+ Protocol prot = new Protocol();
+ prot.setName("ZusatzwertService");
+ prot.setType("get by filter");
+ prot.setPassed(false);
+ protocol.add(prot);
+ try {
+ /* Create a client*/
+ Client client = ClientBuilder.newClient();
+ WebTarget target =
+ client.target(baseUrl + "zusatzwert?probeIdId=1");
+ prot.addInfo("filter", "probeId=1");
+ /* Request the objects using the filter*/
+ Response response = target.request().get();
+ String entity = response.readEntity(String.class);
+ /* Try to parse the response*/
+ JsonReader reader = Json.createReader(new StringReader(entity));
+ JsonObject respObj = reader.readObject();
+ /* Verify the response*/
+ Assert.assertTrue(respObj.getBoolean("success"));
+ prot.addInfo("success", respObj.getBoolean("success"));
+ Assert.assertEquals("200", respObj.getString("message"));
+ prot.addInfo("message", respObj.getString("message"));
+ Assert.assertNotNull(respObj.getJsonArray("data"));
+ prot.addInfo("objects", respObj.getJsonArray("data").size());
+ }
+ catch(JsonException je) {
+ prot.addInfo("exception", je.getMessage());
+ Assert.fail(je.getMessage());
+ }
+ prot.setPassed(true);
+ }
+
+ /**
+ * Test the CREATE Service.
+ *
+ * @param baseUrl The url pointing to the test deployment.
+ */
+ public final void createService(
+ URL baseUrl,
+ List<Protocol> protocol,
+ Integer probeId)
+ throws Exception {
+ System.out.print(".");
+ Protocol prot = new Protocol();
+ prot.setName("ZusatzwertService");
+ prot.setType("create");
+ prot.setPassed(false);
+ protocol.add(prot);
+ try {
+ /* Create a client*/
+ Client client = ClientBuilder.newClient();
+ WebTarget target = client.target(baseUrl + "zusatzwert");
+ /* Send a post request containing a new object*/
+ String zus = CREATE.replace("PID", probeId.toString());
+ Response response = target.request().post(
+ Entity.entity(zus, MediaType.APPLICATION_JSON));
+ String entity = response.readEntity(String.class);
+ /* Try to parse the response*/
+ JsonReader fromServiceReader =
+ Json.createReader(new StringReader(entity));
+ JsonObject content = fromServiceReader.readObject();
+ /* Save the id*/
+ createdId =
+ content.getJsonObject("data").getJsonNumber("id").intValue();
+ prot.addInfo("zusatzwertId", createdId);
+ /* Verify the response*/
+ Assert.assertTrue(content.getBoolean("success"));
+ prot.addInfo("success", content.getBoolean("success"));
+ Assert.assertEquals("200", content.getString("message"));
+ prot.addInfo("message", content.getString("message"));
+ }
+ catch(JsonException je) {
+ prot.addInfo("exception", je.getMessage());
+ Assert.fail(je.getMessage());
+ }
+ prot.setPassed(true);
+ }
+
+ /**
+ * Test the UPDATE Service.
+ *
+ * @param baseUrl The url pointing to the test deployment.
+ */
+ public final void updateService(URL baseUrl, List<Protocol> protocol)
+ throws Exception {
+ System.out.print(".");
+ Protocol prot = new Protocol();
+ prot.setName("ZusatzwertService");
+ prot.setType("update");
+ prot.setPassed(false);
+ protocol.add(prot);
+ try {
+ /* Create a client*/
+ Client client = ClientBuilder.newClient();
+ WebTarget target =
+ client.target(baseUrl + "zusatzwert/" + createdId);
+ prot.addInfo("zusatzwertId", createdId);
+ /* Request an object with the saved id*/
+ Response response = target.request().get();
+ String entity = response.readEntity(String.class);
+ /* Try to parse the response*/
+ JsonReader reader = Json.createReader(new StringReader(entity));
+ JsonObject old = reader.readObject().getJsonObject("data");
+ /* Change the mmtId*/
+ String updatedEntity =
+ old.toString().replace("3.5", "14");
+ prot.addInfo("updated field", "messwertPzs");
+ prot.addInfo("updated value", "3.5");
+ prot.addInfo("updated to", "14");
+ /* Send the updated messwert via put request*/
+ WebTarget putTarget = client.target(baseUrl + "zusatzwert");
+ Response updated = putTarget.request().put(
+ Entity.entity(updatedEntity, MediaType.APPLICATION_JSON));
+ /* Try to parse the response*/
+ JsonReader updatedReader = Json.createReader(
+ new StringReader(updated.readEntity(String.class)));
+ JsonObject updatedObj = updatedReader.readObject();
+ /* Verify the response*/
+ Assert.assertTrue(updatedObj.getBoolean("success"));
+ prot.addInfo("success", updatedObj.getBoolean("success"));
+ Assert.assertEquals("200", updatedObj.getString("message"));
+ prot.addInfo("message", updatedObj.getString("message"));
+ Assert.assertEquals(14,
+ updatedObj.getJsonObject("data").getJsonNumber("messwertPzs"));
+ }
+ catch(JsonException je) {
+ prot.addInfo("exception", je.getMessage());
+ Assert.fail(je.getMessage());
+ }
+ prot.setPassed(true);
+ }
+
+ /**
+ * Test the DELETE Service.
+ *
+ * @param baseUrl The url pointing to the test deployment.
+ */
+ public final void deleteService(URL baseUrl, List<Protocol> protocol) {
+ System.out.print(".");
+ Protocol prot = new Protocol();
+ prot.setName("ZusatzwertService");
+ prot.setType("delete");
+ prot.setPassed(false);
+ protocol.add(prot);
+ try {
+ /* Create a client*/
+ Client client = ClientBuilder.newClient();
+ WebTarget target =
+ client.target(baseUrl + "zusatzwert/" + createdId);
+ prot.addInfo("zusatzwertId", createdId);
+ /* Delete the object with the saved id*/
+ Response response = target.request().delete();
+ String entity = response.readEntity(String.class);
+ /* Try to parse the response*/
+ JsonReader reader = Json.createReader(new StringReader(entity));
+ JsonObject respObj = reader.readObject();
+ /* Verify the response*/
+ Assert.assertTrue(respObj.getBoolean("success"));
+ prot.addInfo("success", respObj.getBoolean("success"));
+ Assert.assertEquals("200", respObj.getString("message"));
+ prot.addInfo("message", respObj.getString("message"));
+ }
+ catch(JsonException je) {
+ prot.addInfo("exception", je.getMessage());
+ Assert.fail(je.getMessage());
+ }
+ prot.setPassed(true);
+ }
+}
More information about the Lada-commits
mailing list