using Mconn;
|
|
|
|
void test_generate() {
|
|
string key_path = "/tmp/test-key-vala.pem";
|
|
string cert_path = "/tmp/test-cert-vala.pem";
|
|
FileUtils.remove(key_path);
|
|
FileUtils.remove(cert_path);
|
|
|
|
assert(FileUtils.test(key_path, FileTest.EXISTS) == false);
|
|
try {
|
|
Crypt.generate_key_cert(key_path, cert_path, "foo");
|
|
} catch (Error e) {
|
|
warning("generate failed: %s", e.message);
|
|
Test.fail();
|
|
}
|
|
assert(FileUtils.test(key_path, FileTest.EXISTS) == true);
|
|
assert(FileUtils.test(cert_path, FileTest.EXISTS) == true);
|
|
}
|
|
|
|
void test_generate_load() {
|
|
string key_path = "/tmp/test-key-vala.pem";
|
|
string cert_path = "/tmp/test-cert-vala.pem";
|
|
FileUtils.remove(key_path);
|
|
FileUtils.remove(cert_path);
|
|
|
|
try {
|
|
Crypt.generate_key_cert(key_path, cert_path, "bar");
|
|
} catch (Error e) {
|
|
warning("generate failed: %s", e.message);
|
|
Test.fail();
|
|
}
|
|
|
|
try {
|
|
var cert = new TlsCertificate.from_files(cert_path,
|
|
key_path);
|
|
} catch (Error e) {
|
|
warning("load from files failed: %s", e.message);
|
|
Test.fail();
|
|
}
|
|
}
|
|
|
|
void test_custom_cn() {
|
|
string key_path = "/tmp/test-key-vala.pem";
|
|
string cert_path = "/tmp/test-cert-vala.pem";
|
|
FileUtils.remove(key_path);
|
|
FileUtils.remove(cert_path);
|
|
|
|
try {
|
|
Crypt.generate_key_cert(key_path, cert_path, "custom-cn");
|
|
} catch (Error e) {
|
|
warning("generate failed: %s", e.message);
|
|
Test.fail();
|
|
}
|
|
|
|
uint8[] data;
|
|
try {
|
|
File.new_for_path(cert_path).load_contents(null, out data, null);
|
|
} catch (Error e) {
|
|
warning("load contents failed: %s", e.message);
|
|
Test.fail();
|
|
}
|
|
|
|
var datum = GnuTLS.Datum() { data=data, size=data.length };
|
|
|
|
var cert = GnuTLS.X509.Certificate.create();
|
|
var res = cert.import(ref datum, GnuTLS.X509.CertificateFormat.PEM);
|
|
assert(res == GnuTLS.ErrorCode.SUCCESS);
|
|
|
|
// verify DN
|
|
var dn = new uint8[1024];
|
|
size_t sz = dn.length;
|
|
cert.get_dn(dn, ref sz);
|
|
debug("dn: %s\n", (string)dn);
|
|
|
|
var issuer_dn = new uint8[1024];
|
|
sz = issuer_dn.length;
|
|
cert.get_issuer_dn(issuer_dn, ref sz);
|
|
debug("dn: %s\n", (string)issuer_dn);
|
|
|
|
var subject = (string)dn;
|
|
var issuer = (string)issuer_dn;
|
|
|
|
// verify that the certificate is self signed
|
|
assert(subject == issuer);
|
|
//
|
|
assert("CN=custom-cn" in subject);
|
|
}
|
|
|
|
public static void main(string[] args) {
|
|
Test.init(ref args);
|
|
|
|
Test.add_func("/mconn-crypt-vala/generated", test_generate);
|
|
Test.add_func("/mconn-crypt-vala/load", test_generate_load);
|
|
Test.add_func("/mconn-crypt-vala/verify-cn", test_custom_cn);
|
|
Test.run();
|
|
}
|