snarkvm_circuit_account/graph_key/
mod.rs#[cfg(test)]
use snarkvm_circuit_types::environment::assert_scope;
use snarkvm_circuit_network::Aleo;
use snarkvm_circuit_types::{Field, environment::prelude::*};
pub struct GraphKey<A: Aleo> {
sk_tag: Field<A>,
}
#[cfg(feature = "console")]
impl<A: Aleo> Inject for GraphKey<A> {
type Primitive = console::GraphKey<A::Network>;
fn new(mode: Mode, graph_key: Self::Primitive) -> Self {
let sk_tag = Field::new(mode, graph_key.sk_tag());
Self { sk_tag }
}
}
impl<A: Aleo> GraphKey<A> {
pub const fn sk_tag(&self) -> &Field<A> {
&self.sk_tag
}
}
#[cfg(feature = "console")]
impl<A: Aleo> Eject for GraphKey<A> {
type Primitive = console::GraphKey<A::Network>;
fn eject_mode(&self) -> Mode {
self.sk_tag.eject_mode()
}
fn eject_value(&self) -> Self::Primitive {
match Self::Primitive::try_from(self.sk_tag.eject_value()) {
Ok(graph_key) => graph_key,
Err(error) => A::halt(format!("Failed to eject the graph key: {error}")),
}
}
}
#[cfg(all(test, feature = "console"))]
pub(crate) mod tests {
use super::*;
use crate::{Circuit, helpers::generate_account};
use anyhow::Result;
const ITERATIONS: u64 = 250;
fn check_new(
mode: Mode,
num_constants: u64,
num_public: u64,
num_private: u64,
num_constraints: u64,
) -> Result<()> {
for i in 0..ITERATIONS {
let (_, _, view_key, _) = generate_account()?;
let graph_key = console::GraphKey::try_from(&view_key)?;
Circuit::scope(format!("New {mode}"), || {
let candidate = GraphKey::<Circuit>::new(mode, graph_key);
assert_eq!(mode, candidate.eject_mode());
assert_eq!(graph_key, candidate.eject_value());
if i > 0 {
assert_scope!(num_constants, num_public, num_private, num_constraints);
}
});
Circuit::reset();
}
Ok(())
}
#[test]
fn test_graph_key_new_constant() -> Result<()> {
check_new(Mode::Constant, 1, 0, 0, 0)
}
#[test]
fn test_graph_key_new_public() -> Result<()> {
check_new(Mode::Public, 0, 1, 0, 0)
}
#[test]
fn test_graph_key_new_private() -> Result<()> {
check_new(Mode::Private, 0, 0, 1, 0)
}
}