sequoia-sq/tests/sq-packet-dump.rs
Neal H. Walfield 936ae250e1
Add support for a persistant certificate store
- Add support for a persistant certificate store using
    `sequoia-cert-store`.

  - Add `sq --no-cert-store` to disable the use of the certificate
    store.  Add `sq --cert-store PATH` to use an alternate certificate
    store.

  - Add `sq import` to import a certificate into the certificate
    store.  Add `sq export` to export certificates.

  - Modify `sq certify`, `sq encrypt`, and `sq verify` to lookup
    certificates in the certificate store, if it is configured.
2023-03-16 13:46:50 +01:00

130 lines
3.9 KiB
Rust

#[cfg(test)]
mod sq_packet_dump {
use assert_cmd::Command;
use predicates::prelude::*;
use openpgp::Result;
use sequoia_openpgp as openpgp;
fn artifact(filename: &str) -> String {
format!("tests/data/{}", filename)
}
#[test]
fn session_key_without_prefix() -> Result<()> {
Command::cargo_bin("sq")
.unwrap()
.arg("--no-cert-store")
.arg("packet")
.arg("dump")
.args(["--session-key", "1FE820EC21FB5D7E33D83367106D1D3747DCD48E6320C1AEC57EE7D18FC437D4"])
.arg(artifact("messages/rsa.msg.pgp"))
.assert()
.success()
.stdout(predicate::str::contains("Decryption failed").not());
Ok(())
}
#[test]
fn session_key_with_prefix() -> Result<()> {
Command::cargo_bin("sq")
.unwrap()
.arg("--no-cert-store")
.arg("packet")
.arg("dump")
.args(["--session-key", "9:1FE820EC21FB5D7E33D83367106D1D3747DCD48E6320C1AEC57EE7D18FC437D4"])
.arg(artifact("messages/rsa.msg.pgp"))
.assert()
.success()
.stdout(predicate::str::contains("Decryption failed").not());
Ok(())
}
#[test]
fn session_key_with_bad_prefix() -> Result<()> {
Command::cargo_bin("sq")
.unwrap()
.arg("--no-cert-store")
.arg("packet")
.arg("dump")
.args(["--session-key", "1:1FE820EC21FB5D7E33D83367106D1D3747DCD48E6320C1AEC57EE7D18FC437D4"])
.arg(artifact("messages/rsa.msg.pgp"))
.assert()
.success()
.stdout(predicate::str::contains("Indicated Symmetric algo: IDEA"))
.stdout(predicate::str::contains("Decryption failed"));
Ok(())
}
#[test]
fn session_key_wrong_length_without_prefix() -> Result<()> {
// too short
Command::cargo_bin("sq")
.unwrap()
.arg("--no-cert-store")
.arg("packet")
.arg("dump")
.args(["--session-key", "1FE820EC21FB5D7E33D83367106D1D3747DCD48E6320C1AEC57EE7D18FC437"])
.arg(artifact("messages/rsa.msg.pgp"))
.assert()
.success()
.stdout(predicate::str::contains("Decryption failed"));
// too long
Command::cargo_bin("sq")
.unwrap()
.arg("--no-cert-store")
.arg("packet")
.arg("dump")
.args(["--session-key", "1FE820EC21FB5D7E33D83367106D1D3747DCD48E6320C1AEC57EE7D18FC437D4AB"])
.arg(artifact("messages/rsa.msg.pgp"))
.assert()
.success()
.stdout(predicate::str::contains("Decryption failed"));
Ok(())
}
#[test]
fn session_key_wrong_length_with_prefix() -> Result<()> {
// too short
Command::cargo_bin("sq")
.unwrap()
.arg("--no-cert-store")
.arg("packet")
.arg("dump")
.args(["--session-key", "1:1FE820EC21FB5D7E33D83367106D1D3747DCD48E6320C1AEC57EE7D18FC437"])
.arg(artifact("messages/rsa.msg.pgp"))
.assert()
.success()
.stdout(predicate::str::contains("Decryption failed"));
// too long
Command::cargo_bin("sq")
.unwrap()
.arg("--no-cert-store")
.arg("packet")
.arg("dump")
.args(["--session-key", "1:1FE820EC21FB5D7E33D83367106D1D3747DCD48E6320C1AEC57EE7D18FC437D4AB"])
.arg(artifact("messages/rsa.msg.pgp"))
.assert()
.success()
.stdout(predicate::str::contains("Decryption failed"));
Ok(())
}
#[test]
fn session_key_wrong_key_with_prefix() -> Result<()> {
Command::cargo_bin("sq")
.unwrap()
.arg("--no-cert-store")
.arg("packet")
.arg("dump")
.args(["--session-key", "9:BB9CCB8EDE22DC222C83BD1C63AEB97335DDC7B696DB171BD16EAA5784CC0478"])
.arg(artifact("messages/rsa.msg.pgp"))
.assert()
.success()
.stdout(predicate::str::contains("Decryption failed"));
Ok(())
}
}