2020-06-02 04:35:43 +03:00
|
|
|
use crate::{
|
|
|
|
boolean::{output_false, output_true},
|
|
|
|
compile_program, get_error, get_output, EdwardsConstrainedValue, EdwardsTestCompiler,
|
|
|
|
};
|
|
|
|
use leo_compiler::{
|
|
|
|
errors::{CompilerError, FunctionError, StatementError},
|
|
|
|
group::edwards_bls12::EdwardsGroupType,
|
|
|
|
ConstrainedValue, InputValue,
|
|
|
|
};
|
2020-05-31 03:05:07 +03:00
|
|
|
|
2020-06-02 00:20:14 +03:00
|
|
|
use snarkos_curves::edwards_bls12::{EdwardsAffine, Fq};
|
|
|
|
use snarkos_gadgets::curves::edwards_bls12::EdwardsBlsGadget;
|
2020-06-02 04:35:43 +03:00
|
|
|
use snarkos_models::{
|
|
|
|
curves::Group,
|
|
|
|
gadgets::{curves::GroupGadget, r1cs::TestConstraintSystem, utilities::alloc::AllocGadget},
|
|
|
|
};
|
2020-05-31 03:05:07 +03:00
|
|
|
use std::str::FromStr;
|
|
|
|
|
2020-05-31 01:37:11 +03:00
|
|
|
const DIRECTORY_NAME: &str = "tests/group/";
|
|
|
|
|
2020-05-31 03:05:07 +03:00
|
|
|
const TEST_POINT_1: &str = "(7374112779530666882856915975292384652154477718021969292781165691637980424078, 3435195339177955418892975564890903138308061187980579490487898366607011481796)";
|
|
|
|
const TEST_POINT_2: &str = "(1005842117974384149622370061042978581211342111653966059496918451529532134799, 79389132189982034519597104273449021362784864778548730890166152019533697186)";
|
|
|
|
|
2020-06-02 00:20:14 +03:00
|
|
|
fn output_expected_constant(program: EdwardsTestCompiler, expected: EdwardsAffine) {
|
2020-05-31 01:37:11 +03:00
|
|
|
let output = get_output(program);
|
|
|
|
assert_eq!(
|
|
|
|
EdwardsConstrainedValue::Return(vec![ConstrainedValue::Group(EdwardsGroupType::Constant(
|
2020-05-31 03:05:07 +03:00
|
|
|
expected
|
2020-05-31 01:37:11 +03:00
|
|
|
))])
|
|
|
|
.to_string(),
|
|
|
|
output.to_string()
|
2020-05-31 03:05:07 +03:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2020-06-02 00:20:14 +03:00
|
|
|
fn output_expected_allocated(program: EdwardsTestCompiler, expected: EdwardsBlsGadget) {
|
|
|
|
let output = get_output(program);
|
|
|
|
assert_eq!(
|
|
|
|
EdwardsConstrainedValue::Return(vec![ConstrainedValue::Group(
|
|
|
|
EdwardsGroupType::Allocated(expected)
|
|
|
|
)])
|
|
|
|
.to_string(),
|
|
|
|
output.to_string()
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2020-05-31 03:05:07 +03:00
|
|
|
fn output_zero(program: EdwardsTestCompiler) {
|
2020-06-02 00:20:14 +03:00
|
|
|
output_expected_constant(program, EdwardsAffine::zero())
|
2020-05-31 01:37:11 +03:00
|
|
|
}
|
|
|
|
|
2020-06-01 22:15:49 +03:00
|
|
|
fn fail_enforce(program: EdwardsTestCompiler) {
|
|
|
|
match get_error(program) {
|
|
|
|
CompilerError::FunctionError(FunctionError::StatementError(
|
|
|
|
StatementError::SynthesisError(_),
|
|
|
|
)) => {}
|
|
|
|
error => panic!("Expected evaluate error, got {}", error),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-31 01:37:11 +03:00
|
|
|
#[test]
|
|
|
|
fn test_zero() {
|
|
|
|
let program = compile_program(DIRECTORY_NAME, "zero.leo").unwrap();
|
|
|
|
output_zero(program);
|
|
|
|
}
|
|
|
|
|
2020-05-31 03:05:07 +03:00
|
|
|
#[test]
|
|
|
|
fn test_point() {
|
|
|
|
let point = EdwardsAffine::from_str(TEST_POINT_1).unwrap();
|
|
|
|
let program = compile_program(DIRECTORY_NAME, "point.leo").unwrap();
|
2020-06-02 00:20:14 +03:00
|
|
|
output_expected_constant(program, point);
|
2020-05-31 03:05:07 +03:00
|
|
|
}
|
|
|
|
|
2020-05-31 01:37:11 +03:00
|
|
|
#[test]
|
|
|
|
fn test_add() {
|
2020-05-31 03:05:07 +03:00
|
|
|
use std::ops::Add;
|
|
|
|
|
|
|
|
let point_1 = EdwardsAffine::from_str(TEST_POINT_1).unwrap();
|
|
|
|
let point_2 = EdwardsAffine::from_str(TEST_POINT_2).unwrap();
|
|
|
|
|
|
|
|
let sum = point_1.add(&point_2);
|
|
|
|
|
2020-05-31 01:37:11 +03:00
|
|
|
let program = compile_program(DIRECTORY_NAME, "add.leo").unwrap();
|
2020-06-02 00:20:14 +03:00
|
|
|
output_expected_constant(program, sum);
|
2020-05-31 01:37:11 +03:00
|
|
|
}
|
2020-05-31 03:19:26 +03:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_sub() {
|
|
|
|
use std::ops::Sub;
|
|
|
|
|
|
|
|
let point_1 = EdwardsAffine::from_str(TEST_POINT_1).unwrap();
|
|
|
|
let point_2 = EdwardsAffine::from_str(TEST_POINT_2).unwrap();
|
|
|
|
|
|
|
|
let sum = point_1.sub(&point_2);
|
|
|
|
|
|
|
|
let program = compile_program(DIRECTORY_NAME, "sub.leo").unwrap();
|
2020-06-02 00:20:14 +03:00
|
|
|
output_expected_constant(program, sum);
|
2020-05-31 03:19:26 +03:00
|
|
|
}
|
2020-06-01 22:15:49 +03:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_eq_true() {
|
|
|
|
let program = compile_program(DIRECTORY_NAME, "eq_true.leo").unwrap();
|
|
|
|
output_true(program)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_eq_false() {
|
|
|
|
let program = compile_program(DIRECTORY_NAME, "eq_false.leo").unwrap();
|
|
|
|
output_false(program)
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_assert_eq_true() {
|
|
|
|
let program = compile_program(DIRECTORY_NAME, "assert_eq_true.leo").unwrap();
|
|
|
|
let _res = get_output(program);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_assert_eq_false() {
|
|
|
|
let program = compile_program(DIRECTORY_NAME, "assert_eq_false.leo").unwrap();
|
|
|
|
fail_enforce(program);
|
|
|
|
}
|
2020-06-02 00:20:14 +03:00
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_input() {
|
|
|
|
let mut program = compile_program(DIRECTORY_NAME, "input.leo").unwrap();
|
|
|
|
program.set_inputs(vec![Some(InputValue::Group(TEST_POINT_1.into()))]);
|
|
|
|
|
|
|
|
let mut cs = TestConstraintSystem::<Fq>::new();
|
|
|
|
let constant_point = EdwardsAffine::from_str(TEST_POINT_1).unwrap();
|
|
|
|
let allocated_point =
|
|
|
|
<EdwardsBlsGadget as AllocGadget<EdwardsAffine, Fq>>::alloc(&mut cs, || Ok(constant_point))
|
|
|
|
.unwrap();
|
|
|
|
|
2020-06-02 03:23:13 +03:00
|
|
|
output_expected_allocated(program, allocated_point);
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_ternary() {
|
|
|
|
let mut program_1 = compile_program(DIRECTORY_NAME, "ternary.leo").unwrap();
|
|
|
|
let mut program_2 = program_1.clone();
|
|
|
|
|
|
|
|
// true -> point_1
|
|
|
|
program_1.set_inputs(vec![Some(InputValue::Boolean(true))]);
|
|
|
|
|
|
|
|
let point_1 = EdwardsAffine::from_str(TEST_POINT_1).unwrap();
|
|
|
|
let output_1 = get_output(program_1);
|
|
|
|
let actual_1: EdwardsAffine = match output_1 {
|
2020-06-02 03:23:40 +03:00
|
|
|
EdwardsConstrainedValue::Return(vec) => match vec.as_slice() {
|
|
|
|
[ConstrainedValue::Group(EdwardsGroupType::Allocated(edwards_gadget))] => {
|
|
|
|
<EdwardsBlsGadget as GroupGadget<EdwardsAffine, Fq>>::get_value(edwards_gadget)
|
|
|
|
.unwrap()
|
2020-06-02 03:23:13 +03:00
|
|
|
}
|
2020-06-02 03:23:40 +03:00
|
|
|
_ => panic!("program output unknown return value"),
|
2020-06-02 03:23:13 +03:00
|
|
|
},
|
2020-06-02 03:23:40 +03:00
|
|
|
_ => panic!("program output unknown return value"),
|
2020-06-02 03:23:13 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
assert_eq!(point_1, actual_1);
|
|
|
|
|
|
|
|
// false -> point_2
|
|
|
|
program_2.set_inputs(vec![Some(InputValue::Boolean(false))]);
|
|
|
|
|
|
|
|
let point_2 = EdwardsAffine::from_str(TEST_POINT_2).unwrap();
|
|
|
|
let output_2 = get_output(program_2);
|
|
|
|
let actual_2: EdwardsAffine = match output_2 {
|
2020-06-02 03:23:40 +03:00
|
|
|
EdwardsConstrainedValue::Return(vec) => match vec.as_slice() {
|
|
|
|
[ConstrainedValue::Group(EdwardsGroupType::Allocated(edwards_gadget))] => {
|
|
|
|
<EdwardsBlsGadget as GroupGadget<EdwardsAffine, Fq>>::get_value(edwards_gadget)
|
|
|
|
.unwrap()
|
2020-06-02 03:23:13 +03:00
|
|
|
}
|
2020-06-02 03:23:40 +03:00
|
|
|
_ => panic!("program output unknown return value"),
|
2020-06-02 03:23:13 +03:00
|
|
|
},
|
2020-06-02 03:23:40 +03:00
|
|
|
_ => panic!("program output unknown return value"),
|
2020-06-02 03:23:13 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
assert_eq!(point_2, actual_2);
|
2020-06-02 00:20:14 +03:00
|
|
|
}
|