123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368 |
- #
- # This file is part of pyasn1 software.
- #
- # Copyright (c) 2005-2020, Ilya Etingof <etingof@gmail.com>
- # License: https://pyasn1.readthedocs.io/en/latest/license.html
- #
- import sys
- import unittest
- from __tests__.base import BaseTestCase
- from pyasn1.type import tag
- from pyasn1.type import namedtype
- from pyasn1.type import opentype
- from pyasn1.type import univ
- from pyasn1.codec.der import decoder
- from pyasn1.compat.octets import ints2octs, null
- from pyasn1.error import PyAsn1Error
- class BitStringDecoderTestCase(BaseTestCase):
- def testShortMode(self):
- assert decoder.decode(
- ints2octs((3, 127, 6) + (170,) * 125 + (128,))
- ) == (((1, 0) * 501), null)
- def testIndefMode(self):
- try:
- decoder.decode(
- ints2octs((35, 128, 3, 2, 0, 169, 3, 2, 1, 138, 0, 0))
- )
- except PyAsn1Error:
- pass
- else:
- assert 0, 'indefinite length encoding tolerated'
- def testDefModeChunked(self):
- try:
- assert decoder.decode(
- ints2octs((35, 8, 3, 2, 0, 169, 3, 2, 1, 138))
- )
- except PyAsn1Error:
- pass
- else:
- assert 0, 'chunked encoding tolerated'
- class OctetStringDecoderTestCase(BaseTestCase):
- def testShortMode(self):
- assert decoder.decode(
- '\004\017Quick brown fox'.encode()
- ) == ('Quick brown fox'.encode(), ''.encode())
- def testIndefMode(self):
- try:
- decoder.decode(
- ints2octs((36, 128, 4, 15, 81, 117, 105, 99, 107, 32, 98, 114, 111, 119, 110, 32, 102, 111, 120, 0, 0))
- )
- except PyAsn1Error:
- pass
- else:
- assert 0, 'indefinite length encoding tolerated'
- def testChunkedMode(self):
- try:
- decoder.decode(
- ints2octs((36, 23, 4, 2, 81, 117, 4, 2, 105, 99, 4, 2, 107, 32, 4, 2, 98, 114, 4, 2, 111, 119, 4, 1, 110))
- )
- except PyAsn1Error:
- pass
- else:
- assert 0, 'chunked encoding tolerated'
- class SequenceDecoderWithUntaggedOpenTypesTestCase(BaseTestCase):
- def setUp(self):
- openType = opentype.OpenType(
- 'id',
- {1: univ.Integer(),
- 2: univ.OctetString()}
- )
- self.s = univ.Sequence(
- componentType=namedtype.NamedTypes(
- namedtype.NamedType('id', univ.Integer()),
- namedtype.NamedType('blob', univ.Any(), openType=openType)
- )
- )
- def testDecodeOpenTypesChoiceOne(self):
- s, r = decoder.decode(
- ints2octs((48, 6, 2, 1, 1, 2, 1, 12)), asn1Spec=self.s,
- decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 1
- assert s[1] == 12
- def testDecodeOpenTypesChoiceTwo(self):
- s, r = decoder.decode(
- ints2octs((48, 16, 2, 1, 2, 4, 11, 113, 117, 105, 99, 107, 32, 98, 114, 111, 119, 110)), asn1Spec=self.s,
- decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 2
- assert s[1] == univ.OctetString('quick brown')
- def testDecodeOpenTypesUnknownType(self):
- try:
- s, r = decoder.decode(
- ints2octs((48, 6, 2, 1, 2, 6, 1, 39)), asn1Spec=self.s,
- decodeOpenTypes=True
- )
- except PyAsn1Error:
- pass
- else:
- assert False, 'unknown open type tolerated'
- def testDecodeOpenTypesUnknownId(self):
- s, r = decoder.decode(
- ints2octs((48, 6, 2, 1, 3, 6, 1, 39)), asn1Spec=self.s,
- decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 3
- assert s[1] == univ.OctetString(hexValue='060127')
- def testDontDecodeOpenTypesChoiceOne(self):
- s, r = decoder.decode(
- ints2octs((48, 6, 2, 1, 1, 2, 1, 12)), asn1Spec=self.s
- )
- assert not r
- assert s[0] == 1
- assert s[1] == ints2octs((2, 1, 12))
- def testDontDecodeOpenTypesChoiceTwo(self):
- s, r = decoder.decode(
- ints2octs((48, 16, 2, 1, 2, 4, 11, 113, 117, 105, 99, 107, 32, 98, 114, 111, 119, 110)), asn1Spec=self.s
- )
- assert not r
- assert s[0] == 2
- assert s[1] == ints2octs((4, 11, 113, 117, 105, 99, 107, 32, 98, 114, 111, 119, 110))
- class SequenceDecoderWithImplicitlyTaggedOpenTypesTestCase(BaseTestCase):
- def setUp(self):
- openType = opentype.OpenType(
- 'id',
- {1: univ.Integer(),
- 2: univ.OctetString()}
- )
- self.s = univ.Sequence(
- componentType=namedtype.NamedTypes(
- namedtype.NamedType('id', univ.Integer()),
- namedtype.NamedType(
- 'blob', univ.Any().subtype(implicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 3)), openType=openType
- )
- )
- )
- def testDecodeOpenTypesChoiceOne(self):
- s, r = decoder.decode(
- ints2octs((48, 8, 2, 1, 1, 131, 3, 2, 1, 12)), asn1Spec=self.s, decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 1
- assert s[1] == 12
- def testDecodeOpenTypesUnknownId(self):
- s, r = decoder.decode(
- ints2octs((48, 8, 2, 1, 3, 131, 3, 2, 1, 12)), asn1Spec=self.s, decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 3
- assert s[1] == univ.OctetString(hexValue='02010C')
- class SequenceDecoderWithExplicitlyTaggedOpenTypesTestCase(BaseTestCase):
- def setUp(self):
- openType = opentype.OpenType(
- 'id',
- {1: univ.Integer(),
- 2: univ.OctetString()}
- )
- self.s = univ.Sequence(
- componentType=namedtype.NamedTypes(
- namedtype.NamedType('id', univ.Integer()),
- namedtype.NamedType(
- 'blob', univ.Any().subtype(explicitTag=tag.Tag(tag.tagClassContext, tag.tagFormatSimple, 3)), openType=openType
- )
- )
- )
- def testDecodeOpenTypesChoiceOne(self):
- s, r = decoder.decode(
- ints2octs((48, 8, 2, 1, 1, 163, 3, 2, 1, 12)), asn1Spec=self.s, decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 1
- assert s[1] == 12
- def testDecodeOpenTypesUnknownId(self):
- s, r = decoder.decode(
- ints2octs((48, 8, 2, 1, 3, 163, 3, 2, 1, 12)), asn1Spec=self.s, decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 3
- assert s[1] == univ.OctetString(hexValue='02010C')
- class SequenceDecoderWithUnaggedSetOfOpenTypesTestCase(BaseTestCase):
- def setUp(self):
- openType = opentype.OpenType(
- 'id',
- {1: univ.Integer(),
- 2: univ.OctetString()}
- )
- self.s = univ.Sequence(
- componentType=namedtype.NamedTypes(
- namedtype.NamedType('id', univ.Integer()),
- namedtype.NamedType('blob', univ.SetOf(componentType=univ.Any()),
- openType=openType)
- )
- )
- def testDecodeOpenTypesChoiceOne(self):
- s, r = decoder.decode(
- ints2octs((48, 8, 2, 1, 1, 49, 3, 2, 1, 12)), asn1Spec=self.s,
- decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 1
- assert s[1][0] == 12
- def testDecodeOpenTypesChoiceTwo(self):
- s, r = decoder.decode(
- ints2octs((48, 18, 2, 1, 2, 49, 13, 4, 11, 113, 117, 105, 99,
- 107, 32, 98, 114, 111, 119, 110)), asn1Spec=self.s,
- decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 2
- assert s[1][0] == univ.OctetString('quick brown')
- def testDecodeOpenTypesUnknownType(self):
- try:
- s, r = decoder.decode(
- ints2octs((48, 6, 2, 1, 2, 6, 1, 39)), asn1Spec=self.s,
- decodeOpenTypes=True
- )
- except PyAsn1Error:
- pass
- else:
- assert False, 'unknown open type tolerated'
- def testDecodeOpenTypesUnknownId(self):
- s, r = decoder.decode(
- ints2octs((48, 8, 2, 1, 3, 49, 3, 2, 1, 12)), asn1Spec=self.s,
- decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 3
- assert s[1][0] == univ.OctetString(hexValue='02010c')
- def testDontDecodeOpenTypesChoiceOne(self):
- s, r = decoder.decode(
- ints2octs((48, 8, 2, 1, 1, 49, 3, 2, 1, 12)), asn1Spec=self.s
- )
- assert not r
- assert s[0] == 1
- assert s[1][0] == ints2octs((2, 1, 12))
- def testDontDecodeOpenTypesChoiceTwo(self):
- s, r = decoder.decode(
- ints2octs((48, 18, 2, 1, 2, 49, 13, 4, 11, 113, 117, 105, 99,
- 107, 32, 98, 114, 111, 119, 110)), asn1Spec=self.s
- )
- assert not r
- assert s[0] == 2
- assert s[1][0] == ints2octs((4, 11, 113, 117, 105, 99, 107, 32, 98, 114,
- 111, 119, 110))
- class SequenceDecoderWithImplicitlyTaggedSetOfOpenTypesTestCase(BaseTestCase):
- def setUp(self):
- openType = opentype.OpenType(
- 'id',
- {1: univ.Integer(),
- 2: univ.OctetString()}
- )
- self.s = univ.Sequence(
- componentType=namedtype.NamedTypes(
- namedtype.NamedType('id', univ.Integer()),
- namedtype.NamedType(
- 'blob', univ.SetOf(
- componentType=univ.Any().subtype(
- implicitTag=tag.Tag(
- tag.tagClassContext, tag.tagFormatSimple, 3))),
- openType=openType
- )
- )
- )
- def testDecodeOpenTypesChoiceOne(self):
- s, r = decoder.decode(
- ints2octs((48, 10, 2, 1, 1, 49, 5, 131, 3, 2, 1, 12)),
- asn1Spec=self.s, decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 1
- assert s[1][0] == 12
- def testDecodeOpenTypesUnknownId(self):
- s, r = decoder.decode(
- ints2octs((48, 10, 2, 1, 3, 49, 5, 131, 3, 2, 1, 12)),
- asn1Spec=self.s, decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 3
- assert s[1][0] == univ.OctetString(hexValue='02010C')
- class SequenceDecoderWithExplicitlyTaggedSetOfOpenTypesTestCase(BaseTestCase):
- def setUp(self):
- openType = opentype.OpenType(
- 'id',
- {1: univ.Integer(),
- 2: univ.OctetString()}
- )
- self.s = univ.Sequence(
- componentType=namedtype.NamedTypes(
- namedtype.NamedType('id', univ.Integer()),
- namedtype.NamedType(
- 'blob', univ.SetOf(
- componentType=univ.Any().subtype(
- explicitTag=tag.Tag(
- tag.tagClassContext, tag.tagFormatSimple, 3))),
- openType=openType
- )
- )
- )
- def testDecodeOpenTypesChoiceOne(self):
- s, r = decoder.decode(
- ints2octs((48, 10, 2, 1, 1, 49, 5, 131, 3, 2, 1, 12)),
- asn1Spec=self.s, decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 1
- assert s[1][0] == 12
- def testDecodeOpenTypesUnknownId(self):
- s, r = decoder.decode(
- ints2octs( (48, 10, 2, 1, 3, 49, 5, 131, 3, 2, 1, 12)),
- asn1Spec=self.s, decodeOpenTypes=True
- )
- assert not r
- assert s[0] == 3
- assert s[1][0] == univ.OctetString(hexValue='02010C')
- suite = unittest.TestLoader().loadTestsFromModule(sys.modules[__name__])
- if __name__ == '__main__':
- unittest.TextTestRunner(verbosity=2).run(suite)
|