summaryrefslogtreecommitdiffstats
path: root/src/test/java/org/uic
diff options
context:
space:
mode:
authorCGantert345 <57003061+CGantert345@users.noreply.github.com>2021-11-24 12:40:11 +0100
committerCGantert345 <57003061+CGantert345@users.noreply.github.com>2021-11-24 12:40:11 +0100
commit3062dbc6b6df9c7ef824eeea8d31ad5702506518 (patch)
treeb5bfec67bf28a1e0ce5aad64822089b78a80fd88 /src/test/java/org/uic
parentextended tests (diff)
downloadUIC-barcode-3062dbc6b6df9c7ef824eeea8d31ad5702506518.tar
UIC-barcode-3062dbc6b6df9c7ef824eeea8d31ad5702506518.tar.gz
UIC-barcode-3062dbc6b6df9c7ef824eeea8d31ad5702506518.tar.bz2
UIC-barcode-3062dbc6b6df9c7ef824eeea8d31ad5702506518.tar.lz
UIC-barcode-3062dbc6b6df9c7ef824eeea8d31ad5702506518.tar.xz
UIC-barcode-3062dbc6b6df9c7ef824eeea8d31ad5702506518.tar.zst
UIC-barcode-3062dbc6b6df9c7ef824eeea8d31ad5702506518.zip
Diffstat (limited to 'src/test/java/org/uic')
-rw-r--r--src/test/java/org/uic/barcode/asn1/test/UperEncodeBitStringTest.java81
1 files changed, 81 insertions, 0 deletions
diff --git a/src/test/java/org/uic/barcode/asn1/test/UperEncodeBitStringTest.java b/src/test/java/org/uic/barcode/asn1/test/UperEncodeBitStringTest.java
new file mode 100644
index 0000000..574a9cf
--- /dev/null
+++ b/src/test/java/org/uic/barcode/asn1/test/UperEncodeBitStringTest.java
@@ -0,0 +1,81 @@
+package org.uic.barcode.asn1.test;
+
+import static org.junit.Assert.assertEquals;
+
+import java.util.ArrayList;
+import java.util.List;
+import java.util.logging.Level;
+
+import org.junit.Test;
+import org.uic.barcode.asn1.datatypes.Asn1Optional;
+import org.uic.barcode.asn1.datatypes.Asn1VarSizeBitstring;
+import org.uic.barcode.asn1.datatypes.FieldOrder;
+import org.uic.barcode.asn1.datatypes.Sequence;
+import org.uic.barcode.asn1.uper.UperEncoder;
+
+
+public class UperEncodeBitStringTest {
+
+ /**
+ * Example from the Standard on UPER.
+ <pre>
+ World-Schema DEFINITIONS AUTOMATIC TAGS ::=
+ BEGIN
+ TestRecord ::= [APPLICATION 0] IMPLICIT SEQUENCE {
+ value BIT STRING OPTIONAL,
+ }
+ END
+
+
+ rec1value TestRecord ::= {
+ value '001'B
+ }
+ </pre>
+
+
+
+ */
+ @Sequence
+ public static class TestRecord {
+
+ @FieldOrder(order = 0)
+ @Asn1Optional() Asn1VarSizeBitstring value;
+
+ public TestRecord() {
+ this(false,false,true);
+ }
+
+ public TestRecord(Boolean value1,Boolean value2,Boolean value3 ) {
+ List<Boolean> booleans = new ArrayList<Boolean>();
+ booleans.add(value1);
+ booleans.add(value2);
+ booleans.add(value3);
+ this.value = new Asn1VarSizeBitstring(booleans);
+
+ }
+ }
+
+
+ @Test public void testEncode() throws IllegalArgumentException, IllegalAccessException {
+ TestRecord record = new TestRecord(false,false,true);
+ byte[] encoded = UperEncoder.encode(record);
+ String hex = UperEncoder.hexStringFromBytes(encoded);
+ UperEncoder.logger.log(Level.FINEST,String.format("data hex: %s", hex));
+ assertEquals("8190",hex);
+ }
+
+
+ @Test public void testDecode() throws IllegalArgumentException, IllegalAccessException {
+ TestRecord record = new TestRecord(false,false,true);
+ byte[] encoded = UperEncoder.encode(record);
+ String hex = UperEncoder.hexStringFromBytes(encoded);
+ UperEncoder.logger.log(Level.FINEST,String.format("data hex: %s", hex));
+ assertEquals("8190",hex);
+ TestRecord result = UperEncoder.decode(encoded, TestRecord.class);
+ assertEquals(result.value.get(0),record.value.get(0));
+ assertEquals(result.value.get(1),record.value.get(1));
+ assertEquals(result.value.get(2),record.value.get(2));
+
+ }
+
+}