#![allow(unused_imports)]
use async_trait::async_trait;
use derive_builder::Builder;
use reqwest;
use rust_decimal::prelude::*;
use serde::{Deserialize, Serialize};
use serde_json::{Value, json};
use std::collections::BTreeMap;
use crate::common::{
config::ConfigurationRestApi,
models::{ParamBuildError, RestApiResponse},
utils::send_request,
};
use crate::staking::rest_api::models;
const HAS_TIME_UNIT: bool = false;
#[async_trait]
pub trait SolStakingApi: Send + Sync {
async fn claim_boost_rewards(
&self,
params: ClaimBoostRewardsParams,
) -> anyhow::Result<RestApiResponse<models::ClaimBoostRewardsResponse>>;
async fn get_bnsol_rate_history(
&self,
params: GetBnsolRateHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetBnsolRateHistoryResponse>>;
async fn get_bnsol_rewards_history(
&self,
params: GetBnsolRewardsHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetBnsolRewardsHistoryResponse>>;
async fn get_boost_rewards_history(
&self,
params: GetBoostRewardsHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetBoostRewardsHistoryResponse>>;
async fn get_sol_redemption_history(
&self,
params: GetSolRedemptionHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetSolRedemptionHistoryResponse>>;
async fn get_sol_staking_history(
&self,
params: GetSolStakingHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetSolStakingHistoryResponse>>;
async fn get_sol_staking_quota_details(
&self,
params: GetSolStakingQuotaDetailsParams,
) -> anyhow::Result<RestApiResponse<models::GetSolStakingQuotaDetailsResponse>>;
async fn get_unclaimed_rewards(
&self,
params: GetUnclaimedRewardsParams,
) -> anyhow::Result<RestApiResponse<Vec<models::GetUnclaimedRewardsResponseInner>>>;
async fn redeem_sol(
&self,
params: RedeemSolParams,
) -> anyhow::Result<RestApiResponse<models::RedeemSolResponse>>;
async fn sol_staking_account(
&self,
params: SolStakingAccountParams,
) -> anyhow::Result<RestApiResponse<models::SolStakingAccountResponse>>;
async fn subscribe_sol_staking(
&self,
params: SubscribeSolStakingParams,
) -> anyhow::Result<RestApiResponse<models::SubscribeSolStakingResponse>>;
}
#[derive(Debug, Clone)]
pub struct SolStakingApiClient {
configuration: ConfigurationRestApi,
}
impl SolStakingApiClient {
pub fn new(configuration: ConfigurationRestApi) -> Self {
Self { configuration }
}
}
#[derive(Clone, Debug, Builder, Default)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct ClaimBoostRewardsParams {
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl ClaimBoostRewardsParams {
#[must_use]
pub fn builder() -> ClaimBoostRewardsParamsBuilder {
ClaimBoostRewardsParamsBuilder::default()
}
}
#[derive(Clone, Debug, Builder, Default)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct GetBnsolRateHistoryParams {
#[builder(setter(into), default)]
pub start_time: Option<i64>,
#[builder(setter(into), default)]
pub end_time: Option<i64>,
#[builder(setter(into), default)]
pub current: Option<i64>,
#[builder(setter(into), default)]
pub size: Option<i64>,
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl GetBnsolRateHistoryParams {
#[must_use]
pub fn builder() -> GetBnsolRateHistoryParamsBuilder {
GetBnsolRateHistoryParamsBuilder::default()
}
}
#[derive(Clone, Debug, Builder, Default)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct GetBnsolRewardsHistoryParams {
#[builder(setter(into), default)]
pub start_time: Option<i64>,
#[builder(setter(into), default)]
pub end_time: Option<i64>,
#[builder(setter(into), default)]
pub current: Option<i64>,
#[builder(setter(into), default)]
pub size: Option<i64>,
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl GetBnsolRewardsHistoryParams {
#[must_use]
pub fn builder() -> GetBnsolRewardsHistoryParamsBuilder {
GetBnsolRewardsHistoryParamsBuilder::default()
}
}
#[derive(Clone, Debug, Builder)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct GetBoostRewardsHistoryParams {
#[builder(setter(into))]
pub r#type: String,
#[builder(setter(into), default)]
pub start_time: Option<i64>,
#[builder(setter(into), default)]
pub end_time: Option<i64>,
#[builder(setter(into), default)]
pub current: Option<i64>,
#[builder(setter(into), default)]
pub size: Option<i64>,
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl GetBoostRewardsHistoryParams {
#[must_use]
pub fn builder(r#type: String) -> GetBoostRewardsHistoryParamsBuilder {
GetBoostRewardsHistoryParamsBuilder::default().r#type(r#type)
}
}
#[derive(Clone, Debug, Builder, Default)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct GetSolRedemptionHistoryParams {
#[builder(setter(into), default)]
pub redeem_id: Option<i64>,
#[builder(setter(into), default)]
pub start_time: Option<i64>,
#[builder(setter(into), default)]
pub end_time: Option<i64>,
#[builder(setter(into), default)]
pub current: Option<i64>,
#[builder(setter(into), default)]
pub size: Option<i64>,
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl GetSolRedemptionHistoryParams {
#[must_use]
pub fn builder() -> GetSolRedemptionHistoryParamsBuilder {
GetSolRedemptionHistoryParamsBuilder::default()
}
}
#[derive(Clone, Debug, Builder, Default)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct GetSolStakingHistoryParams {
#[builder(setter(into), default)]
pub purchase_id: Option<i64>,
#[builder(setter(into), default)]
pub start_time: Option<i64>,
#[builder(setter(into), default)]
pub end_time: Option<i64>,
#[builder(setter(into), default)]
pub current: Option<i64>,
#[builder(setter(into), default)]
pub size: Option<i64>,
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl GetSolStakingHistoryParams {
#[must_use]
pub fn builder() -> GetSolStakingHistoryParamsBuilder {
GetSolStakingHistoryParamsBuilder::default()
}
}
#[derive(Clone, Debug, Builder, Default)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct GetSolStakingQuotaDetailsParams {
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl GetSolStakingQuotaDetailsParams {
#[must_use]
pub fn builder() -> GetSolStakingQuotaDetailsParamsBuilder {
GetSolStakingQuotaDetailsParamsBuilder::default()
}
}
#[derive(Clone, Debug, Builder, Default)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct GetUnclaimedRewardsParams {
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl GetUnclaimedRewardsParams {
#[must_use]
pub fn builder() -> GetUnclaimedRewardsParamsBuilder {
GetUnclaimedRewardsParamsBuilder::default()
}
}
#[derive(Clone, Debug, Builder)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct RedeemSolParams {
#[builder(setter(into))]
pub amount: rust_decimal::Decimal,
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl RedeemSolParams {
#[must_use]
pub fn builder(amount: rust_decimal::Decimal) -> RedeemSolParamsBuilder {
RedeemSolParamsBuilder::default().amount(amount)
}
}
#[derive(Clone, Debug, Builder, Default)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct SolStakingAccountParams {
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl SolStakingAccountParams {
#[must_use]
pub fn builder() -> SolStakingAccountParamsBuilder {
SolStakingAccountParamsBuilder::default()
}
}
#[derive(Clone, Debug, Builder)]
#[builder(pattern = "owned", build_fn(error = "ParamBuildError"))]
pub struct SubscribeSolStakingParams {
#[builder(setter(into))]
pub amount: rust_decimal::Decimal,
#[builder(setter(into), default)]
pub recv_window: Option<i64>,
}
impl SubscribeSolStakingParams {
#[must_use]
pub fn builder(amount: rust_decimal::Decimal) -> SubscribeSolStakingParamsBuilder {
SubscribeSolStakingParamsBuilder::default().amount(amount)
}
}
#[async_trait]
impl SolStakingApi for SolStakingApiClient {
async fn claim_boost_rewards(
&self,
params: ClaimBoostRewardsParams,
) -> anyhow::Result<RestApiResponse<models::ClaimBoostRewardsResponse>> {
let ClaimBoostRewardsParams { recv_window } = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::ClaimBoostRewardsResponse>(
&self.configuration,
"/sapi/v1/sol-staking/sol/claim",
reqwest::Method::POST,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn get_bnsol_rate_history(
&self,
params: GetBnsolRateHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetBnsolRateHistoryResponse>> {
let GetBnsolRateHistoryParams {
start_time,
end_time,
current,
size,
recv_window,
} = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
if let Some(rw) = start_time {
query_params.insert("startTime".to_string(), json!(rw));
}
if let Some(rw) = end_time {
query_params.insert("endTime".to_string(), json!(rw));
}
if let Some(rw) = current {
query_params.insert("current".to_string(), json!(rw));
}
if let Some(rw) = size {
query_params.insert("size".to_string(), json!(rw));
}
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::GetBnsolRateHistoryResponse>(
&self.configuration,
"/sapi/v1/sol-staking/sol/history/rateHistory",
reqwest::Method::GET,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn get_bnsol_rewards_history(
&self,
params: GetBnsolRewardsHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetBnsolRewardsHistoryResponse>> {
let GetBnsolRewardsHistoryParams {
start_time,
end_time,
current,
size,
recv_window,
} = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
if let Some(rw) = start_time {
query_params.insert("startTime".to_string(), json!(rw));
}
if let Some(rw) = end_time {
query_params.insert("endTime".to_string(), json!(rw));
}
if let Some(rw) = current {
query_params.insert("current".to_string(), json!(rw));
}
if let Some(rw) = size {
query_params.insert("size".to_string(), json!(rw));
}
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::GetBnsolRewardsHistoryResponse>(
&self.configuration,
"/sapi/v1/sol-staking/sol/history/bnsolRewardsHistory",
reqwest::Method::GET,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn get_boost_rewards_history(
&self,
params: GetBoostRewardsHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetBoostRewardsHistoryResponse>> {
let GetBoostRewardsHistoryParams {
r#type,
start_time,
end_time,
current,
size,
recv_window,
} = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
query_params.insert("type".to_string(), json!(r#type));
if let Some(rw) = start_time {
query_params.insert("startTime".to_string(), json!(rw));
}
if let Some(rw) = end_time {
query_params.insert("endTime".to_string(), json!(rw));
}
if let Some(rw) = current {
query_params.insert("current".to_string(), json!(rw));
}
if let Some(rw) = size {
query_params.insert("size".to_string(), json!(rw));
}
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::GetBoostRewardsHistoryResponse>(
&self.configuration,
"/sapi/v1/sol-staking/sol/history/boostRewardsHistory",
reqwest::Method::GET,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn get_sol_redemption_history(
&self,
params: GetSolRedemptionHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetSolRedemptionHistoryResponse>> {
let GetSolRedemptionHistoryParams {
redeem_id,
start_time,
end_time,
current,
size,
recv_window,
} = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
if let Some(rw) = redeem_id {
query_params.insert("redeemId".to_string(), json!(rw));
}
if let Some(rw) = start_time {
query_params.insert("startTime".to_string(), json!(rw));
}
if let Some(rw) = end_time {
query_params.insert("endTime".to_string(), json!(rw));
}
if let Some(rw) = current {
query_params.insert("current".to_string(), json!(rw));
}
if let Some(rw) = size {
query_params.insert("size".to_string(), json!(rw));
}
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::GetSolRedemptionHistoryResponse>(
&self.configuration,
"/sapi/v1/sol-staking/sol/history/redemptionHistory",
reqwest::Method::GET,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn get_sol_staking_history(
&self,
params: GetSolStakingHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetSolStakingHistoryResponse>> {
let GetSolStakingHistoryParams {
purchase_id,
start_time,
end_time,
current,
size,
recv_window,
} = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
if let Some(rw) = purchase_id {
query_params.insert("purchaseId".to_string(), json!(rw));
}
if let Some(rw) = start_time {
query_params.insert("startTime".to_string(), json!(rw));
}
if let Some(rw) = end_time {
query_params.insert("endTime".to_string(), json!(rw));
}
if let Some(rw) = current {
query_params.insert("current".to_string(), json!(rw));
}
if let Some(rw) = size {
query_params.insert("size".to_string(), json!(rw));
}
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::GetSolStakingHistoryResponse>(
&self.configuration,
"/sapi/v1/sol-staking/sol/history/stakingHistory",
reqwest::Method::GET,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn get_sol_staking_quota_details(
&self,
params: GetSolStakingQuotaDetailsParams,
) -> anyhow::Result<RestApiResponse<models::GetSolStakingQuotaDetailsResponse>> {
let GetSolStakingQuotaDetailsParams { recv_window } = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::GetSolStakingQuotaDetailsResponse>(
&self.configuration,
"/sapi/v1/sol-staking/sol/quota",
reqwest::Method::GET,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn get_unclaimed_rewards(
&self,
params: GetUnclaimedRewardsParams,
) -> anyhow::Result<RestApiResponse<Vec<models::GetUnclaimedRewardsResponseInner>>> {
let GetUnclaimedRewardsParams { recv_window } = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<Vec<models::GetUnclaimedRewardsResponseInner>>(
&self.configuration,
"/sapi/v1/sol-staking/sol/history/unclaimedRewards",
reqwest::Method::GET,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn redeem_sol(
&self,
params: RedeemSolParams,
) -> anyhow::Result<RestApiResponse<models::RedeemSolResponse>> {
let RedeemSolParams {
amount,
recv_window,
} = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
query_params.insert("amount".to_string(), json!(amount));
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::RedeemSolResponse>(
&self.configuration,
"/sapi/v1/sol-staking/sol/redeem",
reqwest::Method::POST,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn sol_staking_account(
&self,
params: SolStakingAccountParams,
) -> anyhow::Result<RestApiResponse<models::SolStakingAccountResponse>> {
let SolStakingAccountParams { recv_window } = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::SolStakingAccountResponse>(
&self.configuration,
"/sapi/v1/sol-staking/account",
reqwest::Method::GET,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
async fn subscribe_sol_staking(
&self,
params: SubscribeSolStakingParams,
) -> anyhow::Result<RestApiResponse<models::SubscribeSolStakingResponse>> {
let SubscribeSolStakingParams {
amount,
recv_window,
} = params;
let mut query_params = BTreeMap::new();
let body_params = BTreeMap::new();
query_params.insert("amount".to_string(), json!(amount));
if let Some(rw) = recv_window {
query_params.insert("recvWindow".to_string(), json!(rw));
}
send_request::<models::SubscribeSolStakingResponse>(
&self.configuration,
"/sapi/v1/sol-staking/sol/stake",
reqwest::Method::POST,
query_params,
body_params,
if HAS_TIME_UNIT {
self.configuration.time_unit
} else {
None
},
true,
)
.await
}
}
#[cfg(all(test, feature = "staking"))]
mod tests {
use super::*;
use crate::TOKIO_SHARED_RT;
use crate::{errors::ConnectorError, models::DataFuture, models::RestApiRateLimit};
use async_trait::async_trait;
use std::collections::HashMap;
struct DummyRestApiResponse<T> {
inner: Box<dyn FnOnce() -> DataFuture<Result<T, ConnectorError>> + Send + Sync>,
status: u16,
headers: HashMap<String, String>,
rate_limits: Option<Vec<RestApiRateLimit>>,
}
impl<T> From<DummyRestApiResponse<T>> for RestApiResponse<T> {
fn from(dummy: DummyRestApiResponse<T>) -> Self {
Self {
data_fn: dummy.inner,
status: dummy.status,
headers: dummy.headers,
rate_limits: dummy.rate_limits,
}
}
}
struct MockSolStakingApiClient {
force_error: bool,
}
#[async_trait]
impl SolStakingApi for MockSolStakingApiClient {
async fn claim_boost_rewards(
&self,
_params: ClaimBoostRewardsParams,
) -> anyhow::Result<RestApiResponse<models::ClaimBoostRewardsResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"success":true}"#).unwrap();
let dummy_response: models::ClaimBoostRewardsResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::ClaimBoostRewardsResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn get_bnsol_rate_history(
&self,
_params: GetBnsolRateHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetBnsolRateHistoryResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"annualPercentageRate":"0.00006408","exchangeRate":"1.001212343432","boostRewards":[{"boostAPR":"0.12000000","rewardsAsset":"SOL"},{"boostAPR":"0.00200000","rewardsAsset":"BNB"}],"time":1577233578000}],"total":"1"}"#).unwrap();
let dummy_response: models::GetBnsolRateHistoryResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::GetBnsolRateHistoryResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn get_bnsol_rewards_history(
&self,
_params: GetBnsolRewardsHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetBnsolRewardsHistoryResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"estRewardsInSOL":"1.23230920","rows":[{"time":1575018510000,"amountInSOL":"0.23223","holding":"2.3223","holdingInSOL":"2.4231","annualPercentageRate":"0.5"}],"total":1}"#).unwrap();
let dummy_response: models::GetBnsolRewardsHistoryResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::GetBnsolRewardsHistoryResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn get_boost_rewards_history(
&self,
_params: GetBoostRewardsHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetBoostRewardsHistoryResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"time":1729520680,"token":"SOL","amount":"1.20291028","bnsolHolding":"2.0928798","status":"SUCCESS"}],"total":1}"#).unwrap();
let dummy_response: models::GetBoostRewardsHistoryResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::GetBoostRewardsHistoryResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn get_sol_redemption_history(
&self,
_params: GetSolRedemptionHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetSolRedemptionHistoryResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"time":1575018510000,"arrivalTime":1575018510000,"asset":"BNSOL","amount":"21312.23223","distributeAsset":"SOL","distributeAmount":"21338.0699","exchangeRate":"1.00121234","status":"SUCCESS"}],"total":1}"#).unwrap();
let dummy_response: models::GetSolRedemptionHistoryResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::GetSolRedemptionHistoryResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn get_sol_staking_history(
&self,
_params: GetSolStakingHistoryParams,
) -> anyhow::Result<RestApiResponse<models::GetSolStakingHistoryResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"time":1575018510000,"asset":"SOL","amount":"21312.23223","distributeAsset":"BNSOL","distributeAmount":"21286.42584","exchangeRate":"1.00121234","status":"SUCCESS"}],"total":1}"#).unwrap();
let dummy_response: models::GetSolStakingHistoryResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::GetSolStakingHistoryResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn get_sol_staking_quota_details(
&self,
_params: GetSolStakingQuotaDetailsParams,
) -> anyhow::Result<RestApiResponse<models::GetSolStakingQuotaDetailsResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"leftStakingPersonalQuota":"1000","leftRedemptionPersonalQuota":"1000","minStakeAmount":"0.01000000","minRedeemAmount":"0.00000001","redeemPeriod":4,"stakeable":true,"redeemable":true,"soldOut":false,"commissionFee":"0.25000000","nextEpochTime":725993969475,"calculating":false}"#).unwrap();
let dummy_response: models::GetSolStakingQuotaDetailsResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::GetSolStakingQuotaDetailsResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn get_unclaimed_rewards(
&self,
_params: GetUnclaimedRewardsParams,
) -> anyhow::Result<RestApiResponse<Vec<models::GetUnclaimedRewardsResponseInner>>>
{
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"[{"amount":"1.00000011","rewardsAsset":"SOL"},{"amount":"2.00202321","rewardsAsset":"BNB"}]"#).unwrap();
let dummy_response: Vec<models::GetUnclaimedRewardsResponseInner> =
serde_json::from_value(resp_json.clone())
.expect("should parse into Vec<models::GetUnclaimedRewardsResponseInner>");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn redeem_sol(
&self,
_params: RedeemSolParams,
) -> anyhow::Result<RestApiResponse<models::RedeemSolResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"success":true,"solAmount":"0.23092091","exchangeRate":"1.00121234","arrivalTime":1575018510000,"redeemId":1234567}"#).unwrap();
let dummy_response: models::RedeemSolResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::RedeemSolResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn sol_staking_account(
&self,
_params: SolStakingAccountParams,
) -> anyhow::Result<RestApiResponse<models::SolStakingAccountResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"bnsolAmount":"1.10928781","holdingInSOL":"1.22330928","thirtyDaysProfitInSOL":"0.22330928"}"#).unwrap();
let dummy_response: models::SolStakingAccountResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::SolStakingAccountResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
async fn subscribe_sol_staking(
&self,
_params: SubscribeSolStakingParams,
) -> anyhow::Result<RestApiResponse<models::SubscribeSolStakingResponse>> {
if self.force_error {
return Err(ConnectorError::ConnectorClientError {
msg: "ResponseError".to_string(),
code: None,
}
.into());
}
let resp_json: Value = serde_json::from_str(r#"{"success":true,"bnsolAmount":"0.23092091","exchangeRate":"1.001212342342","purchaseId":1234567}"#).unwrap();
let dummy_response: models::SubscribeSolStakingResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::SubscribeSolStakingResponse");
let dummy = DummyRestApiResponse {
inner: Box::new(move || Box::pin(async move { Ok(dummy_response) })),
status: 200,
headers: HashMap::new(),
rate_limits: None,
};
Ok(dummy.into())
}
}
#[test]
fn claim_boost_rewards_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = ClaimBoostRewardsParams::builder().build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"success":true}"#).unwrap();
let expected_response: models::ClaimBoostRewardsResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::ClaimBoostRewardsResponse");
let resp = client
.claim_boost_rewards(params)
.await
.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn claim_boost_rewards_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = ClaimBoostRewardsParams::builder()
.recv_window(5000)
.build()
.unwrap();
let resp_json: Value = serde_json::from_str(r#"{"success":true}"#).unwrap();
let expected_response: models::ClaimBoostRewardsResponse =
serde_json::from_value(resp_json.clone())
.expect("should parse into models::ClaimBoostRewardsResponse");
let resp = client
.claim_boost_rewards(params)
.await
.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn claim_boost_rewards_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = ClaimBoostRewardsParams::builder().build().unwrap();
match client.claim_boost_rewards(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn get_bnsol_rate_history_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetBnsolRateHistoryParams::builder().build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"annualPercentageRate":"0.00006408","exchangeRate":"1.001212343432","boostRewards":[{"boostAPR":"0.12000000","rewardsAsset":"SOL"},{"boostAPR":"0.00200000","rewardsAsset":"BNB"}],"time":1577233578000}],"total":"1"}"#).unwrap();
let expected_response : models::GetBnsolRateHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetBnsolRateHistoryResponse");
let resp = client.get_bnsol_rate_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_bnsol_rate_history_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetBnsolRateHistoryParams::builder().start_time(1623319461670).end_time(1641782889000).current(1).size(10).recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"annualPercentageRate":"0.00006408","exchangeRate":"1.001212343432","boostRewards":[{"boostAPR":"0.12000000","rewardsAsset":"SOL"},{"boostAPR":"0.00200000","rewardsAsset":"BNB"}],"time":1577233578000}],"total":"1"}"#).unwrap();
let expected_response : models::GetBnsolRateHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetBnsolRateHistoryResponse");
let resp = client.get_bnsol_rate_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_bnsol_rate_history_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = GetBnsolRateHistoryParams::builder().build().unwrap();
match client.get_bnsol_rate_history(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn get_bnsol_rewards_history_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetBnsolRewardsHistoryParams::builder().build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"estRewardsInSOL":"1.23230920","rows":[{"time":1575018510000,"amountInSOL":"0.23223","holding":"2.3223","holdingInSOL":"2.4231","annualPercentageRate":"0.5"}],"total":1}"#).unwrap();
let expected_response : models::GetBnsolRewardsHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetBnsolRewardsHistoryResponse");
let resp = client.get_bnsol_rewards_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_bnsol_rewards_history_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetBnsolRewardsHistoryParams::builder().start_time(1623319461670).end_time(1641782889000).current(1).size(10).recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"estRewardsInSOL":"1.23230920","rows":[{"time":1575018510000,"amountInSOL":"0.23223","holding":"2.3223","holdingInSOL":"2.4231","annualPercentageRate":"0.5"}],"total":1}"#).unwrap();
let expected_response : models::GetBnsolRewardsHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetBnsolRewardsHistoryResponse");
let resp = client.get_bnsol_rewards_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_bnsol_rewards_history_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = GetBnsolRewardsHistoryParams::builder().build().unwrap();
match client.get_bnsol_rewards_history(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn get_boost_rewards_history_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetBoostRewardsHistoryParams::builder("CLAIM".to_string(),).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"time":1729520680,"token":"SOL","amount":"1.20291028","bnsolHolding":"2.0928798","status":"SUCCESS"}],"total":1}"#).unwrap();
let expected_response : models::GetBoostRewardsHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetBoostRewardsHistoryResponse");
let resp = client.get_boost_rewards_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_boost_rewards_history_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetBoostRewardsHistoryParams::builder("CLAIM".to_string(),).start_time(1623319461670).end_time(1641782889000).current(1).size(10).recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"time":1729520680,"token":"SOL","amount":"1.20291028","bnsolHolding":"2.0928798","status":"SUCCESS"}],"total":1}"#).unwrap();
let expected_response : models::GetBoostRewardsHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetBoostRewardsHistoryResponse");
let resp = client.get_boost_rewards_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_boost_rewards_history_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = GetBoostRewardsHistoryParams::builder("CLAIM".to_string())
.build()
.unwrap();
match client.get_boost_rewards_history(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn get_sol_redemption_history_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetSolRedemptionHistoryParams::builder().build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"time":1575018510000,"arrivalTime":1575018510000,"asset":"BNSOL","amount":"21312.23223","distributeAsset":"SOL","distributeAmount":"21338.0699","exchangeRate":"1.00121234","status":"SUCCESS"}],"total":1}"#).unwrap();
let expected_response : models::GetSolRedemptionHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetSolRedemptionHistoryResponse");
let resp = client.get_sol_redemption_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_sol_redemption_history_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetSolRedemptionHistoryParams::builder().redeem_id(1).start_time(1623319461670).end_time(1641782889000).current(1).size(10).recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"time":1575018510000,"arrivalTime":1575018510000,"asset":"BNSOL","amount":"21312.23223","distributeAsset":"SOL","distributeAmount":"21338.0699","exchangeRate":"1.00121234","status":"SUCCESS"}],"total":1}"#).unwrap();
let expected_response : models::GetSolRedemptionHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetSolRedemptionHistoryResponse");
let resp = client.get_sol_redemption_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_sol_redemption_history_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = GetSolRedemptionHistoryParams::builder().build().unwrap();
match client.get_sol_redemption_history(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn get_sol_staking_history_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetSolStakingHistoryParams::builder().build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"time":1575018510000,"asset":"SOL","amount":"21312.23223","distributeAsset":"BNSOL","distributeAmount":"21286.42584","exchangeRate":"1.00121234","status":"SUCCESS"}],"total":1}"#).unwrap();
let expected_response : models::GetSolStakingHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetSolStakingHistoryResponse");
let resp = client.get_sol_staking_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_sol_staking_history_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetSolStakingHistoryParams::builder().purchase_id(1).start_time(1623319461670).end_time(1641782889000).current(1).size(10).recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"rows":[{"time":1575018510000,"asset":"SOL","amount":"21312.23223","distributeAsset":"BNSOL","distributeAmount":"21286.42584","exchangeRate":"1.00121234","status":"SUCCESS"}],"total":1}"#).unwrap();
let expected_response : models::GetSolStakingHistoryResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetSolStakingHistoryResponse");
let resp = client.get_sol_staking_history(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_sol_staking_history_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = GetSolStakingHistoryParams::builder().build().unwrap();
match client.get_sol_staking_history(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn get_sol_staking_quota_details_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetSolStakingQuotaDetailsParams::builder().build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"leftStakingPersonalQuota":"1000","leftRedemptionPersonalQuota":"1000","minStakeAmount":"0.01000000","minRedeemAmount":"0.00000001","redeemPeriod":4,"stakeable":true,"redeemable":true,"soldOut":false,"commissionFee":"0.25000000","nextEpochTime":725993969475,"calculating":false}"#).unwrap();
let expected_response : models::GetSolStakingQuotaDetailsResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetSolStakingQuotaDetailsResponse");
let resp = client.get_sol_staking_quota_details(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_sol_staking_quota_details_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetSolStakingQuotaDetailsParams::builder().recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"leftStakingPersonalQuota":"1000","leftRedemptionPersonalQuota":"1000","minStakeAmount":"0.01000000","minRedeemAmount":"0.00000001","redeemPeriod":4,"stakeable":true,"redeemable":true,"soldOut":false,"commissionFee":"0.25000000","nextEpochTime":725993969475,"calculating":false}"#).unwrap();
let expected_response : models::GetSolStakingQuotaDetailsResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::GetSolStakingQuotaDetailsResponse");
let resp = client.get_sol_staking_quota_details(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_sol_staking_quota_details_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = GetSolStakingQuotaDetailsParams::builder().build().unwrap();
match client.get_sol_staking_quota_details(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn get_unclaimed_rewards_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetUnclaimedRewardsParams::builder().build().unwrap();
let resp_json: Value = serde_json::from_str(r#"[{"amount":"1.00000011","rewardsAsset":"SOL"},{"amount":"2.00202321","rewardsAsset":"BNB"}]"#).unwrap();
let expected_response : Vec<models::GetUnclaimedRewardsResponseInner> = serde_json::from_value(resp_json.clone()).expect("should parse into Vec<models::GetUnclaimedRewardsResponseInner>");
let resp = client.get_unclaimed_rewards(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_unclaimed_rewards_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = GetUnclaimedRewardsParams::builder().recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"[{"amount":"1.00000011","rewardsAsset":"SOL"},{"amount":"2.00202321","rewardsAsset":"BNB"}]"#).unwrap();
let expected_response : Vec<models::GetUnclaimedRewardsResponseInner> = serde_json::from_value(resp_json.clone()).expect("should parse into Vec<models::GetUnclaimedRewardsResponseInner>");
let resp = client.get_unclaimed_rewards(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn get_unclaimed_rewards_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = GetUnclaimedRewardsParams::builder().build().unwrap();
match client.get_unclaimed_rewards(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn redeem_sol_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = RedeemSolParams::builder(dec!(1.0),).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"success":true,"solAmount":"0.23092091","exchangeRate":"1.00121234","arrivalTime":1575018510000,"redeemId":1234567}"#).unwrap();
let expected_response : models::RedeemSolResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::RedeemSolResponse");
let resp = client.redeem_sol(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn redeem_sol_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = RedeemSolParams::builder(dec!(1.0),).recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"success":true,"solAmount":"0.23092091","exchangeRate":"1.00121234","arrivalTime":1575018510000,"redeemId":1234567}"#).unwrap();
let expected_response : models::RedeemSolResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::RedeemSolResponse");
let resp = client.redeem_sol(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn redeem_sol_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = RedeemSolParams::builder(dec!(1.0)).build().unwrap();
match client.redeem_sol(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn sol_staking_account_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = SolStakingAccountParams::builder().build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"bnsolAmount":"1.10928781","holdingInSOL":"1.22330928","thirtyDaysProfitInSOL":"0.22330928"}"#).unwrap();
let expected_response : models::SolStakingAccountResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::SolStakingAccountResponse");
let resp = client.sol_staking_account(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn sol_staking_account_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = SolStakingAccountParams::builder().recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"bnsolAmount":"1.10928781","holdingInSOL":"1.22330928","thirtyDaysProfitInSOL":"0.22330928"}"#).unwrap();
let expected_response : models::SolStakingAccountResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::SolStakingAccountResponse");
let resp = client.sol_staking_account(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn sol_staking_account_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = SolStakingAccountParams::builder().build().unwrap();
match client.sol_staking_account(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
#[test]
fn subscribe_sol_staking_required_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = SubscribeSolStakingParams::builder(dec!(1.0),).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"success":true,"bnsolAmount":"0.23092091","exchangeRate":"1.001212342342","purchaseId":1234567}"#).unwrap();
let expected_response : models::SubscribeSolStakingResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::SubscribeSolStakingResponse");
let resp = client.subscribe_sol_staking(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn subscribe_sol_staking_optional_params_success() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: false };
let params = SubscribeSolStakingParams::builder(dec!(1.0),).recv_window(5000).build().unwrap();
let resp_json: Value = serde_json::from_str(r#"{"success":true,"bnsolAmount":"0.23092091","exchangeRate":"1.001212342342","purchaseId":1234567}"#).unwrap();
let expected_response : models::SubscribeSolStakingResponse = serde_json::from_value(resp_json.clone()).expect("should parse into models::SubscribeSolStakingResponse");
let resp = client.subscribe_sol_staking(params).await.expect("Expected a response");
let data_future = resp.data();
let actual_response = data_future.await.unwrap();
assert_eq!(actual_response, expected_response);
});
}
#[test]
fn subscribe_sol_staking_response_error() {
TOKIO_SHARED_RT.block_on(async {
let client = MockSolStakingApiClient { force_error: true };
let params = SubscribeSolStakingParams::builder(dec!(1.0))
.build()
.unwrap();
match client.subscribe_sol_staking(params).await {
Ok(_) => panic!("Expected an error"),
Err(err) => {
assert_eq!(err.to_string(), "Connector client error: ResponseError");
}
}
});
}
}