From a421aa306f421fcf7ba150c8402b79f990caa12d Mon Sep 17 00:00:00 2001 From: Nickolay Olshevsky Date: Wed, 9 Oct 2024 16:21:11 +0300 Subject: [PATCH] Update code and tests to slightly improve coverage. --- src/librepgp/stream-dump.cpp | 38 +++++++++++++++++------------------- src/tests/cli_tests.py | 37 ++++++++++++++++++++++++++++------- 2 files changed, 48 insertions(+), 27 deletions(-) diff --git a/src/librepgp/stream-dump.cpp b/src/librepgp/stream-dump.cpp index 82f47e042e..6d475ef8dd 100644 --- a/src/librepgp/stream-dump.cpp +++ b/src/librepgp/stream-dump.cpp @@ -422,15 +422,11 @@ dst_print_str(pgp_dest_t *dst, const char *name, const std::string &str) static void dst_print_algs(pgp_dest_t * dst, - const char * name, + const std::string & name, const std::vector &algs, const id_str_pair map[]) { - if (!name) { - name = "algorithms"; - } - - dst_printf(dst, "%s: ", name); + dst_printf(dst, "%s: ", name.c_str()); for (size_t i = 0; i < algs.size(); i++) { auto comma = i + 1 < algs.size() ? ", " : ""; dst_printf(dst, "%s%s", id_str_pair::lookup(map, algs[i], "Unknown"), comma); @@ -454,32 +450,27 @@ dst_print_sig_type(pgp_dest_t *dst, const char *name, pgp_sig_type_t sigtype) } static void -dst_print_hex(pgp_dest_t *dst, const char *name, const uint8_t *data, size_t len, bool bytes) +dst_print_hex( + pgp_dest_t *dst, const std::string &name, const uint8_t *data, size_t len, bool bytes) { char hex[512]; vsnprinthex(hex, sizeof(hex), data, len); if (bytes) { - dst_printf(dst, "%s: 0x%s (%d bytes)\n", name, hex, (int) len); + dst_printf(dst, "%s: 0x%s (%d bytes)\n", name.c_str(), hex, (int) len); } else { - dst_printf(dst, "%s: 0x%s\n", name, hex); + dst_printf(dst, "%s: 0x%s\n", name.c_str(), hex); } } static void -dst_print_keyid(pgp_dest_t *dst, const char *name, const pgp_key_id_t &keyid) +dst_print_keyid(pgp_dest_t *dst, const std::string &name, const pgp_key_id_t &keyid) { - if (!name) { - name = "key id"; - } dst_print_hex(dst, name, keyid.data(), keyid.size(), false); } static void -dst_print_fp(pgp_dest_t *dst, const char *name, const pgp_fingerprint_t &fp) +dst_print_fp(pgp_dest_t *dst, const std::string &name, const pgp_fingerprint_t &fp) { - if (!name) { - name = "fingerprint"; - } dst_print_hex(dst, name, fp.fingerprint, fp.length, true); } @@ -589,6 +580,13 @@ static void stream_dump_signature_pkt(rnp_dump_ctx_t * ctx, /* Todo: move dumper to pgp::pkt or pgp namespace */ using namespace pgp; +/** + * @brief Dump signature subpacket to the dst. + * + * @param ctx dump context + * @param dst dest + * @param subpkt subpacket itself + */ static void signature_dump_subpacket(rnp_dump_ctx_t *ctx, pgp_dest_t *dst, const pkt::sigsub::Raw &subpkt) { @@ -1186,12 +1184,12 @@ stream_dump_pk_session_key(rnp_dump_ctx_t *ctx, pgp_source_t *src, pgp_dest_t *d dst_printf(dst, "version: %d\n", (int) pkey.version); #if defined(ENABLE_CRYPTO_REFRESH) if (pkey.version == PGP_PKSK_V6) { - dst_print_fp(dst, NULL, pkey.fp); + dst_print_fp(dst, "fingerprint", pkey.fp); } else { - dst_print_keyid(dst, NULL, pkey.key_id); + dst_print_keyid(dst, "key id", pkey.key_id); } #else - dst_print_keyid(dst, NULL, pkey.key_id); + dst_print_keyid(dst, "key id", pkey.key_id); #endif dst_print_palg(dst, NULL, pkey.alg); dst_printf(dst, "encrypted material:\n"); diff --git a/src/tests/cli_tests.py b/src/tests/cli_tests.py index 717159c5b4..f21514158a 100755 --- a/src/tests/cli_tests.py +++ b/src/tests/cli_tests.py @@ -2544,7 +2544,7 @@ def test_rnp_list_packets(self): 'json raw listing mismatch') # List packets with all values, JSON output params = ['--json', '--raw', '--list-packets', KEY_P256, '--mpi', '--grips'] - ret, out, err = run_proc(RNP, params) + ret, out, _ = run_proc(RNP, params) self.assertEqual(ret, 0, 'json all listing failed') compare_file_ex(data_path('test_list_packets/list_json_all.txt'), out, 'json all listing mismatch') @@ -2576,37 +2576,60 @@ def test_rnp_list_packets(self): self.assertEqual(ret, 0) self.assertRegex(out, r'(?s)^.*"type.str":"signer\'s user ID".*"length":9.*"uid":"alice@rnp".*$') # List signature with reason for revocation subpacket - params = ['--list-packets', data_path('test_uid_validity/key-sig-revocation.pgp')] + KEY = data_path('test_uid_validity/key-sig-revocation.pgp') + params = ['--list-packets', KEY] ret, out, _ = run_proc(RNP, params) self.assertEqual(ret, 0) self.assertRegex(out, r'(?s)^.*:type 29, len 24.*reason for revocation: 32 \(No longer valid\).*message: Testing revoked userid.*$') # JSON list signature with reason for revocation subpacket - params = ['--list-packets', '--json', data_path('test_uid_validity/key-sig-revocation.pgp')] + params = ['--list-packets', '--json', KEY] ret, out, _ = run_proc(RNP, params) self.assertEqual(ret, 0) self.assertRegex(out, r'(?s)^.*"type.str":"reason for revocation".*"code":32.*"message":"Testing revoked userid.".*$') # v5 public key - params = ['--list-packets', data_path('test_stream_key_load/v5-rsa-pub.asc')] + KEY = data_path('test_stream_key_load/v5-rsa-pub.asc') + params = ['--list-packets', KEY] ret, out, _ = run_proc(RNP, params) self.assertEqual(ret, 0) self.assertRegex(out, r'(?s)^.*v5 public key material length: 391.*v5 public key material length: 391.*$') self.assertNotRegex(out, r'(?s)^.*v5 s2k length.*$') self.assertNotRegex(out, r'(?s)^.*v5 secret key data length.*$') - params = ['--list-packets', '--json', data_path('test_stream_key_load/v5-rsa-pub.asc')] + params = ['--list-packets', '--json', KEY] ret, out, _ = run_proc(RNP, params) self.assertEqual(ret, 0) self.assertRegex(out, r'(?s)^.*"v5 public key material length":391.*"v5 public key material length":391.*$') self.assertNotRegex(out, r'(?s)^.*"v5 s2k length".*$') self.assertNotRegex(out, r'(?s)^.*"v5 secret key data length".*$') # v5 secret key - params = ['--list-packets', data_path('test_stream_key_load/v5-rsa-sec.asc')] + KEY = data_path('test_stream_key_load/v5-rsa-sec.asc') + params = ['--list-packets', KEY] ret, out, _ = run_proc(RNP, params) self.assertEqual(ret, 0) self.assertRegex(out, r'(?s)^.*v5 s2k length: 28.*v5 secret key data length: 988.*v5 s2k length: 28.*v5 secret key data length: 987.*$') - params = ['--list-packets', '--json', data_path('test_stream_key_load/v5-rsa-sec.asc')] + params = ['--list-packets', '--json', KEY] ret, out, _ = run_proc(RNP, params) self.assertEqual(ret, 0) self.assertRegex(out, r'(?s)^.*"v5 s2k length":28.*"v5 secret key data length":988.*"v5 s2k length":28.*"v5 secret key data length":987.*$') + # key with designated revoker packet + KEY = data_path('test_stream_key_load/ecc-p256-desigrevoked-25519-pub.asc') + params = ['--list-packets', KEY] + ret, out, _ = run_proc(RNP, params) + self.assertEqual(ret, 0) + self.assertRegex(out, r'(?s)^.*revocation key.*class.*128.*$') + params = ['--list-packets', '--json', KEY] + ret, out, _ = run_proc(RNP, params) + self.assertEqual(ret, 0) + self.assertRegex(out, r'(?s)^.*"revocation key".*"class":128.*$') + # primary userid subpackets + KEY = data_path('test_uid_validity/key-uids-pub.pgp') + params = ['--list-packets', KEY] + ret, out, _ = run_proc(RNP, params) + self.assertEqual(ret, 0) + self.assertRegex(out, r'(?s)^.* primary user ID: 1.*$') + params = ['--list-packets', '--json', KEY] + ret, out, _ = run_proc(RNP, params) + self.assertEqual(ret, 0) + self.assertRegex(out, r'(?s)^.*"primary":true.*$') def test_rnp_list_packets_edge_cases(self): KEY_EMPTY_UID = data_path('test_key_edge_cases/key-empty-uid.pgp')