/* * SPDX-License-Identifier: LGPL-2.0+ * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) any later version. * * This 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General * Public License along with this library. If not, see . */ #include "config.h" #include #include "ostree-blob-reader-private.h" static const guint8 pubkey_ed25519[] = { 0x30, 0x2a, 0x30, 0x05, 0x06, 0x03, 0x2b, 0x65, 0x70, 0x03, 0x21, 0x00, 0x36, 0x09, 0x06, 0x69, 0xf3, 0x52, 0xb1, 0xe3, 0x7e, 0xd4, 0xb5, 0xe3, 0x4c, 0x52, 0x6b, 0x7d, 0xdb, 0xba, 0x37, 0x6a, 0xac, 0xe6, 0xb9, 0x5f, 0xf5, 0xdd, 0xf1, 0x95, 0xa5, 0x5c, 0x96, 0x09 }; static const gchar pem_pubkey_ed25519[] = "-----BEGIN PUBLIC KEY-----\n" "MCowBQYDK2VwAyEANgkGafNSseN+1LXjTFJrfdu6N2qs5rlf9d3xlaVclgk=\n" "-----END PUBLIC KEY-----\n"; static const gchar pem_pubkey_ed25519_whitespace[] = "-----BEGIN PUBLIC KEY-----\n" " \n" "MCowBQYDK2VwAyEANgkGafNSseN+1LXjTFJrfdu6N2qs5rlf9d3xlaVclgk=\n" "-----END PUBLIC KEY-----\n"; static const gchar pem_pubkey_empty[] = ""; static const gchar pem_pubkey_ed25519_no_trailer[] = "-----BEGIN PUBLIC KEY-----\n" "MCowBQYDK2VwAyEANgkGafNSseN+1LXjTFJrfdu6N2qs5rlf9d3xlaVclgk=\n"; static const gchar pem_pubkey_ed25519_label_mismatch[] = "-----BEGIN PUBLIC KEY X-----\n" "MCowBQYDK2VwAyEANgkGafNSseN+1LXjTFJrfdu6N2qs5rlf9d3xlaVclgk=\n" "-----END PUBLIC KEY Y-----\n"; static void test_ostree_read_pem_block_valid (void) { static const struct { const gchar *pem_data; gsize pem_size; const gchar *label; const guint8 *data; gsize size; } tests[] = { { pem_pubkey_ed25519, sizeof (pem_pubkey_ed25519), "PUBLIC KEY", pubkey_ed25519, sizeof (pubkey_ed25519) }, { pem_pubkey_ed25519_whitespace, sizeof (pem_pubkey_ed25519_whitespace), "PUBLIC KEY", pubkey_ed25519, sizeof (pubkey_ed25519) }, { pem_pubkey_empty, sizeof (pem_pubkey_empty), NULL, NULL, 0 }, }; for (gsize i = 0; i < G_N_ELEMENTS (tests); i++) { g_autoptr (GInputStream) stream = g_memory_input_stream_new_from_data (tests[i].pem_data, tests[i].pem_size, NULL); g_autoptr (GDataInputStream) data_stream = g_data_input_stream_new (stream); g_autofree char *label = NULL; g_autoptr (GBytes) bytes = NULL; g_autoptr (GError) error = NULL; bytes = _ostree_read_pem_block (data_stream, &label, NULL, &error); g_assert_no_error (error); g_assert_cmpstr (label, ==, tests[i].label); if (tests[i].data) { g_autoptr (GBytes) expected_bytes = g_bytes_new_static (tests[i].data, tests[i].size); g_assert (g_bytes_equal (bytes, expected_bytes)); } } } static void test_ostree_read_pem_block_invalid (void) { static const struct { const gchar *pem_data; gsize pem_size; } tests[] = { { pem_pubkey_ed25519_no_trailer, sizeof (pem_pubkey_ed25519_no_trailer) }, { pem_pubkey_ed25519_label_mismatch, sizeof (pem_pubkey_ed25519_label_mismatch) }, }; for (gsize i = 0; i < G_N_ELEMENTS (tests); i++) { g_autoptr (GInputStream) stream = g_memory_input_stream_new_from_data (tests[i].pem_data, tests[i].pem_size, NULL); g_autoptr (GDataInputStream) data_stream = g_data_input_stream_new (stream); g_autofree char *label = NULL; g_autoptr (GBytes) bytes = NULL; g_autoptr (GError) error = NULL; bytes = _ostree_read_pem_block (data_stream, &label, NULL, &error); g_assert_null (bytes); g_assert_null (label); g_assert_nonnull (error); } } int main (int argc, char **argv) { g_test_init (&argc, &argv, NULL); g_test_add_func ("/ostree_read_pem_block/valid", test_ostree_read_pem_block_valid); g_test_add_func ("/ostree_read_pem_block/invalid", test_ostree_read_pem_block_invalid); return g_test_run (); }