thesimplekid 1 год назад
Родитель
Сommit
0c90ef0e0b
2 измененных файлов с 34 добавлено и 16 удалено
  1. 32 16
      integration_test/src/main.rs
  2. 2 0
      src/client.rs

+ 32 - 16
integration_test/src/main.rs

@@ -10,10 +10,16 @@ use cashu_crab::client::Client;
 use cashu_crab::types::{MintKeys, MintProofs, Proofs, Token};
 use lightning_invoice::Invoice;
 
+const MINTURL: &str = "https:dev-cashu.thesimplekid.com";
+
+const MINTAMOUNT: u64 = 21;
+const SENDAMOUNT: u64 = 5;
+
+const MELTINVOICE: &str = "lnbc10n1pj9d299pp5dwz8y2xuk3yrrfuayclwpffgnd3htfzmxvd8xqa4hzcp58kdeq2sdq5g9kxy7fqd9h8vmmfvdjscqzzsxqyz5vqsp5hdjrv0gx59qy7m4a9xk66m0kvja9ljjzh6zp6wn8np8kky5xnqks9qyyssqd09y339sp53l0apkrt8klmrrvl7qmxd2237p8m8cz8xcl725ems8al55hkjl6c2sjx755s7m8rlmhwej9u8glv2ltwzfssddzpwk05cp4re0t3";
+
 #[tokio::main]
 async fn main() {
-    let url = "https:dev-cashu.thesimplekid.com";
-    let client = Client::new(url).unwrap();
+    let client = Client::new(MINTURL).unwrap();
 
     // NUT-09
     test_get_mint_info(&client).await;
@@ -30,13 +36,11 @@ async fn main() {
     );
     let new_token = test_receive(&wallet, &token.to_string()).await;
 
-    let proofs = Token::from_str(&new_token).unwrap().token[0].clone().proofs;
-    test_send(&wallet, proofs.clone()).await;
-
+    let _proofs = Token::from_str(&new_token).unwrap().token[0].clone().proofs;
     let spendable = test_check_spendable(&client, &new_token).await;
+    let proofs = test_send(&wallet, spendable).await;
 
-    let invoice = Invoice::from_str("lnbc20n1pjy3tp8pp5mmrp5vhzrmsz4d6sew77aw0wr7dfxptumxvstsl8peu8ypjhdmwsdq5g9kxy7fqd9h8vmmfvdjscqzpgxqyz5vqsp5aajwlqyxwwtk57tnxzgf9rk6mp0u3z33ksylqj6lu7et7dvlkdvs9qyyssq02rdva0hvamlgvfau0mqnknglk02v6d6x56xh5s8dtx9crtdrwf9hf6f87kk2n7tt0fsjg4xsyd50rqayxln5p9ygvetqtyrrtvy5ygpcjjwek").unwrap();
-    test_melt(&wallet, invoice, spendable).await;
+    test_melt(&wallet, Invoice::from_str(MELTINVOICE).unwrap(), proofs).await;
 
     test_check_fees(&client).await;
 }
@@ -56,13 +60,19 @@ async fn test_get_mint_keysets(client: &Client) {
 }
 
 async fn test_request_mint(wallet: &CashuWallet) {
-    let mint = wallet.request_mint(Amount::from_sat(5)).await.unwrap();
+    let mint = wallet
+        .request_mint(Amount::from_sat(MINTAMOUNT))
+        .await
+        .unwrap();
 
     assert!(mint.pr.check_signature().is_ok())
 }
 
 async fn test_mint(wallet: &CashuWallet) -> Proofs {
-    let mint_req = wallet.request_mint(Amount::from_sat(5)).await.unwrap();
+    let mint_req = wallet
+        .request_mint(Amount::from_sat(MINTAMOUNT))
+        .await
+        .unwrap();
     println!("Mint Req: {:?}", mint_req.pr.to_string());
 
     // Since before the mint happens the invoice in the mint req has to be paid this wait is here
@@ -71,7 +81,7 @@ async fn test_mint(wallet: &CashuWallet) -> Proofs {
     thread::sleep(Duration::from_secs(30));
 
     wallet
-        .mint_token(Amount::from_sat(5), &mint_req.hash)
+        .mint_token(Amount::from_sat(MINTAMOUNT), &mint_req.hash)
         .await
         .unwrap()
 
@@ -79,7 +89,7 @@ async fn test_mint(wallet: &CashuWallet) -> Proofs {
 }
 
 async fn test_check_fees(mint: &Client) {
-    let invoice = Invoice::from_str("lnbc10n1p3a6s0dsp5n55r506t2fv4r0mjcg30v569nk2u9s40ur4v3r3mgtscjvkvnrqqpp5lzfv8fmjzduelk74y9rsrxrayvhyzcdsh3zkdgv0g50napzalvqsdqhf9h8vmmfvdjn5gp58qengdqxq8p3aaymdcqpjrzjqwryaup9lh50kkranzgcdnn2fgvx390wgj5jd07rwr3vxeje0glc7z70cgqqg4sqqqqqqqlgqqqqrucqjq9qyysgqrjky5axsldzhqsjwsc38xa37k6t04le3ws4t26nqej62vst5xkz56qw85r6c4a3tr79588e0ceuuahwgfnkqc6n6269unlwqtvwr5vqqy0ncdq").unwrap();
+    let invoice = Invoice::from_str(MELTINVOICE).unwrap();
 
     let _fee = mint.check_fees(invoice).await.unwrap();
     // println!("{fee:?}");
@@ -99,7 +109,7 @@ async fn test_receive(wallet: &CashuWallet, token: &str) -> String {
     };
 
     let s = token.to_string();
-    println!("{s}");
+    // println!("{s}");
     s
 }
 
@@ -114,23 +124,29 @@ async fn test_check_spendable(client: &Client, token: &str) -> Proofs {
         .await
         .unwrap();
 
+    println!("Spendable: {:?}", spendable);
     assert!(!spendable.spendable.is_empty());
-    // println!("Spendable: {:?}", spendable);
 
     spendable.spendable
 }
 
-async fn test_send(wallet: &CashuWallet, proofs: Proofs) {
-    let send = wallet.send(Amount::from_sat(2), proofs).await.unwrap();
+async fn test_send(wallet: &CashuWallet, proofs: Proofs) -> Proofs {
+    let send = wallet
+        .send(Amount::from_sat(SENDAMOUNT), proofs)
+        .await
+        .unwrap();
 
     println!("{:?}", send);
 
     let keep_token = wallet.proofs_to_token(send.change_proofs, Some("Keeping these".to_string()));
 
-    let send_token = wallet.proofs_to_token(send.send_proofs, Some("Sending these".to_string()));
+    let send_token =
+        wallet.proofs_to_token(send.send_proofs.clone(), Some("Sending these".to_string()));
 
     println!("Keep Token: {keep_token}");
     println!("Send Token: {send_token}");
+
+    send.send_proofs
 }
 
 async fn test_melt(wallet: &CashuWallet, invoice: Invoice, proofs: Proofs) {

+ 2 - 0
src/client.rs

@@ -129,6 +129,8 @@ impl Client {
             .send()?
             .json::<Value>()?;
 
+        println!("{:?}", value);
+
         Ok(serde_json::from_value(value)?)
     }