diff options
author | CGantert345 <57003061+CGantert345@users.noreply.github.com> | 2021-03-29 14:44:43 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-03-29 14:44:43 +0200 |
commit | c25be270079ed4fa23d7a5c2a2d5eb8519243fb3 (patch) | |
tree | 011863c021df3e5356f07b056d30d0e7476061e4 /src/test/java/org/uic/barcode/asn1/test/UperEncodeSequenceOfIntegerTest.java | |
parent | Merge pull request #13 from UnionInternationalCheminsdeFer/time_zone_fix_3 (diff) | |
parent | structure change 1 (diff) | |
download | UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.gz UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.bz2 UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.lz UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.xz UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.tar.zst UIC-barcode-c25be270079ed4fa23d7a5c2a2d5eb8519243fb3.zip |
Diffstat (limited to 'src/test/java/org/uic/barcode/asn1/test/UperEncodeSequenceOfIntegerTest.java')
-rw-r--r-- | src/test/java/org/uic/barcode/asn1/test/UperEncodeSequenceOfIntegerTest.java | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/src/test/java/org/uic/barcode/asn1/test/UperEncodeSequenceOfIntegerTest.java b/src/test/java/org/uic/barcode/asn1/test/UperEncodeSequenceOfIntegerTest.java new file mode 100644 index 0000000..9194dca --- /dev/null +++ b/src/test/java/org/uic/barcode/asn1/test/UperEncodeSequenceOfIntegerTest.java @@ -0,0 +1,72 @@ +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.FieldOrder; +import org.uic.barcode.asn1.datatypes.Sequence; +import org.uic.barcode.asn1.datatypesimpl.SequenceOfUnrestrictedLong; +import org.uic.barcode.asn1.uper.UperEncoder; + + +public class UperEncodeSequenceOfIntegerTest { + + /** + * Example from the Standard on UPER. + <pre> +TestRecord ::= [APPLICATION 0] IMPLICIT SEQUENCE { + number INTEGER, +} + </pre> + */ + @Sequence + public static class TestRecord { + + @FieldOrder(order = 0) + SequenceOfUnrestrictedLong numbers; + + public TestRecord() { + } + + public TestRecord(List<Long> nums) { + numbers = new SequenceOfUnrestrictedLong(nums); + } + } + + + @Test public void test() throws IllegalArgumentException, IllegalAccessException { + + ArrayList<Long> nums = new ArrayList<Long>(); + nums.add(new Long(12345678909999899L)); + nums.add(new Long(12345678909999899L)); + TestRecord record = new TestRecord(nums); + byte[] encoded = UperEncoder.encode(record); + String hex = UperEncoder.hexStringFromBytes(encoded); + UperEncoder.logger.log(Level.FINEST,String.format("data hex: %s", UperEncoder.hexStringFromBytes(encoded))); + assertEquals("02072BDC545DF10B1B072BDC545DF10B1B",hex); + + } + + @Test public void testDecode() throws IllegalArgumentException, IllegalAccessException { + + ArrayList<Long> nums = new ArrayList<Long>(); + nums.add(new Long(12345678909999899L)); + nums.add(new Long(12345678909999899L)); + TestRecord record = new TestRecord(nums); + byte[] encoded = UperEncoder.encode(record); + String hex = UperEncoder.hexStringFromBytes(encoded); + UperEncoder.logger.log(Level.FINEST,String.format("data hex: %s", UperEncoder.hexStringFromBytes(encoded))); + assertEquals("02072BDC545DF10B1B072BDC545DF10B1B",hex); + + TestRecord result = UperEncoder.decode(encoded, TestRecord.class); + assertEquals(result.numbers.get(0).longValue(),record.numbers.get(0).longValue()); + assertEquals(result.numbers.get(1).longValue(),record.numbers.get(1).longValue()); + + + } + +} |