2020-06-13 10:47:09 +03:00
|
|
|
use crate::{
|
|
|
|
boolean::{output_false, output_true},
|
|
|
|
get_output,
|
|
|
|
integers::u32::{output_one, output_zero},
|
|
|
|
parse_program,
|
|
|
|
EdwardsConstrainedValue,
|
|
|
|
EdwardsTestCompiler,
|
|
|
|
};
|
|
|
|
use leo_inputs::types::{IntegerType, U32Type};
|
2020-06-13 05:32:16 +03:00
|
|
|
use leo_types::InputValue;
|
2020-06-13 10:47:09 +03:00
|
|
|
|
2020-06-13 12:04:31 +03:00
|
|
|
use crate::integers::u32::output_number;
|
2020-06-13 05:32:16 +03:00
|
|
|
use snarkos_curves::edwards_bls12::Fq;
|
|
|
|
use snarkos_models::gadgets::r1cs::TestConstraintSystem;
|
|
|
|
|
|
|
|
fn empty_output_satisfied(program: EdwardsTestCompiler) {
|
|
|
|
let output = get_output(program);
|
|
|
|
|
|
|
|
assert_eq!(EdwardsConstrainedValue::Return(vec![]).to_string(), output.to_string());
|
|
|
|
}
|
|
|
|
|
2020-06-13 12:08:21 +03:00
|
|
|
// Tests a statements.conditional enforceBit() program
|
2020-06-13 05:32:16 +03:00
|
|
|
//
|
|
|
|
// function main(bit: private u8) {
|
|
|
|
// if bit == 1u8 {
|
|
|
|
// assert_eq!(bit, 1u8);
|
|
|
|
// } else {
|
|
|
|
// assert_eq!(bit, 0u8);
|
|
|
|
// }
|
|
|
|
// }
|
|
|
|
#[test]
|
|
|
|
fn conditional_basic() {
|
2020-06-13 12:04:31 +03:00
|
|
|
let bytes = include_bytes!("assert.leo");
|
2020-06-13 05:32:16 +03:00
|
|
|
let mut program_1_pass = parse_program(bytes).unwrap();
|
|
|
|
let mut program_0_pass = program_1_pass.clone();
|
|
|
|
let mut program_2_fail = program_1_pass.clone();
|
|
|
|
|
|
|
|
// Check that an input value of 1 satisfies the constraint system
|
|
|
|
|
2020-06-13 10:47:09 +03:00
|
|
|
program_1_pass.set_inputs(vec![Some(InputValue::Integer(IntegerType::U32Type(U32Type {}), 1))]);
|
2020-06-13 05:32:16 +03:00
|
|
|
empty_output_satisfied(program_1_pass);
|
|
|
|
|
|
|
|
// Check that an input value of 0 satisfies the constraint system
|
|
|
|
|
2020-06-13 10:47:09 +03:00
|
|
|
program_0_pass.set_inputs(vec![Some(InputValue::Integer(IntegerType::U32Type(U32Type {}), 0))]);
|
2020-06-13 05:32:16 +03:00
|
|
|
empty_output_satisfied(program_0_pass);
|
|
|
|
|
|
|
|
// Check that an input value of 2 does not satisfy the constraint system
|
|
|
|
|
2020-06-13 10:47:09 +03:00
|
|
|
program_2_fail.set_inputs(vec![Some(InputValue::Integer(IntegerType::U32Type(U32Type {}), 2))]);
|
2020-06-13 05:32:16 +03:00
|
|
|
let mut cs = TestConstraintSystem::<Fq>::new();
|
|
|
|
let _output = program_2_fail.compile_constraints(&mut cs).unwrap();
|
|
|
|
assert!(!cs.is_satisfied());
|
|
|
|
}
|
2020-06-13 10:47:09 +03:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn conditional_mutate() {
|
2020-06-13 12:04:31 +03:00
|
|
|
let bytes = include_bytes!("mutate.leo");
|
2020-06-13 10:47:09 +03:00
|
|
|
let mut program_1_true = parse_program(bytes).unwrap();
|
|
|
|
let mut program_0_pass = program_1_true.clone();
|
|
|
|
|
|
|
|
// Check that an input value of 1 satisfies the constraint system
|
|
|
|
|
|
|
|
program_1_true.set_inputs(vec![Some(InputValue::Integer(IntegerType::U32Type(U32Type {}), 1))]);
|
|
|
|
output_one(program_1_true);
|
|
|
|
|
|
|
|
// Check that an input value of 0 satisfies the constraint system
|
|
|
|
|
|
|
|
program_0_pass.set_inputs(vec![Some(InputValue::Integer(IntegerType::U32Type(U32Type {}), 0))]);
|
|
|
|
output_zero(program_0_pass);
|
|
|
|
}
|
2020-06-13 12:04:31 +03:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn conditional_for_loop() {
|
|
|
|
let bytes = include_bytes!("for_loop.leo");
|
|
|
|
let mut program_true_6 = parse_program(bytes).unwrap();
|
|
|
|
let mut program_false_0 = program_true_6.clone();
|
|
|
|
|
|
|
|
// Check that an input value of 1 satisfies the constraint system
|
|
|
|
|
|
|
|
program_true_6.set_inputs(vec![Some(InputValue::Boolean(true))]);
|
|
|
|
output_number(program_true_6, 6u32);
|
|
|
|
|
|
|
|
// Check that an input value of 0 satisfies the constraint system
|
|
|
|
|
|
|
|
program_false_0.set_inputs(vec![Some(InputValue::Boolean(false))]);
|
|
|
|
output_zero(program_false_0);
|
|
|
|
}
|