Skip to content

Commit

Permalink
Rebase
Browse files Browse the repository at this point in the history
Signed-off-by: Patrik Stas <[email protected]>
  • Loading branch information
Patrik-Stas committed Oct 26, 2023
1 parent 020f640 commit 88278d8
Show file tree
Hide file tree
Showing 2 changed files with 102 additions and 90 deletions.
183 changes: 94 additions & 89 deletions aries_vcx/tests/test_credential_retrieval.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

pub mod utils;

use std::collections::HashMap;
use std::{collections::HashMap, error::Error};

use aries_vcx::{
common::proofs::proof_request::PresentationRequestData,
Expand All @@ -20,7 +20,7 @@ use messages::{
},
};
use serde_json::json;
use test_utils::{constants::DEFAULT_SCHEMA_ATTRS, run_setup_test};
use test_utils::{constants::DEFAULT_SCHEMA_ATTRS, devsetup::build_setup_profile, run_setup_test};

use crate::utils::{
create_and_write_credential, create_and_write_test_cred_def, create_and_write_test_schema,
Expand All @@ -30,93 +30,98 @@ use crate::utils::{
#[ignore]
// TODO: This should be a unit test
async fn test_agency_pool_retrieve_credentials_empty() -> Result<(), Box<dyn Error>> {
run_setup_test!(|setup| async move {

let pres_req_data = PresentationRequestData {
nonce: "123432421212".into(),
name: "proof_req_1".into(),
data_version: "0.1".into(),
requested_attributes: serde_json::from_value(json!({}))?,
requested_predicates: serde_json::from_value(json!({}))?,
non_revoked: None,
};

let attach_type =
AttachmentType::Base64(general_purpose::STANDARD.encode(json!(pres_req_data).to_string()));
let attach_data = AttachmentData::builder().content(attach_type).build();
let attach = Attachment::builder()
.data(attach_data)
.id(AttachmentId::PresentationRequest.as_ref().to_owned())
.mime_type(MimeType::Json)
.build();

let content = RequestPresentationV1Content::builder()
.request_presentations_attach(vec![attach])
.build();

// test retrieving credentials for empty proof request returns "{}"
let id = "test_id".to_owned();
let proof_req = RequestPresentationV1::builder()
.id(id)
.content(content)
.build();
let proof: Prover = Prover::create_from_request("1", proof_req)?;

let retrieved_creds = proof
.retrieve_credentials(&setup.wallet, &setup.anoncreds)
.await?;
assert_eq!(serde_json::to_string(&retrieved_creds)?, "{}".to_string());
assert!(retrieved_creds.credentials_by_referent.is_empty());

// populate proof request with a single attribute referent request
let pres_req_data = PresentationRequestData {
nonce: "123432421212".into(),
name: "proof_req_1".into(),
data_version: "0.1".into(),
requested_attributes: serde_json::from_value(
json!({ "address1_1": {"name": "address1"} }),
)?,
requested_predicates: serde_json::from_value(json!({}))?,
non_revoked: None,
};

let attach_type =
AttachmentType::Base64(general_purpose::STANDARD.encode(json!(pres_req_data).to_string()));
let attach_data = AttachmentData::builder().content(attach_type).build();
let attach = Attachment::builder()
.data(attach_data)
.id(AttachmentId::PresentationRequest.as_ref().to_owned())
.mime_type(MimeType::Json)
.build();

let content = RequestPresentationV1Content::builder()
.request_presentations_attach(vec![attach])
.build();

// test retrieving credentials for the proof request returns the referent with no cred
// matches
let id = "test_id".to_owned();
let proof_req = RequestPresentationV1::builder()
.id(id)
.content(content)
.build();
let proof: Prover = Prover::create_from_request("2", proof_req)?;

let retrieved_creds = proof
.retrieve_credentials(&setup.wallet, &setup.anoncreds)
.await?;
assert_eq!(
serde_json::to_string(&retrieved_creds)?,
json!({"attrs":{"address1_1":[]}}).to_string()
);
assert_eq!(
retrieved_creds,
RetrievedCredentials {
credentials_by_referent: HashMap::from([("address1_1".to_string(), vec![])])
}
)
})
.await;
build_setup_profile()
.await
.run2(|setup| async move {
let pres_req_data = PresentationRequestData {
nonce: "123432421212".into(),
name: "proof_req_1".into(),
data_version: "0.1".into(),
requested_attributes: serde_json::from_value(json!({}))?,
requested_predicates: serde_json::from_value(json!({}))?,
non_revoked: None,
};

let attach_type = AttachmentType::Base64(
general_purpose::STANDARD.encode(json!(pres_req_data).to_string()),
);
let attach_data = AttachmentData::builder().content(attach_type).build();
let attach = Attachment::builder()
.data(attach_data)
.id(AttachmentId::PresentationRequest.as_ref().to_owned())
.mime_type(MimeType::Json)
.build();

let content = RequestPresentationV1Content::builder()
.request_presentations_attach(vec![attach])
.build();

// test retrieving credentials for empty proof request returns "{}"
let id = "test_id".to_owned();
let proof_req = RequestPresentationV1::builder()
.id(id)
.content(content)
.build();
let proof: Prover = Prover::create_from_request("1", proof_req)?;

let retrieved_creds = proof
.retrieve_credentials(&setup.wallet, &setup.anoncreds)
.await?;
assert_eq!(serde_json::to_string(&retrieved_creds)?, "{}".to_string());
assert!(retrieved_creds.credentials_by_referent.is_empty());

// populate proof request with a single attribute referent request
let pres_req_data = PresentationRequestData {
nonce: "123432421212".into(),
name: "proof_req_1".into(),
data_version: "0.1".into(),
requested_attributes: serde_json::from_value(
json!({ "address1_1": {"name": "address1"} }),
)?,
requested_predicates: serde_json::from_value(json!({}))?,
non_revoked: None,
};

let attach_type = AttachmentType::Base64(
general_purpose::STANDARD.encode(json!(pres_req_data).to_string()),
);
let attach_data = AttachmentData::builder().content(attach_type).build();
let attach = Attachment::builder()
.data(attach_data)
.id(AttachmentId::PresentationRequest.as_ref().to_owned())
.mime_type(MimeType::Json)
.build();

let content = RequestPresentationV1Content::builder()
.request_presentations_attach(vec![attach])
.build();

// test retrieving credentials for the proof request returns the referent with no cred
// matches
let id = "test_id".to_owned();
let proof_req = RequestPresentationV1::builder()
.id(id)
.content(content)
.build();
let proof: Prover = Prover::create_from_request("2", proof_req)?;

let retrieved_creds = proof
.retrieve_credentials(&setup.wallet, &setup.anoncreds)
.await?;
assert_eq!(
serde_json::to_string(&retrieved_creds)?,
json!({"attrs":{"address1_1":[]}}).to_string()
);
assert_eq!(
retrieved_creds,
RetrievedCredentials {
credentials_by_referent: HashMap::from([("address1_1".to_string(), vec![])])
}
);
Ok(())
})
.await;
Ok(())
}

#[tokio::test]
Expand Down
9 changes: 8 additions & 1 deletion tools/test_utils/src/devsetup.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

use std::{
env,
error::Error,
fs::{self, DirBuilder, OpenOptions},
future::Future,
io::Write,
Expand Down Expand Up @@ -349,7 +350,13 @@ where
F: Future<Output = ()>,
{
f(self).await;
reset_global_state();
}

pub async fn run2<F>(self, f: impl FnOnce(Self) -> F)
where
F: Future<Output = Result<(), Box<dyn Error>>>,
{
f(self).await;
}
}

Expand Down

0 comments on commit 88278d8

Please sign in to comment.