/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 8; tab-width: 8 -*- */
/* test-object.c: Test GkmObject
Copyright (C) 2012 Stefan Walter
The Gnome Keyring Library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library General Public License as
published by the Free Software Foundation; either version 2 of the
License, or (at your option) any later version.
The Gnome Keyring Library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Library General Public License for more details.
You should have received a copy of the GNU Library General Public
License along with the Gnome Library; see the file COPYING.LIB. If not,
.
Author: Stef Walter
*/
#include "config.h"
#include "mock-module.h"
#include "gkm/gkm-attributes.h"
#include "gkm/gkm-certificate.h"
#include "gkm/gkm-object.h"
#include "gkm/gkm-module.h"
#include "gkm/gkm-serializable.h"
#include "gkm/gkm-session.h"
#include "gkm/gkm-test.h"
#include "egg/egg-testing.h"
#include "pkcs11i.h"
typedef struct {
GkmModule *module;
GkmSession *session;
GBytes *certificate_data;
GkmCertificate *certificate;
} Test;
static void
setup_basic (Test* test,
gconstpointer unused)
{
gchar *data;
gsize length;
test->module = mock_module_initialize_and_enter ();
test->session = mock_module_open_session (TRUE);
if (!g_file_get_contents (SRCDIR "/pkcs11/gkm/fixtures/test-certificate-1.der", &data, &length, NULL))
g_assert_not_reached ();
test->certificate_data = g_bytes_new_take (data, length);
}
static void
teardown_basic (Test* test,
gconstpointer unused)
{
g_bytes_unref (test->certificate_data);
mock_module_leave_and_finalize ();
}
static GkmCertificate *
create_certificate_object (GkmSession *session,
GBytes *data)
{
GkmCertificate *certificate;
certificate = g_object_new (GKM_TYPE_CERTIFICATE,
"unique", "test-certificate",
"module", gkm_session_get_module (session),
"manager", gkm_session_get_manager (session),
NULL);
if (!gkm_serializable_load (GKM_SERIALIZABLE (certificate), NULL, data))
g_assert_not_reached ();
return certificate;
}
static void
setup (Test *test,
gconstpointer unused)
{
setup_basic (test, unused);
test->certificate = create_certificate_object (test->session, test->certificate_data);
}
static void
teardown (Test *test,
gconstpointer unused)
{
g_clear_object (&test->certificate);
teardown_basic (test, unused);
}
static void
test_attribute_check_value (Test* test,
gconstpointer unused)
{
gpointer data;
gsize n_data;
data = gkm_object_get_attribute_data (GKM_OBJECT (test->certificate),
test->session, CKA_CHECK_VALUE, &n_data);
egg_assert_cmpmem (data, n_data, ==, "\x36\x86\x35", 3);
g_free (data);
}
static void
test_attribute_issuer (Test* test,
gconstpointer unused)
{
gpointer data;
gsize n_data;
data = gkm_object_get_attribute_data (GKM_OBJECT (test->certificate),
test->session, CKA_ISSUER, &n_data);
egg_assert_cmpmem (data, n_data, ==, "\x30\x81\xCF\x31\x0B\x30\x09\x06\x03\x55\x04\x06\x13\x02\x5A\x41\x31\x15\x30\x13\x06\x03\x55\x04\x08\x13\x0C\x57\x65\x73\x74\x65\x72\x6E\x20\x43\x61\x70\x65\x31\x12\x30\x10\x06\x03\x55\x04\x07\x13\x09\x43\x61\x70\x65\x20\x54\x6F\x77\x6E\x31\x1A\x30\x18\x06\x03\x55\x04\x0A\x13\x11\x54\x68\x61\x77\x74\x65\x20\x43\x6F\x6E\x73\x75\x6C\x74\x69\x6E\x67\x31\x28\x30\x26\x06\x03\x55\x04\x0B\x13\x1F\x43\x65\x72\x74\x69\x66\x69\x63\x61\x74\x69\x6F\x6E\x20\x53\x65\x72\x76\x69\x63\x65\x73\x20\x44\x69\x76\x69\x73\x69\x6F\x6E\x31\x23\x30\x21\x06\x03\x55\x04\x03\x13\x1A\x54\x68\x61\x77\x74\x65\x20\x50\x65\x72\x73\x6F\x6E\x61\x6C\x20\x50\x72\x65\x6D\x69\x75\x6D\x20\x43\x41\x31\x2A\x30\x28\x06\x09\x2A\x86\x48\x86\xF7\x0D\x01\x09\x01\x16\x1B\x70\x65\x72\x73\x6F\x6E\x61\x6C\x2D\x70\x72\x65\x6D\x69\x75\x6D\x40\x74\x68\x61\x77\x74\x65\x2E\x63\x6F\x6D", 210);
g_free (data);
}
static void
test_attribute_subject (Test* test,
gconstpointer unused)
{
gpointer data;
gsize n_data;
data = gkm_object_get_attribute_data (GKM_OBJECT (test->certificate),
test->session, CKA_SUBJECT, &n_data);
egg_assert_cmpmem (data, n_data, ==, "\x30\x81\xCF\x31\x0B\x30\x09\x06\x03\x55\x04\x06\x13\x02\x5A\x41\x31\x15\x30\x13\x06\x03\x55\x04\x08\x13\x0C\x57\x65\x73\x74\x65\x72\x6E\x20\x43\x61\x70\x65\x31\x12\x30\x10\x06\x03\x55\x04\x07\x13\x09\x43\x61\x70\x65\x20\x54\x6F\x77\x6E\x31\x1A\x30\x18\x06\x03\x55\x04\x0A\x13\x11\x54\x68\x61\x77\x74\x65\x20\x43\x6F\x6E\x73\x75\x6C\x74\x69\x6E\x67\x31\x28\x30\x26\x06\x03\x55\x04\x0B\x13\x1F\x43\x65\x72\x74\x69\x66\x69\x63\x61\x74\x69\x6F\x6E\x20\x53\x65\x72\x76\x69\x63\x65\x73\x20\x44\x69\x76\x69\x73\x69\x6F\x6E\x31\x23\x30\x21\x06\x03\x55\x04\x03\x13\x1A\x54\x68\x61\x77\x74\x65\x20\x50\x65\x72\x73\x6F\x6E\x61\x6C\x20\x50\x72\x65\x6D\x69\x75\x6D\x20\x43\x41\x31\x2A\x30\x28\x06\x09\x2A\x86\x48\x86\xF7\x0D\x01\x09\x01\x16\x1B\x70\x65\x72\x73\x6F\x6E\x61\x6C\x2D\x70\x72\x65\x6D\x69\x75\x6D\x40\x74\x68\x61\x77\x74\x65\x2E\x63\x6F\x6D", 210);
g_free (data);
}
static void
test_attribute_serial_number (Test* test,
gconstpointer unused)
{
gpointer data;
gsize n_data;
data = gkm_object_get_attribute_data (GKM_OBJECT (test->certificate),
test->session, CKA_SERIAL_NUMBER, &n_data);
egg_assert_cmpmem (data, n_data, ==, "\x02\x01\x00", 3);
g_free (data);
}
static void
test_attribute_value (Test* test,
gconstpointer unused)
{
gconstpointer raw;
gpointer data;
gsize n_data, n_raw;
data = gkm_object_get_attribute_data (GKM_OBJECT (test->certificate),
test->session, CKA_VALUE, &n_data);
raw = g_bytes_get_data (test->certificate_data, NULL);
n_raw = g_bytes_get_size (test->certificate_data);
egg_assert_cmpmem (data, n_data, ==, raw, n_raw);
g_free (data);
}
static void
test_hash (Test* test,
gconstpointer unused)
{
gpointer hash;
gsize n_hash;
hash = gkm_certificate_hash (test->certificate, GCRY_MD_SHA1, &n_hash);
egg_assert_cmpmem (hash, n_hash, ==, "\x36\x86\x35\x63\xFD\x51\x28\xC7\xBE\xA6\xF0\x05\xCF\xE9\xB4\x36\x68\x08\x6C\xCE", 20);
g_free (hash);
}
int
main (int argc, char **argv)
{
#if !GLIB_CHECK_VERSION(2,35,0)
g_type_init ();
#endif
g_test_init (&argc, &argv, NULL);
g_test_add ("/gkm/certificate/issuer", Test, NULL, setup, test_attribute_issuer, teardown);
g_test_add ("/gkm/certificate/subject", Test, NULL, setup, test_attribute_subject, teardown);
g_test_add ("/gkm/certificate/check-value", Test, NULL, setup, test_attribute_check_value, teardown);
g_test_add ("/gkm/certificate/serial-number", Test, NULL, setup, test_attribute_serial_number, teardown);
g_test_add ("/gkm/certificate/value", Test, NULL, setup, test_attribute_value, teardown);
g_test_add ("/gkm/certificate/hash", Test, NULL, setup, test_hash, teardown);
return egg_tests_run_in_thread_with_loop ();
}