Skip to content

Commit

Permalink
Add test for #762
Browse files Browse the repository at this point in the history
  • Loading branch information
moCello committed Aug 16, 2023
1 parent 8691d2b commit 0f33c4a
Show file tree
Hide file tree
Showing 2 changed files with 78 additions and 7 deletions.
12 changes: 5 additions & 7 deletions tests/common/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,8 @@ where
{
let pp = PublicParameters::setup(capacity, rng)
.expect("Creation of public parameter shouldn't fail");
Compiler::compile_with_circuit(&pp, label, circuit).expect("It should be possible to create the prover and verifier circuit descriptions")
Compiler::compile_with_circuit(&pp, label, circuit)
.expect("It should be possible to compile the prover and verifier")
}

// Check that proof creation and verification of a satisfied circuit passes
Expand All @@ -37,12 +38,10 @@ pub(crate) fn check_satisfied_circuit<C, R>(
C: Circuit,
R: RngCore + CryptoRng,
{
let (proof, pi_circuit) = prover
let (proof, _pi_circuit) = prover
.prove(rng, circuit)
.expect("Prover for valid circuit shouldn't fail");

assert_eq!(*pi_expected, pi_circuit);

verifier.verify(&proof, &pi_expected).expect(msg);
}

Expand All @@ -63,18 +62,17 @@ pub(crate) fn check_satisfied_circuit_fails<C, R>(
C: Circuit,
R: RngCore + CryptoRng,
{
let (proof, pi_circuit) = prover
let (proof, _pi_circuit) = prover
.prove(rng, circuit)
.expect("Prover for valid circuit shouldn't fail");

assert_eq!(*pi_expected, pi_circuit);

verifier.verify(&proof, &pi_expected).expect_err(msg);
}

// Check that proof creation of an unsatisfied circuit fails
// This is also the case when the constants appended to the circuit does not
// match the ones from the circuit description
#[allow(dead_code)]
pub(crate) fn check_unsatisfied_circuit<C, R>(
prover: &Prover,
circuit: &C,
Expand Down
73 changes: 73 additions & 0 deletions tests/public_inputs.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,73 @@
// This Source Code Form is subject to the terms of the Mozilla Public
// License, v. 2.0. If a copy of the MPL was not distributed with this
// file, You can obtain one at http://mozilla.org/MPL/2.0/.
//
// Copyright (c) DUSK NETWORK. All rights reserved.

use dusk_plonk::prelude::*;
use rand::rngs::StdRng;
use rand::SeedableRng;

const CAPACITY: usize = 1 << 4;
const LABEL: &[u8] = b"check_public_inputs";

#[derive(Default)]
pub struct TestPI {
public: Vec<BlsScalar>,
sum: BlsScalar,
}

impl TestPI {
pub fn new(public: Vec<BlsScalar>, sum: BlsScalar) -> Self {
Self { public, sum }
}
}

impl Circuit for TestPI {
fn circuit<C>(&self, composer: &mut C) -> Result<(), Error>
where
C: Composer,
{
// this circuit will always have the same amount of gates but different
// amount of public inputs, depending on the struct data
let mut sum = C::ZERO;
for i in 0..2 {
let constraint = match i < self.public.len() {
true => Constraint::new()
.left(1)
.a(sum)
.right(1)
.b(C::ONE)
.public(self.public[i]),
false => Constraint::new().left(1).a(sum).right(1).b(C::ONE),
};
sum = composer.gate_add(constraint);
}
let expected_sum = composer.append_witness(self.sum);
composer.assert_equal(sum, expected_sum);

Ok(())
}
}

#[ignore = "test for issue #762"]
#[test]
fn public_inputs() {
let rng = &mut StdRng::seed_from_u64(0x10b);
let pp = PublicParameters::setup(CAPACITY, rng)
.expect("Creation of public parameter shouldn't fail");

// compiling the default version of TestPI, which has no pi
let (prover, _verifier) = Compiler::compile::<TestPI>(&pp, LABEL)
.expect("It should be possible to compile the prover and verifier");

// Create circuit with public inputs
let pi: Vec<BlsScalar> = [BlsScalar::one(); 2].into();
let sum = BlsScalar::from(4);
let circuit = TestPI::new(pi, sum);
let result = prover.prove(rng, &circuit);
assert!(
result.is_err(),
"proof creation for circuit diferrent from circuit description shouldn't be possible"
);
}

0 comments on commit 0f33c4a

Please sign in to comment.