aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorChristof Rabensteiner <christof.rabensteiner@iaik.tugraz.at>2019-04-10 14:07:50 +0200
committerChristof Rabensteiner <christof.rabensteiner@iaik.tugraz.at>2019-04-10 14:07:50 +0200
commit106a12c2ab80ccac70910f5b6e337ac24e04da65 (patch)
tree187732e478e0797edd29dbb158d0c8a18613ebcb /src
parenteaa2485479b9ece8014eb51be4759606c911d246 (diff)
downloadmoa-zs-106a12c2ab80ccac70910f5b6e337ac24e04da65.tar.gz
moa-zs-106a12c2ab80ccac70910f5b6e337ac24e04da65.tar.bz2
moa-zs-106a12c2ab80ccac70910f5b6e337ac24e04da65.zip
Add Testcase For JAXB Marshalling
Diffstat (limited to 'src')
-rw-r--r--src/test/java/at/gv/egiz/moazs/JaxbMarshallerTest.java101
-rw-r--r--src/test/resources/at/gv/egiz/moazs/App2MzsServiceTest/validDeliveryRequest.soap2
2 files changed, 102 insertions, 1 deletions
diff --git a/src/test/java/at/gv/egiz/moazs/JaxbMarshallerTest.java b/src/test/java/at/gv/egiz/moazs/JaxbMarshallerTest.java
new file mode 100644
index 0000000..e85a5ba
--- /dev/null
+++ b/src/test/java/at/gv/egiz/moazs/JaxbMarshallerTest.java
@@ -0,0 +1,101 @@
+package at.gv.egiz.moazs;
+
+import at.gv.e_government.reference.namespace.zustellung.mzs.app2mzs_.DeliveryRequestType;
+import org.junit.Test;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+import javax.xml.bind.JAXBContext;
+import javax.xml.bind.JAXBElement;
+import javax.xml.bind.JAXBException;
+import javax.xml.bind.Marshaller;
+import javax.xml.datatype.DatatypeConfigurationException;
+import javax.xml.datatype.DatatypeFactory;
+import java.math.BigInteger;
+import java.nio.charset.Charset;
+import java.util.GregorianCalendar;
+
+public class JaxbMarshallerTest {
+
+ private static final Logger logger = LoggerFactory.getLogger(JaxbMarshallerTest.class);
+
+ private Marshaller createMarshaller() throws JAXBException {
+ JAXBContext context = JAXBContext.newInstance(
+ at.gv.e_government.reference.namespace.zustellung.mzs.persondata_.ObjectFactory.class,
+ at.gv.e_government.reference.namespace.zustellung.mzs.app2mzs_.ObjectFactory.class,
+ at.gv.e_government.reference.namespace.zustellung.msg.phase2._20181206_.ObjectFactory.class,
+ at.gv.e_government.reference.namespace.persondata.phase2._20181206_.ObjectFactory.class);
+
+ var m = context.createMarshaller();
+ m.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, Boolean.TRUE);
+ return m;
+
+ }
+
+ private JAXBElement<DeliveryRequestType> generateSampleRequest() throws DatatypeConfigurationException {
+ var pof = new at.gv.e_government.reference.namespace.zustellung.mzs.persondata_.ObjectFactory();
+ var mzsof = new at.gv.e_government.reference.namespace.zustellung.mzs.app2mzs_.ObjectFactory();
+ var msgof = new at.gv.e_government.reference.namespace.zustellung.msg.phase2._20181206_.ObjectFactory();
+
+ var deliveryRequest = new DeliveryRequestType();
+
+ var sender = mzsof.createDeliveryRequestTypeSender();
+ var corporateBody = pof.createCorporateBodyType();
+ corporateBody.setFullName("Bundesministerium für Testzwecke");
+ sender.setPerson(pof.createCorporateBody(corporateBody));
+ deliveryRequest.setSender(sender);
+
+ var receiver = mzsof.createDeliveryRequestTypeReceiver();
+ var physicalPerson = pof.createPhysicalPersonType();
+ var name = pof.createPersonNameType();
+ name.setGivenName("Maxi");
+ var familyName = pof.createPersonNameTypeFamilyName();
+ familyName.setValue("Mustermann1");
+ name.setFamilyName(familyName);
+ physicalPerson.setName(name);
+ var cal = new GregorianCalendar(1984, 1, 24);
+ var xmlDate = DatatypeFactory.newInstance().newXMLGregorianCalendar(cal);
+ physicalPerson.setDateOfBirth(pof.createDateOfBirth(xmlDate).getValue());
+ receiver.setPerson(pof.createPhysicalPerson(physicalPerson));
+ var postal = pof.createPostalAddressType();
+ postal.setCountryCode("AT");
+ postal.setPostalCode("1010");
+ postal.setMunicipality("Wien");
+ var deliveryAddress = pof.createPostalAddressTypeDeliveryAddress();
+ deliveryAddress.setStreetName("Musterstraße");
+ deliveryAddress.setBuildingNumber("10");
+ postal.setDeliveryAddress(deliveryAddress);
+ receiver.getAddress().add(pof.createAddress(postal));
+ deliveryRequest.setReceiver(receiver);
+
+ var metadata = msgof.createMetaData();
+ metadata.setAppDeliveryID("asd");
+ metadata.setSubject("Wichtige Mitteilung!");
+ metadata.setDeliveryQuality("RSa");
+ deliveryRequest.setMetaData(metadata);
+
+ var payload = mzsof.createDeliveryRequestTypePayload();
+ payload.setDocumentReference("https://authority.gv.at/files/73bdf969781ba41fa07df1ff8439cf685c0db1c3");
+ payload.setFileName("brief.xml");
+ payload.setMIMEType("text/xml");
+ payload.setSize(BigInteger.valueOf(123401));
+ var checksum = msgof.createCheckSumType();
+ checksum.setAlgorithmID("SHA1");
+ checksum.setValue("random".getBytes(Charset.forName("UTF-8")));
+ payload.setCheckSum(checksum);
+ deliveryRequest.getPayload().add(payload);
+
+ return mzsof.createDeliveryRequest(deliveryRequest);
+ }
+
+ @Test
+ public void testMarshalling() throws JAXBException, DatatypeConfigurationException {
+
+ logger.info("test marshalling....");
+ var request = generateSampleRequest();
+ var m = createMarshaller();
+ m.marshal(request, System.out);
+
+ }
+
+}
diff --git a/src/test/resources/at/gv/egiz/moazs/App2MzsServiceTest/validDeliveryRequest.soap b/src/test/resources/at/gv/egiz/moazs/App2MzsServiceTest/validDeliveryRequest.soap
index 5254540..d71939b 100644
--- a/src/test/resources/at/gv/egiz/moazs/App2MzsServiceTest/validDeliveryRequest.soap
+++ b/src/test/resources/at/gv/egiz/moazs/App2MzsServiceTest/validDeliveryRequest.soap
@@ -40,7 +40,7 @@
<mzs:Payload>
<mzs:DocumentReference>https://authority.gv.at/files/73bdf969781ba41fa07df1ff8439cf685c0db1c3</mzs:DocumentReference>
<mzs:FileName>brief.xml</mzs:FileName>
- <mzs:MIMEType>application/xml</mzs:MIMEType>
+ <mzs:MIMEType>text/xml</mzs:MIMEType>
<msg:CheckSum>
<msg:AlgorithmID>SHA1</msg:AlgorithmID>
<msg:Value>9b972c70fdaf5e1b26b3387c87b0ffb72e5940b6</msg:Value>