1
0
Fork 0
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

421 lines
22 KiB

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta charset="utf-8">
<title>QUnit for ASN1 Encoder Class 'asn1x509.js'</title>
<script type="text/javascript" src="jquery-1.4.2.min.js"></script>
<script type="text/javascript" src="qunit.js"></script>
<link rel="stylesheet" href="qunit.css" type="text/css" media="screen" />
<script src="http://yui.yahooapis.com/2.9.0/build/yahoo/yahoo-min.js"></script>
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/core-min.js"></script>
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/enc-base64-min.js"></script>
<script src="http://crypto-js.googlecode.com/svn/tags/3.1.2/build/components/sha1.js"></script>
<script language="JavaScript" type="text/javascript" src="../ext/jsbn.js"></script>
<script language="JavaScript" type="text/javascript" src="../ext/jsbn2.js"></script>
<script language="JavaScript" type="text/javascript" src="../ext/base64.js"></script>
<script language="JavaScript" type="text/javascript" src="../ext/rsa.js"></script>
<script language="JavaScript" type="text/javascript" src="../ext/rsa2.js"></script>
<script language="JavaScript" type="text/javascript" src="../base64x-1.1.js"></script>
<script language="JavaScript" type="text/javascript" src="../asn1hex-1.1.js"></script>
<script language="JavaScript" type="text/javascript" src="../rsapem-1.1.js"></script>
<script language="JavaScript" type="text/javascript" src="../rsasign-1.2.js"></script>
<script language="JavaScript" type="text/javascript" src="../crypto-1.1.js"></script>
<script language="JavaScript" type="text/javascript" src="../asn1-1.0.js"></script>
<script language="JavaScript" type="text/javascript" src="../asn1x509-1.0.js"></script>
<script language="JavaScript" type="text/javascript" src="../x509-1.1.js"></script>
<script language="JavaScript" type="text/javascript" src="../keyutil-1.0.js"></script>
<script type="text/javascript">
<!--
$(document).ready(function(){
// ======= TEST ===============================================================
// _test/z4.tsa.cer
var z4TSACERT =
"-----BEGIN CERTIFICATE-----\n" +
"MIIDETCCAfmgAwIBAgIBTTANBgkqhkiG9w0BAQUFADAbMQswCQYDVQQGEwJVUzEM\n" +
"MAoGA1UECgwDQ0ExMB4XDTEzMDUwMTIzNTk1OVoXDTIzMDUwMTIzNTk1OVowHDEL\n" +
"MAkGA1UEBhMCVVMxDTALBgNVBAMMBFRTQTEwggEiMA0GCSqGSIb3DQEBAQUAA4IB\n" +
"DwAwggEKAoIBAQDfdOqotHd55SYO0dLz2oXengw/tZ+q3ZmOPeVmMuOMIYO/Cv1w\n" +
"k2U0OK4pug4OBSJPhl09Zs6IwB8NwPOU7EDTgMOcQUYB/6QNCI1J7Zm2oLtuchzz\n" +
"4pIb+o4ZAhVprLhRyvqi8OTKQ7kfGfs5Tuwmn1M/0fQkfzMxADpjOKNgf0uy6lN6\n" +
"utjdTrPKKFUQNdc6/Ty8EeTnQEwUlsT2LAXCfEKxTn5RlRljDztS7Sfgs8VL0FPy\n" +
"1Qi8B+dFcgRYKFrcpsVaZ1lBmXKsXDRu5QR/Rg3f9DRq4GR1sNH8RLY9uApMl2SN\n" +
"z+sR4zRPG85R/se5Q06Gu0BUQ3UPm67ETVZLAgMBAAGjXzBdMAwGA1UdEwEB/wQC\n" +
"MAAwCwYDVR0PBAQDAgbAMBYGA1UdJQEB/wQMMAoGCCsGAQUFBwMIMCgGA1UdHwQh\n" +
"MB8wHaAboBmGF2h0dHA6Ly90ZXN0LmNvbS9jYTEuY3JsMA0GCSqGSIb3DQEBBQUA\n" +
"A4IBAQBNkm5GniFi3PKqbafCVN8mpHWJjF2stCRTVxeTCIXUC63YD5XKABGzPH+Y\n" +
"2R8fCrOa8cGlHmFXOlJye/lnXeZodPyxJUvAKohTp6sG+rJVId8ISI2Io2i5BF8a\n" +
"CHdm8qd8E0fJvBudqkEc26Ia6tFSA/gEW0ffhsCkN/lXUAjuvDLqtTtU7zBU6dIl\n" +
"h12Pwyf+x6AsYSciA9zWC6OE590K8Jr2z4u85biM7viWvPeZPNHSNM1fe+8wKbP8\n" +
"64JtLj/VrglcsXALaUalyh2Hs7gPQzjyus1fyhEWPO3T6KMcBMXjb6anxL5q9YO5\n" +
"qx1hJTY3L1hahBcMTALQyTEiFv1S\n" +
"-----END CERTIFICATE-----\n";
test("Certificate class test", function() {
var pubKey = new RSAKey();
pubKey.setPublic('e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a', '10001');
var o = new KJUR.asn1.x509.TBSCertificate();
o.setSerialNumberByParam({'int': 4});
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setNotBeforeByParam({'str': '130504235959Z'});
o.setNotAfterByParam({'str': '140504235959Z'});
o.setSubjectByParam({'str': '/C=US/CN=b'});
o.setSubjectPublicKeyByParam({'rsakey': pubKey});
o.appendExtension(new KJUR.asn1.x509.BasicConstraints({'cA':true}));
o.appendExtension(new KJUR.asn1.x509.KeyUsage({'bin':'11'}));
var prvKey = new RSAKey();
prvKey.readPrivateKeyFromASN1HexString("3082013a020100024100e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a4e3518fd590203010001024078bbc54c646795e9a623cb0f912c7f9f6861711560e57bade21ded2f7d9579f86272fab9e71ab27282c2760c404dae6ac8a3ab852cf6bcd562f9aff8247a264d022100fe9bd450866b3255614fde976a76ac0b1d5830dda64f5359b946d8512bc1239f022100e9ab680f5f05dbb0f4311b0e6f4368f4874a1238979d8bc600c35c6f20707c07022100d549cb698dc17d4fe30e5a84f3ade860033c1eeb7f67d286465c9fd817d45b3702201849b4bb44493b989d092da2c675df46eb790b83ce5e95d4b2e79b88017b2fa902207d261a96256d49b020cb1d587ecde127e093a4d2b34cdbff171f34125b5857a9");
var crt1 = new KJUR.asn1.x509.Certificate({tbscertobj: o,
prvkeyobj: prvKey});
crt1.sign();
expect(3);
// test3
equal(crt1.asn1TBSCert.getEncodedHex(), "3081e5a003020102020104300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161301e170d3133303530343233353935395a170d3134303530343233353935395a3019310b3009060355040613025553310a300806035504030c01623057300d06092a864886f70d01010105000346003043023c00e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a0203010001a31d301b300c0603551d13040530030101ff300b0603551d0f0404030206c0", "constructor,sign,asn1TBSCert.getEncodedHex");
// test1
hCrt1 = crt1.getEncodedHex()
equal(hCrt1, "3082013a3081e5a003020102020104300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161301e170d3133303530343233353935395a170d3134303530343233353935395a3019310b3009060355040613025553310a300806035504030c01623057300d06092a864886f70d01010105000346003043023c00e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a0203010001a31d301b300c0603551d13040530030101ff300b0603551d0f0404030206c0300d06092a864886f70d010105050003410088dca030a5dcae7b85f0bfcb1fcbac18065d9f5bfd717c78075449a8447e87d0c7cb0cfd2b2ad7140c4075fd44b741502b89a7f7a9967e21c8aea330ac124be0", "constructor,sign,getEncodedHex");
// test2
equal(crt1.getPEMString(), "-----BEGIN CERTIFICATE-----\r\nMIIBOjCB5aADAgECAgEEMA0GCSqGSIb3DQEBBQUAMBkxCzAJBgNVBAYTAlVTMQow\r\nCAYDVQQKDAFhMB4XDTEzMDUwNDIzNTk1OVoXDTE0MDUwNDIzNTk1OVowGTELMAkG\r\nA1UEBhMCVVMxCjAIBgNVBAMMAWIwVzANBgkqhkiG9w0BAQEFAANGADBDAjwA6GZN\r\n0rQFKRIVaPOzm8l6Yue6PAm6vcTw3NjfkOt5C5u2RaK3DjESdHtNPEG1FCSJURX+\r\n+I951D6uWxoCAwEAAaMdMBswDAYDVR0TBAUwAwEB/zALBgNVHQ8EBAMCBsAwDQYJ\r\nKoZIhvcNAQEFBQADQQCI3KAwpdyue4Xwv8sfy6wYBl2fW/1xfHgHVEmoRH6H0MfL\r\nDP0rKtcUDEB1/US3QVAriaf3qZZ+IciuozCsEkvg\r\n-----END CERTIFICATE-----\r\n", "getPEMString");
});
test("TBSCertificate class test", function() {
expect(1);
var rsaKey = new RSAKey();
rsaKey.setPublic('e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a', '10001');
var o = new KJUR.asn1.x509.TBSCertificate();
o.setSerialNumberByParam({'int': 4});
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setNotBeforeByParam({'str': '130504235959Z'});
o.setNotAfterByParam({'str': '140504235959Z'});
o.setSubjectByParam({'str': '/C=US/CN=b'});
o.setSubjectPublicKeyByParam({'rsakey': rsaKey});
o.appendExtension(new KJUR.asn1.x509.BasicConstraints({'cA':true}));
o.appendExtension(new KJUR.asn1.x509.KeyUsage({'bin':'11'}));
equal(o.getEncodedHex(), "3081e5a003020102020104300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161301e170d3133303530343233353935395a170d3134303530343233353935395a3019310b3009060355040613025553310a300806035504030c01623057300d06092a864886f70d01010105000346003043023c00e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a0203010001a31d301b300c0603551d13040530030101ff300b0603551d0f0404030206c0", "set/append test1");
});
test("X500Name class test", function() {
var o = null;
o = new KJUR.asn1.x509.X500Name();
o.setByString("/C=US/O=aaa");
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c03616161",
"setByString(/C=US/O=aaa)");
o = new KJUR.asn1.x509.X500Name();
o.setByObject({C: "US", O: "aaa"});
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c03616161",
"setByObject({C: 'US', O: 'aaa'})");
o = new KJUR.asn1.x509.X500Name({'str':'/C=US/O=aaa'});
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c03616161",
"constructor str /C=US/O=aaa");
o = new KJUR.asn1.x509.X500Name({'C': 'US', 'O': 'aaa'});
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c03616161",
"constructor obj C:US, O:aaa");
o = new KJUR.asn1.x509.X500Name({'C': 'US', 'O': 'aa/'});
equal(o.getEncodedHex(),
"301b310b3009060355040613025553310c300a060355040a0c0361612f",
"constructor obj C:US, O:aa/");
});
test("RDN class test", function() {
expect(2);
var o2 = new KJUR.asn1.x509.RDN();
o2.addByString("O=aaa");
equal(o2.getEncodedHex(), "310c300a060355040a0c03616161", "addByString(O=aaa)");
var o3 = new KJUR.asn1.x509.RDN({'str':'O=aaa'});
equal(o3.getEncodedHex(), "310c300a060355040a0c03616161", "constructor str O=aaa");
});
test("AttributeTypeAndValue class test", function() {
expect(3);
var o1 = new KJUR.asn1.x509.AttributeTypeAndValue();
o1.setByAttrTypeAndValueStr("O", "aaa");
equal(o1.getEncodedHex(), "300a060355040a0c03616161", "setByAttrTypeAndValueStr O aaa");
var o2 = new KJUR.asn1.x509.AttributeTypeAndValue();
o2.setByString("O=aaa");
equal(o2.getEncodedHex(), "300a060355040a0c03616161", "setByString(O=aaa)");
var o3 = new KJUR.asn1.x509.AttributeTypeAndValue({'str':'O=aaa'});
equal(o3.getEncodedHex(), "300a060355040a0c03616161", "constructor str O=aaa");
});
// === BEGIN Other ASN1 structure class ======================================
test("SubjectPublicKeyInfo class test", function() {
expect(4);
var rsaKey = new RSAKey();
rsaKey.setPublic('e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a', '10001');
var o1 = new KJUR.asn1.x509.SubjectPublicKeyInfo({'rsakey': rsaKey});
equal(o1.getEncodedHex(), "3057300d06092a864886f70d01010105000346003043023c00e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a0203010001", "constructor default rsaKey");
equal(o1.rsaKey.e.toString(16), "10001", "rsa1");
var o2 = new KJUR.asn1.x509.SubjectPublicKeyInfo();
o2.setRSAPEM("-----BEGIN PUBLIC KEY-----\n" +
"MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAOtpGHibL8Ue+MXPPufkcrNES40rCT5L\n" +
"RIU9MjTZ8/7owG5bAsiFA9Xxh3uZK1T5QA64jNJVbp2ojHAtNyWPuwsCAwEAAQ==" +
"-----END PUBLIC KEY-----\n");
equal(o2.rsaKey.n.toString(16), "eb6918789b2fc51ef8c5cf3ee7e472b3444b8d2b093e4b44853d3234d9f3fee8c06e5b02c88503d5f1877b992b54f9400eb88cd2556e9da88c702d37258fbb0b", "setRSAPEM rsaKey.n");
equal(o2.rsaKey.e.toString(16), "10001", "setRSAPEM rsaKey.e");
});
test("Time class test", function() {
expect(4);
var o1 = new KJUR.asn1.x509.Time({'str':'130430235959Z'}); // UTC
equal(o1.getEncodedHex(), "170d3133303433303233353935395a", "constructor default timestr");
var o2 = new KJUR.asn1.x509.Time({'str':'20130430235959Z', 'type': 'gen'}); // Gen
equal(o2.getEncodedHex(), "180f32303133303433303233353935395a", "constructor default timestr");
var o3 = new KJUR.asn1.x509.Time({'str':'20130430235959Z'}); // Gen
equal(o3.getEncodedHex(), "180f32303133303433303233353935395a", "constructor default timestr (auto gen)");
var o4 = new KJUR.asn1.x509.Time(); // auto UTC
equal(o4.getEncodedHex().substr(0, 4), "170d", "constructor default timestr (empty)=170d...");
});
test("AlgorithmIdentifier class test", function() {
expect(1);
var o1 = new KJUR.asn1.x509.AlgorithmIdentifier({'name':'SHA1withRSA'});
equal(o1.getEncodedHex(), "300d06092a864886f70d0101050500", "constructor name SHA1withRSA");
});
test("GeneralName class test", function() {
expect(5);
var o1 = new KJUR.asn1.x509.GeneralName({'rfc822':'u1@foo.com'});
equal(o1.getEncodedHex(), "810a753140666f6f2e636f6d", "constructor rfc822 u1@foo.com");
var o2 = new KJUR.asn1.x509.GeneralName({'dns':'foo.com'});
equal(o2.getEncodedHex(), "8207666f6f2e636f6d", "constructor dns foo.com");
var o3 = new KJUR.asn1.x509.GeneralName({'uri':'http://aaa.com/'});
equal(o3.getEncodedHex(), "860f687474703a2f2f6161612e636f6d2f", "constructor uri http://aaa.com/");
var o4= new KJUR.asn1.x509.GeneralName({certissuer: z4TSACERT});
equal(o4.getEncodedHex(), "a41d301b310b3009060355040613025553310c300a060355040a0c03434131", "constructor certissuer cert1");
var o5= new KJUR.asn1.x509.GeneralName({certsubj: z4TSACERT});
equal(o5.getEncodedHex(), "a41e301c310b3009060355040613025553310d300b06035504030c0454534131", "constructor certsubj cert1");
});
test("GeneralNames class test", function() {
expect(1);
var o1 = new KJUR.asn1.x509.GeneralNames([{'uri':'http://aaa.com/'}]);
equal(o1.getEncodedHex(), "3011860f687474703a2f2f6161612e636f6d2f", "constructor uri http://aaa.com/");
});
test("DistributionPointName class test", function() {
expect(1);
var o1a = new KJUR.asn1.x509.GeneralNames([{'uri':'http://aaa.com/'}]);
var o1 = new KJUR.asn1.x509.DistributionPointName(o1a);
equal(o1.getEncodedHex(), "a011860f687474703a2f2f6161612e636f6d2f", "constructor uri http://aaa.com/");
});
test("DistributionPoint class test", function() {
expect(1);
var o1aa = new KJUR.asn1.x509.GeneralNames([{'uri':'http://aaa.com/'}]);
var o1a = new KJUR.asn1.x509.DistributionPointName(o1aa);
var o1 = new KJUR.asn1.x509.DistributionPoint({'dpobj': o1a});
equal(o1.getEncodedHex(), "3015a013a011860f687474703a2f2f6161612e636f6d2f", "constructor dpobj http://aaa.com/");
});
test("OID class test", function() {
var o = KJUR.asn1.x509.OID;
equal(o.atype2obj('C').getEncodedHex(), "0603550406", "C");
equal(o.name2obj('SHA1withRSA').getEncodedHex(),
"06092a864886f70d010105", "name2obj SHA1withRSA");
equal(o.name2oid('basicConstraints'), '2.5.29.19', "name2oid basicConstraints");
equal(o.name2oid('UNKNOWNOIDNAME'), '', "name2oid unknown name");
equal(o.oid2name('2.5.29.19'), 'basicConstraints', "oid2name basicConstraints");
equal(o.oid2name('0.0.0.0'), '', "oid2name unknown oid");
});
// BasicConstraints
test("BasicConstraints class test", function() {
expect(6);
var o1 = new KJUR.asn1.x509.BasicConstraints({});
equal(o1.getExtnValueHex(), "3000", "constructor cA=f getExtnValueHex");
equal(o1.getEncodedHex(), "30090603551d1304023000", "constructor cA=f getEncodedHex");
var o2 = new KJUR.asn1.x509.BasicConstraints({'cA':true});
equal(o2.getExtnValueHex(), "30030101ff", "constructor cA=t getExtnValueHex");
equal(o2.getEncodedHex(), "300c0603551d13040530030101ff", "constructor cA=t getEncodedHex");
var o3 = new KJUR.asn1.x509.BasicConstraints({'cA':true, 'pathLen': 7});
equal(o3.getExtnValueHex(), "30060101ff020107", "constructor cA=t pl=7 getExtnValueHex");
equal(o3.getEncodedHex(), "300f0603551d13040830060101ff020107", "constructor cA=t pl=7 getEncodedHex");
});
// KeyUsage
test("KeyUsage class test", function() {
expect(3);
var o = new KJUR.asn1.x509.KeyUsage({'bin':'11'});
equal(o.getExtnValueHex(), "030206c0", "constructor bin 11 getExtnValueHex");
equal(o.getEncodedHex(), "300b0603551d0f0404030206c0", "constructor bin 11 getEncodedHex");
var o2 = new KJUR.asn1.x509.KeyUsage({'bin':'11', 'critical': true});
equal(o2.getEncodedHex(), "300e0603551d0f0101ff0404030206c0", "constructor bin 11 critical getEncodedHex");
});
// CRLDP
test("CRLDistributionPoints class test", function() {
expect(2);
var gn1 = new KJUR.asn1.x509.GeneralNames([{'uri':'http://aaa.com/'}]);
var dpn1 = new KJUR.asn1.x509.DistributionPointName(gn1);
var dp1 = new KJUR.asn1.x509.DistributionPoint({'dpobj': dpn1});
var cdp1 = new KJUR.asn1.x509.CRLDistributionPoints({'array': [dp1]});
equal(cdp1.getEncodedHex(), "30200603551d1f041930173015a013a011860f687474703a2f2f6161612e636f6d2f", "constructor array http://aaa.com/");
var cdp2 = new KJUR.asn1.x509.CRLDistributionPoints({'uri': 'http://aaa.com/'});
equal(cdp2.getEncodedHex(), "30200603551d1f041930173015a013a011860f687474703a2f2f6161612e636f6d2f", "constructor uri http://aaa.com/");
});
// ExtKeyUsage
test("ExtKeyUsage class test", function() {
expect(1);
var eku1 =
new KJUR.asn1.x509.ExtKeyUsage({'array':
[{'oid': '2.5.29.37.0'}, // anyExtendedKeyUsage
{'name': 'clientAuth'}]});
equal(eku1.getEncodedHex(), "30190603551d25041230100604551d250006082b06010505070302", "constructor array");
});
// AuthorityKeyIdentifier
test("AuthorityKeyIdentifier class test (KID)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'kid': {'hex': '89ab'}});
equal(o1.getExtnValueHex(), "3004800289ab", "kid value");
equal(o1.getEncodedHex(), "300d0603551d2304063004800289ab", "ext hex");
});
test("AuthorityKeyIdentifier class test (CertIssuer)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'issuer': {'str': '/C=US/CN=a'}});
equal(o1.getExtnValueHex(), "301ba119310b3009060355040613025553310a300806035504030c0161", "issuer name");
equal(o1.getEncodedHex(), "30240603551d23041d301ba119310b3009060355040613025553310a300806035504030c0161", "ext hex");
});
test("AuthorityKeyIdentifier class test (CertSN)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'sn': {'hex': '1234'}});
equal(o1.getExtnValueHex(), "300482021234", "cert SN");
equal(o1.getEncodedHex(), "300d0603551d230406300482021234", "ext hex");
});
test("AuthorityKeyIdentifier class test (All)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'kid': {'hex': '89ab'},
'issuer': {'str': '/C=US/CN=a'},
'sn': {'hex': '1234'}});
equal(o1.getExtnValueHex(), "3023800289aba119310b3009060355040613025553310a300806035504030c016182021234", "all");
equal(o1.getEncodedHex(), "302c0603551d2304253023800289aba119310b3009060355040613025553310a300806035504030c016182021234", "ext hex");
});
test("AuthorityKeyIdentifier class test (KID critical)", function() {
expect(2);
var o1 = new KJUR.asn1.x509.AuthorityKeyIdentifier({'kid': {'hex': '89ab'}, 'critical': true});
equal(o1.getExtnValueHex(), "3004800289ab", "kid critical");
equal(o1.getEncodedHex(), "30100603551d230101ff04063004800289ab", "ext hex");
});
// ==== END OF X.509V3 EXTENSION TEST ===================
test("CRL class test", function() {
expect(1);
// TBS
var o = new KJUR.asn1.x509.TBSCertList();
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setThisUpdateByParam({'str': '130504235959Z'});
o.setNextUpdateByParam({'str': '130604235959Z'});
var prvKey = new RSAKey();
prvKey.readPrivateKeyFromASN1HexString("3082013a020100024100e8664dd2b40529121568f3b39bc97a62e7ba3c09babdc4f0dcd8df90eb790b9bb645a2b70e3112747b4d3c41b51424895115fef88f79d43eae5b1a4e3518fd590203010001024078bbc54c646795e9a623cb0f912c7f9f6861711560e57bade21ded2f7d9579f86272fab9e71ab27282c2760c404dae6ac8a3ab852cf6bcd562f9aff8247a264d022100fe9bd450866b3255614fde976a76ac0b1d5830dda64f5359b946d8512bc1239f022100e9ab680f5f05dbb0f4311b0e6f4368f4874a1238979d8bc600c35c6f20707c07022100d549cb698dc17d4fe30e5a84f3ade860033c1eeb7f67d286465c9fd817d45b3702201849b4bb44493b989d092da2c675df46eb790b83ce5e95d4b2e79b88017b2fa902207d261a96256d49b020cb1d587ecde127e093a4d2b34cdbff171f34125b5857a9");
var crl1 = new KJUR.asn1.x509.CRL({'tbsobj': o,'rsaprvkey': prvKey});
crl1.sign();
equal(crl1.getEncodedHex(), "30819c3048300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161170d3133303530343233353935395a170d3133303630343233353935395a300d06092a864886f70d0101050500034100161f6e8b3cbe992aa4eece8894516a65d530543c6f23e83860cc391ae8289504cbe91f118fd20e2b96966182f695f9dce27b3e76f7d84beeab293cc3c9649740", "crl sign");
});
test("TBSCertList class test", function() {
expect(1);
var o = new KJUR.asn1.x509.TBSCertList();
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setThisUpdateByParam({'str': '130504235959Z'});
o.setNextUpdateByParam({'str': '130604235959Z'});
equal(o.getEncodedHex(), "3048300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161170d3133303530343233353935395a170d3133303630343233353935395a", "constructor");
});
test("TBSCertList 2 class test", function() {
expect(1);
var o = new KJUR.asn1.x509.TBSCertList();
o.setSignatureAlgByParam({'name': 'SHA1withRSA'});
o.setIssuerByParam({'str': '/C=US/O=a'});
o.setThisUpdateByParam({'str': '130504235959Z'});
o.setNextUpdateByParam({'str': '130604235959Z'});
o.addRevokedCert({'int': 4}, {'str':'130514235959Z'});
equal(o.getEncodedHex(), "305e300d06092a864886f70d01010505003019310b3009060355040613025553310a3008060355040a0c0161170d3133303530343233353935395a170d3133303630343233353935395a30143012020104170d3133303531343233353935395a", "constructor with revoked cert");
});
test("CRLEntry class test", function() {
expect(1);
var e = new KJUR.asn1.x509.CRLEntry({'time':{'str':'130514235959Z'}, 'sn':{'int':3}});
equal(e.getEncodedHex(), "3012020103170d3133303531343233353935395a", "constructor/1");
});
test("X509Util.getPKCS8PubKeyPEMfromRSAKey", function() {
var s = "" +
"-----BEGIN PUBLIC KEY-----\r\n" +
"MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAOtpGHibL8Ue+MXPPufkcrNES40rCT5L\r\n" +
"RIU9MjTZ8/7owG5bAsiFA9Xxh3uZK1T5QA64jNJVbp2ojHAtNyWPuwsCAwEAAQ==\r\n" +
"-----END PUBLIC KEY-----\r\n";
var rsaKey = new RSAKey();
rsaKey.setPublic("eb6918789b2fc51ef8c5cf3ee7e472b3444b8d2b093e4b44853d3234d9f3fee8c06e5b02c88503d5f1877b992b54f9400eb88cd2556e9da88c702d37258fbb0b", "10001"); // z1.pubp8.der
var pem = KJUR.asn1.x509.X509Util.getPKCS8PubKeyPEMfromRSAKey(rsaKey);
equal(pem, s, "z1.pubp8.pem");
});
});
-->
</script>
</head>
<body>
<div id="qunit"></div>
<div id="qunit-fixture">test markup</div>
<a href="index.html">TEST INDEX</a> |
</body>
</html>