2022-05-06 07:57:45 -07:00
|
|
|
#![cfg(feature = "alloc")]
|
|
|
|
|
2020-07-03 15:23:28 -07:00
|
|
|
use rand::thread_rng;
|
|
|
|
|
2021-03-01 06:38:25 -08:00
|
|
|
use reddsa::*;
|
2020-07-03 15:23:28 -07:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn spendauth_batch_verify() {
|
2021-02-21 19:07:12 -08:00
|
|
|
let mut rng = thread_rng();
|
2021-03-01 07:29:07 -08:00
|
|
|
let mut batch = batch::Verifier::<_, sapling::Binding>::new();
|
2020-07-03 15:23:28 -07:00
|
|
|
for _ in 0..32 {
|
2021-03-01 07:29:07 -08:00
|
|
|
let sk = SigningKey::<sapling::SpendAuth>::new(&mut rng);
|
2020-07-03 15:23:28 -07:00
|
|
|
let vk = VerificationKey::from(&sk);
|
|
|
|
let msg = b"BatchVerifyTest";
|
2021-02-21 19:07:12 -08:00
|
|
|
let sig = sk.sign(&mut rng, &msg[..]);
|
2021-03-01 07:29:07 -08:00
|
|
|
batch.queue(batch::Item::from_spendauth(vk.into(), sig, msg));
|
2020-07-03 15:23:28 -07:00
|
|
|
}
|
|
|
|
assert!(batch.verify(rng).is_ok());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn binding_batch_verify() {
|
2021-02-21 19:07:12 -08:00
|
|
|
let mut rng = thread_rng();
|
2021-03-01 07:29:07 -08:00
|
|
|
let mut batch = batch::Verifier::<sapling::SpendAuth, _>::new();
|
2020-07-03 15:23:28 -07:00
|
|
|
for _ in 0..32 {
|
2021-03-01 07:29:07 -08:00
|
|
|
let sk = SigningKey::<sapling::Binding>::new(&mut rng);
|
2020-07-03 15:23:28 -07:00
|
|
|
let vk = VerificationKey::from(&sk);
|
|
|
|
let msg = b"BatchVerifyTest";
|
2021-02-21 19:07:12 -08:00
|
|
|
let sig = sk.sign(&mut rng, &msg[..]);
|
2021-03-01 07:29:07 -08:00
|
|
|
batch.queue(batch::Item::from_binding(vk.into(), sig, msg));
|
2020-07-03 15:23:28 -07:00
|
|
|
}
|
|
|
|
assert!(batch.verify(rng).is_ok());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn alternating_batch_verify() {
|
2021-02-21 19:07:12 -08:00
|
|
|
let mut rng = thread_rng();
|
2020-07-03 15:23:28 -07:00
|
|
|
let mut batch = batch::Verifier::new();
|
|
|
|
for i in 0..32 {
|
2021-03-01 07:29:07 -08:00
|
|
|
let item = match i % 2 {
|
2020-07-03 15:23:28 -07:00
|
|
|
0 => {
|
2021-03-01 07:29:07 -08:00
|
|
|
let sk = SigningKey::<sapling::SpendAuth>::new(&mut rng);
|
2020-07-03 15:23:28 -07:00
|
|
|
let vk = VerificationKey::from(&sk);
|
|
|
|
let msg = b"BatchVerifyTest";
|
2021-02-21 19:07:12 -08:00
|
|
|
let sig = sk.sign(&mut rng, &msg[..]);
|
2021-03-01 07:29:07 -08:00
|
|
|
batch::Item::from_spendauth(vk.into(), sig, msg)
|
2020-07-03 15:23:28 -07:00
|
|
|
}
|
|
|
|
1 => {
|
2021-03-01 07:29:07 -08:00
|
|
|
let sk = SigningKey::<sapling::Binding>::new(&mut rng);
|
2020-07-03 15:23:28 -07:00
|
|
|
let vk = VerificationKey::from(&sk);
|
|
|
|
let msg = b"BatchVerifyTest";
|
2021-02-21 19:07:12 -08:00
|
|
|
let sig = sk.sign(&mut rng, &msg[..]);
|
2021-03-01 07:29:07 -08:00
|
|
|
batch::Item::from_binding(vk.into(), sig, msg)
|
2020-07-03 15:23:28 -07:00
|
|
|
}
|
2020-07-15 12:38:43 -07:00
|
|
|
_ => unreachable!(),
|
|
|
|
};
|
|
|
|
batch.queue(item);
|
2020-07-03 15:23:28 -07:00
|
|
|
}
|
|
|
|
assert!(batch.verify(rng).is_ok());
|
|
|
|
}
|
2020-07-15 12:38:43 -07:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn bad_batch_verify() {
|
2021-02-21 19:07:12 -08:00
|
|
|
let mut rng = thread_rng();
|
2020-07-15 12:38:43 -07:00
|
|
|
let bad_index = 4; // must be even
|
|
|
|
let mut batch = batch::Verifier::new();
|
|
|
|
let mut items = Vec::new();
|
|
|
|
for i in 0..32 {
|
2021-03-01 07:29:07 -08:00
|
|
|
let item = match i % 2 {
|
2020-07-15 12:38:43 -07:00
|
|
|
0 => {
|
2021-03-01 07:29:07 -08:00
|
|
|
let sk = SigningKey::<sapling::SpendAuth>::new(&mut rng);
|
2020-07-15 12:38:43 -07:00
|
|
|
let vk = VerificationKey::from(&sk);
|
|
|
|
let msg = b"BatchVerifyTest";
|
|
|
|
let sig = if i != bad_index {
|
2021-02-21 19:07:12 -08:00
|
|
|
sk.sign(&mut rng, &msg[..])
|
2020-07-15 12:38:43 -07:00
|
|
|
} else {
|
2021-02-21 19:07:12 -08:00
|
|
|
sk.sign(&mut rng, b"bad")
|
2020-07-15 12:38:43 -07:00
|
|
|
};
|
2021-03-01 07:29:07 -08:00
|
|
|
batch::Item::from_spendauth(vk.into(), sig, msg)
|
2020-07-15 12:38:43 -07:00
|
|
|
}
|
|
|
|
1 => {
|
2021-03-01 07:29:07 -08:00
|
|
|
let sk = SigningKey::<sapling::Binding>::new(&mut rng);
|
2020-07-15 12:38:43 -07:00
|
|
|
let vk = VerificationKey::from(&sk);
|
|
|
|
let msg = b"BatchVerifyTest";
|
2021-02-21 19:07:12 -08:00
|
|
|
let sig = sk.sign(&mut rng, &msg[..]);
|
2021-03-01 07:29:07 -08:00
|
|
|
batch::Item::from_binding(vk.into(), sig, msg)
|
2020-07-15 12:38:43 -07:00
|
|
|
}
|
|
|
|
_ => unreachable!(),
|
|
|
|
};
|
|
|
|
items.push(item.clone());
|
|
|
|
batch.queue(item);
|
|
|
|
}
|
|
|
|
assert!(batch.verify(rng).is_err());
|
|
|
|
for (i, item) in items.drain(..).enumerate() {
|
|
|
|
if i != bad_index {
|
|
|
|
assert!(item.verify_single().is_ok());
|
|
|
|
} else {
|
|
|
|
assert!(item.verify_single().is_err());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|