Mercurial > lada > lada-server
changeset 489:4adca0e92d98
Added test for zusatzwert service.
author | Raimund Renkert <raimund.renkert@intevation.de> |
---|---|
date | Wed, 18 Feb 2015 14:42:21 +0100 |
parents | c1b0f4217488 |
children | d6b9ba0fc2c7 |
files | src/test/java/de/intevation/lada/LadaTest.java src/test/java/de/intevation/lada/test/Zusatzwert.java |
diffstat | 2 files changed, 357 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- 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());
--- /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@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); + } +}