Blame gck/gck-test.c

Packit b00eeb
/*
Packit b00eeb
 * gnome-keyring
Packit b00eeb
 *
Packit b00eeb
 * Copyright (C) 2010 Stefan Walter
Packit b00eeb
 *
Packit b00eeb
 * This program is free software; you can redistribute it and/or modify
Packit b00eeb
 * it under the terms of the GNU Lesser General Public License as
Packit b00eeb
 * published by the Free Software Foundation; either version 2.1 of
Packit b00eeb
 * the License, or (at your option) any later version.
Packit b00eeb
 *
Packit b00eeb
 * This program is distributed in the hope that it will be useful, but
Packit b00eeb
 * WITHOUT ANY WARRANTY; without even the implied warranty of
Packit b00eeb
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit b00eeb
 * Lesser General Public License for more details.
Packit b00eeb
 *
Packit b00eeb
 * You should have received a copy of the GNU Lesser General Public
Packit b00eeb
 * License along with this program; if not, see <http://www.gnu.org/licenses/>.
Packit b00eeb
 */
Packit b00eeb
Packit b00eeb
#include "config.h"
Packit b00eeb
Packit b00eeb
#include "gck-test.h"
Packit b00eeb
Packit b00eeb
#include <p11-kit/pkcs11.h>
Packit b00eeb
Packit b00eeb
#include <glib.h>
Packit b00eeb
Packit b00eeb
#include <string.h>
Packit b00eeb
Packit b00eeb
static const gchar*
Packit b00eeb
defined_rv_to_string (CK_RV rv)
Packit b00eeb
{
Packit b00eeb
	#define GKM_X(rv) case rv: return #rv;
Packit b00eeb
	switch (rv) {
Packit b00eeb
Packit b00eeb
	/* These are not really errors, or not current */
Packit b00eeb
	GKM_X (CKR_OK)
Packit b00eeb
	GKM_X (CKR_NO_EVENT)
Packit b00eeb
	GKM_X (CKR_FUNCTION_NOT_PARALLEL)
Packit b00eeb
	GKM_X (CKR_SESSION_PARALLEL_NOT_SUPPORTED)
Packit b00eeb
	GKM_X (CKR_CANCEL)
Packit b00eeb
	GKM_X (CKR_FUNCTION_CANCELED)
Packit b00eeb
	GKM_X (CKR_HOST_MEMORY)
Packit b00eeb
	GKM_X (CKR_SLOT_ID_INVALID)
Packit b00eeb
	GKM_X (CKR_GENERAL_ERROR)
Packit b00eeb
	GKM_X (CKR_FUNCTION_FAILED)
Packit b00eeb
	GKM_X (CKR_ARGUMENTS_BAD)
Packit b00eeb
	GKM_X (CKR_NEED_TO_CREATE_THREADS)
Packit b00eeb
	GKM_X (CKR_CANT_LOCK)
Packit b00eeb
	GKM_X (CKR_ATTRIBUTE_READ_ONLY)
Packit b00eeb
	GKM_X (CKR_ATTRIBUTE_SENSITIVE)
Packit b00eeb
	GKM_X (CKR_ATTRIBUTE_TYPE_INVALID)
Packit b00eeb
	GKM_X (CKR_ATTRIBUTE_VALUE_INVALID)
Packit b00eeb
	GKM_X (CKR_DATA_INVALID)
Packit b00eeb
	GKM_X (CKR_DATA_LEN_RANGE)
Packit b00eeb
	GKM_X (CKR_DEVICE_ERROR)
Packit b00eeb
	GKM_X (CKR_DEVICE_MEMORY)
Packit b00eeb
	GKM_X (CKR_DEVICE_REMOVED)
Packit b00eeb
	GKM_X (CKR_ENCRYPTED_DATA_INVALID)
Packit b00eeb
	GKM_X (CKR_ENCRYPTED_DATA_LEN_RANGE)
Packit b00eeb
	GKM_X (CKR_FUNCTION_NOT_SUPPORTED)
Packit b00eeb
	GKM_X (CKR_KEY_HANDLE_INVALID)
Packit b00eeb
	GKM_X (CKR_KEY_SIZE_RANGE)
Packit b00eeb
	GKM_X (CKR_KEY_TYPE_INCONSISTENT)
Packit b00eeb
	GKM_X (CKR_KEY_NOT_NEEDED)
Packit b00eeb
	GKM_X (CKR_KEY_CHANGED)
Packit b00eeb
	GKM_X (CKR_KEY_NEEDED)
Packit b00eeb
	GKM_X (CKR_KEY_INDIGESTIBLE)
Packit b00eeb
	GKM_X (CKR_KEY_FUNCTION_NOT_PERMITTED)
Packit b00eeb
	GKM_X (CKR_KEY_NOT_WRAPPABLE)
Packit b00eeb
	GKM_X (CKR_KEY_UNEXTRACTABLE)
Packit b00eeb
	GKM_X (CKR_MECHANISM_INVALID)
Packit b00eeb
	GKM_X (CKR_MECHANISM_PARAM_INVALID)
Packit b00eeb
	GKM_X (CKR_OBJECT_HANDLE_INVALID)
Packit b00eeb
	GKM_X (CKR_OPERATION_ACTIVE)
Packit b00eeb
	GKM_X (CKR_OPERATION_NOT_INITIALIZED)
Packit b00eeb
	GKM_X (CKR_PIN_INCORRECT)
Packit b00eeb
	GKM_X (CKR_PIN_INVALID)
Packit b00eeb
	GKM_X (CKR_PIN_LEN_RANGE)
Packit b00eeb
	GKM_X (CKR_PIN_EXPIRED)
Packit b00eeb
	GKM_X (CKR_PIN_LOCKED)
Packit b00eeb
	GKM_X (CKR_SESSION_CLOSED)
Packit b00eeb
	GKM_X (CKR_SESSION_COUNT)
Packit b00eeb
	GKM_X (CKR_SESSION_HANDLE_INVALID)
Packit b00eeb
	GKM_X (CKR_SESSION_READ_ONLY)
Packit b00eeb
	GKM_X (CKR_SESSION_EXISTS)
Packit b00eeb
	GKM_X (CKR_SESSION_READ_ONLY_EXISTS)
Packit b00eeb
	GKM_X (CKR_SESSION_READ_WRITE_SO_EXISTS)
Packit b00eeb
	GKM_X (CKR_SIGNATURE_INVALID)
Packit b00eeb
	GKM_X (CKR_SIGNATURE_LEN_RANGE)
Packit b00eeb
	GKM_X (CKR_TEMPLATE_INCOMPLETE)
Packit b00eeb
	GKM_X (CKR_TEMPLATE_INCONSISTENT)
Packit b00eeb
	GKM_X (CKR_TOKEN_NOT_PRESENT)
Packit b00eeb
	GKM_X (CKR_TOKEN_NOT_RECOGNIZED)
Packit b00eeb
	GKM_X (CKR_TOKEN_WRITE_PROTECTED)
Packit b00eeb
	GKM_X (CKR_UNWRAPPING_KEY_HANDLE_INVALID)
Packit b00eeb
	GKM_X (CKR_UNWRAPPING_KEY_SIZE_RANGE)
Packit b00eeb
	GKM_X (CKR_UNWRAPPING_KEY_TYPE_INCONSISTENT)
Packit b00eeb
	GKM_X (CKR_USER_ALREADY_LOGGED_IN)
Packit b00eeb
	GKM_X (CKR_USER_NOT_LOGGED_IN)
Packit b00eeb
	GKM_X (CKR_USER_PIN_NOT_INITIALIZED)
Packit b00eeb
	GKM_X (CKR_USER_TYPE_INVALID)
Packit b00eeb
	GKM_X (CKR_USER_ANOTHER_ALREADY_LOGGED_IN)
Packit b00eeb
	GKM_X (CKR_USER_TOO_MANY_TYPES)
Packit b00eeb
	GKM_X (CKR_WRAPPED_KEY_INVALID)
Packit b00eeb
	GKM_X (CKR_WRAPPED_KEY_LEN_RANGE)
Packit b00eeb
	GKM_X (CKR_WRAPPING_KEY_HANDLE_INVALID)
Packit b00eeb
	GKM_X (CKR_WRAPPING_KEY_SIZE_RANGE)
Packit b00eeb
	GKM_X (CKR_WRAPPING_KEY_TYPE_INCONSISTENT)
Packit b00eeb
	GKM_X (CKR_RANDOM_SEED_NOT_SUPPORTED)
Packit b00eeb
	GKM_X (CKR_RANDOM_NO_RNG)
Packit b00eeb
	GKM_X (CKR_DOMAIN_PARAMS_INVALID)
Packit b00eeb
	GKM_X (CKR_BUFFER_TOO_SMALL)
Packit b00eeb
	GKM_X (CKR_SAVED_STATE_INVALID)
Packit b00eeb
	GKM_X (CKR_INFORMATION_SENSITIVE)
Packit b00eeb
	GKM_X (CKR_STATE_UNSAVEABLE)
Packit b00eeb
	GKM_X (CKR_CRYPTOKI_NOT_INITIALIZED)
Packit b00eeb
	GKM_X (CKR_CRYPTOKI_ALREADY_INITIALIZED)
Packit b00eeb
	GKM_X (CKR_MUTEX_BAD)
Packit b00eeb
	GKM_X (CKR_MUTEX_NOT_LOCKED)
Packit b00eeb
	GKM_X (CKR_FUNCTION_REJECTED)
Packit b00eeb
	default:
Packit b00eeb
		return NULL;
Packit b00eeb
	}
Packit b00eeb
Packit b00eeb
	#undef GKM_X
Packit b00eeb
}
Packit b00eeb
Packit b00eeb
static gchar*
Packit b00eeb
rv_to_string (CK_RV rv)
Packit b00eeb
{
Packit b00eeb
	gchar *string = g_strdup (defined_rv_to_string (rv));
Packit b00eeb
	if (string == NULL)
Packit b00eeb
		string = g_strdup_printf ("0x%08lx", (gulong)rv);
Packit b00eeb
	return string;
Packit b00eeb
}
Packit b00eeb
Packit b00eeb
void
Packit b00eeb
gck_assertion_message_cmprv (const gchar *domain, const gchar *file, gint line,
Packit b00eeb
                             const gchar *func, const gchar *expr,
Packit b00eeb
                             CK_RV arg1, const gchar *cmp, CK_RV arg2)
