/* -*- 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 (); }