use hex_literal::hex; use plonky2::field::goldilocks_field::GoldilocksField; use plonky2::plonk::config::PoseidonGoldilocksConfig; use plonky2::util::timing::TimingTree; use plonky2_evm::all_stark::AllStark; use plonky2_evm::config::StarkConfig; use plonky2_evm::generation::partial_trie::PartialTrie; use plonky2_evm::generation::{generate_traces, TransactionData}; use plonky2_evm::prover::prove; use plonky2_evm::verifier::verify_proof; type F = GoldilocksField; const D: usize = 2; type C = PoseidonGoldilocksConfig; /// Test a simple token transfer to a new address. #[test] #[ignore] // TODO: Won't work until txn parsing, storage, etc. are implemented. fn test_simple_transfer() -> anyhow::Result<()> { let all_stark = AllStark::::default(); let txn = TransactionData { signed_txn: hex!("f85f050a82520894000000000000000000000000000000000000000064801ca0fa56df5d988638fad8798e5ef75a1e1125dc7fb55d2ac4bce25776a63f0c2967a02cb47a5579eb5f83a1cabe4662501c0059f1b58e60ef839a1b0da67af6b9fb38").to_vec(), // TODO: Add trie with sender account. state_trie: PartialTrie::Empty, transaction_trie: PartialTrie::Empty, receipt_trie: PartialTrie::Empty, storage_tries: vec![], }; let traces = generate_traces(&all_stark, &[txn]); let config = StarkConfig::standard_fast_config(); let proof = prove::( &all_stark, &config, traces, vec![vec![]; 4], &mut TimingTree::default(), )?; verify_proof(all_stark, proof, &config) }