Sophie

Sophie

distrib > Fedora > 13 > i386 > media > os > by-pkgid > b19df05292ea6fc997c221dbeca1120c > files > 424

m2crypto-0.20.2-5.fc13.i686.rpm

#!/usr/bin/python

"""Unit tests for M2Crypto.m2 obj_* functions.
"""

import unittest
from M2Crypto import X509, ASN1, BIO, Rand, m2

"""
These functions must be cleaned up and moved to some python module
Taken from CA managment code
"""

def x509_name2list(name):
    for i in range(0, name.entry_count()):
        yield X509.X509_Name_Entry(m2.x509_name_get_entry(name._ptr(), i), _pyfree = 0)

def x509_name_entry2tuple(entry):
    bio = BIO.MemoryBuffer()
    m2.asn1_string_print(bio._ptr(), m2.x509_name_entry_get_data(entry._ptr()))
    return (m2.obj_obj2txt(m2.x509_name_entry_get_object(entry._ptr()), 0), bio.getvalue())

def tuple2x509_name_entry(tup):
    obj, data = tup
    _x509_ne = m2.x509_name_entry_create_by_txt(None, obj, ASN1.MBSTRING_ASC, data, len(data))
    if not _x509_ne:
        raise ValueError("Invalid object indentifier: %s" % obj)
    return X509.X509_Name_Entry(_x509_ne, _pyfree = 1) # Prevent memory leaks

class ObjectsTestCase(unittest.TestCase):

    def callback(self, *args):
        pass

    def test_obj2txt(self):
        assert m2.obj_obj2txt(m2.obj_txt2obj("commonName", 0), 1) == "2.5.4.3", "2.5.4.3"
        assert m2.obj_obj2txt(m2.obj_txt2obj("commonName", 0), 0) == "commonName", "commonName"

    def test_nid(self):
        assert m2.obj_ln2nid("commonName") == m2.obj_txt2nid("2.5.4.3"), "ln2nid and txt2nid mismatch"
        assert m2.obj_ln2nid("CN") == 0, "ln2nid on sn"
        assert m2.obj_sn2nid("CN") == m2.obj_ln2nid("commonName"), "ln2nid and sn2nid mismatch"
        assert m2.obj_sn2nid("CN") == m2.obj_obj2nid(m2.obj_txt2obj("CN", 0)), "obj2nid"
        assert m2.obj_txt2nid("__unknown") == 0, "__unknown"
                              
    def test_tuple2tuple(self):
        tup = ("CN", "someCommonName")
        tup1 = x509_name_entry2tuple(tuple2x509_name_entry(tup))
        assert tup1[1] == tup[1], tup1 # tup1[0] is 'commonName', not 'CN'
        assert x509_name_entry2tuple(tuple2x509_name_entry(tup1)) == tup1, tup1

    def test_unknown(self):
        self.assertRaises(ValueError, tuple2x509_name_entry, ("__unknown", "_"))
        
    def test_x509_name(self):
        n = X509.X509_Name()
        n.C = 'US' # It seems this actually needs to be a real 2 letter country code
        n.SP = 'State or Province'
        n.L = 'locality name'
        n.O = 'orhanization name'
        n.OU = 'org unit'
        n.CN = 'common name'
        n.Email = 'bob@example.com'
        n.serialNumber = '1234'
        n.SN = 'surname'
        n.GN = 'given name'
        
        n.givenName = 'name given'
        assert len(n) == 11, len(n)

        tl = map(x509_name_entry2tuple, x509_name2list(n))

        assert len(tl) == len(n), len(tl)

        x509_n = m2.x509_name_new()
        for o in map(tuple2x509_name_entry, tl):
            m2.x509_name_add_entry(x509_n, o._ptr(), -1, 0)
            o._pyfree = 0 # Take care of underlying object
        n1 = X509.X509_Name(x509_n)

        assert n.as_text() == n1.as_text(), n1.as_text()

def suite():
    suite = unittest.TestSuite()
    suite.addTest(unittest.makeSuite(ObjectsTestCase))
    return suite


if __name__ == '__main__':
    Rand.load_file('randpool.dat', -1)
    unittest.TextTestRunner().run(suite())
    Rand.save_file('randpool.dat')