2023-09-27 09:27:01 -07:00
|
|
|
mod helpers;
|
|
|
|
|
2024-06-21 13:54:57 -07:00
|
|
|
use frost_ed25519 as frost;
|
|
|
|
|
2023-07-12 10:55:26 -07:00
|
|
|
use frost::aggregate;
|
|
|
|
use frost::keys::IdentifierList;
|
2023-09-27 09:27:01 -07:00
|
|
|
use helpers::signature_gen::{key_package, round_1, round_2};
|
2023-04-17 08:16:24 -07:00
|
|
|
use rand::thread_rng;
|
2023-09-27 09:27:01 -07:00
|
|
|
use trusted_dealer::inputs::Config;
|
|
|
|
use trusted_dealer::trusted_dealer_keygen::split_secret;
|
2023-04-17 08:16:24 -07:00
|
|
|
|
2023-09-27 09:27:01 -07:00
|
|
|
use trusted_dealer::trusted_dealer_keygen::trusted_dealer_keygen;
|
2023-04-17 08:16:24 -07:00
|
|
|
|
|
|
|
#[test]
|
2023-05-24 07:37:43 -07:00
|
|
|
fn check_keygen_with_dealer() {
|
2023-04-17 08:16:24 -07:00
|
|
|
let mut rng = thread_rng();
|
|
|
|
let config = Config {
|
|
|
|
min_signers: 2,
|
|
|
|
max_signers: 3,
|
2023-06-02 08:54:55 -07:00
|
|
|
secret: Vec::new(),
|
2023-04-17 08:16:24 -07:00
|
|
|
};
|
2023-07-12 10:55:26 -07:00
|
|
|
let (shares, pubkeys) =
|
|
|
|
trusted_dealer_keygen(&config, IdentifierList::Default, &mut rng).unwrap();
|
|
|
|
|
|
|
|
let key_packages = key_package(&shares);
|
|
|
|
let (nonces, commitments) = round_1(config.min_signers, &mut rng, &key_packages);
|
|
|
|
let message = "i am a message".as_bytes();
|
|
|
|
let (signing_package, signature_shares) = round_2(nonces, &key_packages, commitments, message);
|
|
|
|
let group_signature = aggregate(&signing_package, &signature_shares, &pubkeys).unwrap();
|
2023-11-21 06:56:29 -08:00
|
|
|
let verify_signature = pubkeys.verifying_key().verify(message, &group_signature);
|
2023-06-14 10:52:43 -07:00
|
|
|
|
|
|
|
assert!(verify_signature.is_ok());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn check_keygen_with_dealer_with_large_num_of_signers() {
|
|
|
|
let mut rng = thread_rng();
|
|
|
|
let config = Config {
|
|
|
|
min_signers: 14,
|
|
|
|
max_signers: 20,
|
|
|
|
secret: Vec::new(),
|
|
|
|
};
|
2023-07-12 10:55:26 -07:00
|
|
|
let (shares, pubkeys) =
|
|
|
|
trusted_dealer_keygen(&config, IdentifierList::Default, &mut rng).unwrap();
|
|
|
|
|
|
|
|
let key_packages = key_package(&shares);
|
|
|
|
let (nonces, commitments) = round_1(config.min_signers, &mut rng, &key_packages);
|
|
|
|
let message = "i am a message".as_bytes();
|
|
|
|
let (signing_package, signature_shares) = round_2(nonces, &key_packages, commitments, message);
|
|
|
|
let group_signature = aggregate(&signing_package, &signature_shares, &pubkeys).unwrap();
|
2023-11-21 06:56:29 -08:00
|
|
|
let verify_signature = pubkeys.verifying_key().verify(message, &group_signature);
|
2023-04-17 08:16:24 -07:00
|
|
|
|
|
|
|
assert!(verify_signature.is_ok());
|
|
|
|
}
|
2023-05-24 07:37:43 -07:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn check_keygen_with_dealer_with_secret() {
|
|
|
|
let mut rng = thread_rng();
|
2023-06-05 03:25:43 -07:00
|
|
|
let secret: Vec<u8> = vec![
|
|
|
|
123, 28, 51, 211, 245, 41, 29, 133, 222, 102, 72, 51, 190, 177, 173, 70, 159, 127, 182, 2,
|
|
|
|
90, 14, 199, 139, 58, 121, 12, 110, 19, 169, 131, 4,
|
|
|
|
];
|
2023-06-02 08:54:55 -07:00
|
|
|
let secret_config = Config {
|
2023-05-24 07:37:43 -07:00
|
|
|
min_signers: 2,
|
|
|
|
max_signers: 3,
|
2023-06-05 03:25:43 -07:00
|
|
|
secret,
|
2023-05-24 07:37:43 -07:00
|
|
|
};
|
2023-07-12 10:55:26 -07:00
|
|
|
|
|
|
|
let (shares, pubkeys) =
|
|
|
|
split_secret(&secret_config, IdentifierList::Default, &mut rng).unwrap();
|
|
|
|
let key_packages = key_package(&shares);
|
|
|
|
let (nonces, commitments) = round_1(secret_config.min_signers, &mut rng, &key_packages);
|
|
|
|
let message = "i am a message".as_bytes();
|
|
|
|
let (signing_package, signature_shares) = round_2(nonces, &key_packages, commitments, message);
|
|
|
|
let group_signature = aggregate(&signing_package, &signature_shares, &pubkeys).unwrap();
|
2023-11-21 06:56:29 -08:00
|
|
|
let verify_signature = pubkeys.verifying_key().verify(message, &group_signature);
|
2023-06-14 10:52:43 -07:00
|
|
|
|
|
|
|
assert!(verify_signature.is_ok());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn check_keygen_with_dealer_with_secret_with_large_num_of_signers() {
|
|
|
|
let mut rng = thread_rng();
|
|
|
|
let secret: Vec<u8> = vec![
|
|
|
|
123, 28, 51, 211, 245, 41, 29, 133, 222, 102, 72, 51, 190, 177, 173, 70, 159, 127, 182, 2,
|
|
|
|
90, 14, 199, 139, 58, 121, 12, 110, 19, 169, 131, 4,
|
|
|
|
];
|
|
|
|
let secret_config = Config {
|
|
|
|
min_signers: 14,
|
|
|
|
max_signers: 20,
|
|
|
|
secret,
|
|
|
|
};
|
2023-07-12 10:55:26 -07:00
|
|
|
let (shares, pubkeys) =
|
|
|
|
split_secret(&secret_config, IdentifierList::Default, &mut rng).unwrap();
|
|
|
|
let key_packages = key_package(&shares);
|
|
|
|
let (nonces, commitments) = round_1(secret_config.min_signers, &mut rng, &key_packages);
|
|
|
|
let message = "i am a message".as_bytes();
|
|
|
|
let (signing_package, signature_shares) = round_2(nonces, &key_packages, commitments, message);
|
|
|
|
let group_signature = aggregate(&signing_package, &signature_shares, &pubkeys).unwrap();
|
2023-11-21 06:56:29 -08:00
|
|
|
let verify_signature = pubkeys.verifying_key().verify(message, &group_signature);
|
2023-06-05 03:25:43 -07:00
|
|
|
|
|
|
|
assert!(verify_signature.is_ok());
|
2023-05-24 07:37:43 -07:00
|
|
|
}
|