use std::str::FromStr;
use workspaces::types::{KeyType, SecretKey};
use workspaces::AccountId;
#[test]
fn test_keypair_ed25519() -> anyhow::Result<()> {
let pk_expected = "\"ed25519:DcA2MzgpJbrUATQLLceocVckhhAqrkingax4oJ9kZ847\"";
let sk_expected = "\"ed25519:3KyUuch8pYP47krBq4DosFEVBMR5wDTMQ8AThzM8kAEcBQEpsPdYTZ2FPX5ZnSoLrerjwg66hwwJaW1wHzprd5k3\"";
let sk = SecretKey::from_seed(KeyType::ED25519, "test");
let pk = sk.public_key();
assert_eq!(serde_json::to_string(&pk)?, pk_expected);
assert_eq!(serde_json::to_string(&sk)?, sk_expected);
assert_eq!(pk, serde_json::from_str(pk_expected)?);
assert_eq!(sk, serde_json::from_str(sk_expected)?);
Ok(())
}
#[test]
fn test_keypair_secp256k1() -> anyhow::Result<()> {
let pk_expected = "\"secp256k1:5ftgm7wYK5gtVqq1kxMGy7gSudkrfYCbpsjL6sH1nwx2oj5NR2JktohjzB6fbEhhRERQpiwJcpwnQjxtoX3GS3cQ\"";
let sk_expected = "\"secp256k1:X4ETFKtQkSGVoZEnkn7bZ3LyajJaK2b3eweXaKmynGx\"";
let sk = SecretKey::from_seed(KeyType::SECP256K1, "test");
let pk = sk.public_key();
assert_eq!(serde_json::to_string(&pk)?, pk_expected);
assert_eq!(serde_json::to_string(&sk)?, sk_expected);
assert_eq!(pk, serde_json::from_str(pk_expected)?);
assert_eq!(sk, serde_json::from_str(sk_expected)?);
Ok(())
}
#[test]
fn test_valid_account_id() {
let account_id = "testnet";
assert!(
AccountId::from_str(account_id).is_ok(),
"Something changed underneath for testnet to not be a valid Account ID"
);
}