Packit b00eeb
{
Packit b00eeb
	gchar *a1, *a2, *s;
Packit b00eeb
	a1 = rv_to_string (arg1);
Packit b00eeb
	a2 = rv_to_string (arg2);
Packit b00eeb
	s = g_strdup_printf ("assertion failed (%s): (%s %s %s)", expr, a1, cmp, a2);
Packit b00eeb
	g_free (a1);
Packit b00eeb
	g_free (a2);
Packit b00eeb
	g_assertion_message (domain, file, line, func, s);
Packit b00eeb
	g_free (s);
Packit b00eeb
}
Packit b00eeb
Packit b00eeb
void
Packit b00eeb
gck_assertion_message_cmpulong (const gchar *domain, const gchar *file, gint line,
Packit b00eeb
                                const gchar *func, const gchar *expr,
Packit b00eeb
                                CK_ULONG arg1, const gchar *cmp, CK_ULONG arg2)
Packit b00eeb
{
Packit b00eeb
	char *s = NULL;
Packit b00eeb
	s = g_strdup_printf ("assertion failed (%s): (0x%08llx %s 0x%08llx)", expr,
Packit b00eeb
	                     (long long unsigned)arg1, cmp, (long long unsigned)arg2);
Packit b00eeb
	g_assertion_message (domain, file, line, func, s);
Packit b00eeb
	g_free (s);
Packit b00eeb
}