sequoia-sq/tests/integration/sq_key_import_export.rs

110 lines
3.2 KiB
Rust
Raw Normal View History

2024-05-21 18:08:01 +02:00
use sequoia_openpgp as openpgp;
use openpgp::KeyHandle;
2024-05-21 18:08:01 +02:00
use openpgp::Result;
use openpgp::packet::Key;
use super::common::power_set;
use super::common::Sq;
2024-05-30 20:47:52 +02:00
#[test]
fn sq_key_import_export() -> Result<()>
{
let sq = Sq::new();
// Generate a few keys as red herrings.
for i in 0..10 {
let (_, key_pgp, _) = sq.key_generate(&[], &[&format!("Key {}", i)]);
sq.key_import(key_pgp);
}
2024-05-21 18:08:01 +02:00
// Generate and import a key.
let (cert, key_pgp, _) = sq.key_generate(&[], &["Alice"]);
sq.key_import(key_pgp);
2024-05-21 18:08:01 +02:00
// Export the whole certificate.
for by_fpr in [true, false] {
let kh: KeyHandle = if by_fpr {
cert.fingerprint().into()
} else {
cert.keyid().into()
};
2024-05-21 18:08:01 +02:00
let got = sq.key_export(kh);
assert_eq!(cert, got);
}
2024-05-21 18:08:01 +02:00
// Export each non-empty subset of keys.
2024-05-21 18:08:01 +02:00
eprintln!("Certificate:");
for k in cert.keys() {
eprintln!(" {}", k.fingerprint());
}
let keys: Vec<Key<_, _>> = cert.keys()
.map(|k| {
k.key().clone()
})
.collect();
let key_ids = keys.iter().map(|k| k.fingerprint()).collect::<Vec<_>>();
for (i, selection) in power_set(&key_ids).into_iter().enumerate() {
for by_fpr in [true, false] {
eprintln!("Test #{}, by {}:",
i + 1,
if by_fpr { "fingerprint" } else { "key ID" });
eprintln!(" Exporting:");
for k in selection.iter() {
eprintln!(" {}", k);
}
// Export the selection.
let got = sq.key_subkey_export(
cert.key_handle(), selection.clone());
// Make sure we got exactly what we asked for; no
// more, no less.
eprintln!(" Got:");
let mut secrets = 0;
for got in got.keys() {
let expected = keys.iter()
.find(|k| k.fingerprint() == got.fingerprint())
.expect("have key");
eprintln!(" {} {} secret key material",
got.fingerprint(),
if got.has_secret() {
"has"
} else {
"doesn't have"
});
if let Ok(got) = got.parts_as_secret() {
assert!(
selection.contains(&got.fingerprint()),
"got secret key material \
for a key we didn't ask for ({})",
got.fingerprint());
assert_eq!(expected.parts_as_secret().expect("have secrets"),
got.key());
secrets += 1;
} else {
assert!(
! selection.contains(&got.fingerprint()),
"didn't get secret key material \
for a key we asked for ({})",
got.fingerprint());
assert_eq!(expected, got.key());
2024-05-21 18:08:01 +02:00
}
}
assert_eq!(secrets, selection.len());
2024-05-21 18:08:01 +02:00
}
}
Ok(())
2024-05-21 18:08:01 +02:00
}