mirror of
https://github.com/ProvableHQ/leo.git
synced 2024-12-12 11:27:41 +03:00
56 lines
1.6 KiB
Rust
56 lines
1.6 KiB
Rust
use crate::{
|
|
boolean::{output_expected_boolean, output_false, output_true},
|
|
get_output,
|
|
integers::{fail_integer, fail_synthesis, IntegerTester},
|
|
parse_program,
|
|
EdwardsConstrainedValue,
|
|
EdwardsTestCompiler,
|
|
};
|
|
use leo_compiler::ConstrainedValue;
|
|
use leo_inputs::types::{IntegerType, U64Type};
|
|
use leo_types::{InputValue, Integer};
|
|
|
|
use snarkos_curves::edwards_bls12::Fq;
|
|
use snarkos_models::gadgets::{
|
|
r1cs::TestConstraintSystem,
|
|
utilities::{alloc::AllocGadget, uint::UInt64},
|
|
};
|
|
|
|
fn output_expected_allocated(program: EdwardsTestCompiler, expected: UInt64) {
|
|
let output = get_output(program);
|
|
|
|
match output {
|
|
EdwardsConstrainedValue::Return(vec) => match vec.as_slice() {
|
|
[ConstrainedValue::Integer(Integer::U64(actual))] => assert_eq!(*actual, expected),
|
|
_ => panic!("program output unknown return value"),
|
|
},
|
|
_ => panic!("program output unknown return value"),
|
|
}
|
|
}
|
|
|
|
#[test]
|
|
#[ignore] //temporarily ignore memory expensive tests for travis
|
|
fn test_u64() {
|
|
test_uint!(Testu64, u64, IntegerType::U64Type(U64Type {}), UInt64);
|
|
|
|
Testu64::test_min(std::u64::MIN);
|
|
Testu64::test_max(std::u64::MAX);
|
|
|
|
Testu64::test_input();
|
|
|
|
Testu64::test_add();
|
|
// Testu64::test_sub(); //Todo: Catch subtraction overflow error in gadget
|
|
Testu64::test_mul();
|
|
Testu64::test_div();
|
|
Testu64::test_pow(); // takes ~2mins
|
|
|
|
Testu64::test_eq();
|
|
Testu64::test_ge();
|
|
Testu64::test_gt();
|
|
Testu64::test_le();
|
|
Testu64::test_gt();
|
|
|
|
Testu64::test_assert_eq();
|
|
Testu64::test_ternary();
|
|
}
|