df2f3d340f
* fix popularity contest * more info in the Debug for Web3Rpc * add frontend_requests and cache_misses to the Balance query * add more to balance and stats flushing and improved test coverage * it compiles * deserializer for Ulid to Uuid I think a wrapper type on Ulid that implements sea_orm::Value is probably better * rename variable to match struct name * add deserializer for Address -> Vec<u8> * sql sum returns a Decimal. need to convert to u64 * assert more * one log and assert more * log more * use a helper to get the user's rpc provider * this should be 2 now that we have a public and authed call * this should be zero. the public has the cache miss * instrument cu calcs * trace the value we took, not the default that replaced it * move usd_per_chain into config * remove some extra logging * use Arc::into_inner to maybe avoid a race * off by 1 * pass paid credits used instead of returning it this lets us use it to write to our user balance cache first. importantly, this keeps us from holding a write lock while writing to mysql * no cache misses expected in this test * actually check the admin * put the balance checks back now that the rest of the test works * archive request is being set incorrectly * wow howd we manage flipping the greater than sign on archive depth * move latest_balance and premium_credits_used to before any stats are emitted * lint * and build undoes the linting. fun i didnt even want to lint them in the first place, so this is fine * missed incrementing total_spent when not incrementing total_spent_paid_credits * use the credits on self * use the credits on self (pt 2) * fix type for 10 cu query * convert the requestmetadata on the other side of the channel * logs * viewing stats is allowed even without a balance * move paid_credits_used to AuthorizationChecks * wip * test_sum_credits_used finally passes * UserBalanceCache::get_or_insert * re-enable rpc_secret_key_cache * move invalidate to a helper function and always call it **after** the db is commited * fix PartialEq and Eq on RpcSecretKey * cargo upgrade
71 lines
2.0 KiB
Rust
71 lines
2.0 KiB
Rust
mod common;
|
|
|
|
use std::str::FromStr;
|
|
use std::time::Duration;
|
|
|
|
use crate::common::admin_increases_balance::admin_increase_balance;
|
|
use crate::common::create_admin::create_user_as_admin;
|
|
use crate::common::create_user::{create_user, set_user_tier};
|
|
use crate::common::user_balance::user_get_balance;
|
|
use crate::common::TestApp;
|
|
use migration::sea_orm::prelude::Decimal;
|
|
use tracing::info;
|
|
|
|
// #[cfg_attr(not(feature = "tests-needing-docker"), ignore)]
|
|
#[ignore = "under construction"]
|
|
#[test_log::test(tokio::test)]
|
|
async fn test_admin_imitate_user() {
|
|
let x = TestApp::spawn(31337, true).await;
|
|
|
|
todo!();
|
|
}
|
|
|
|
#[cfg_attr(not(feature = "tests-needing-docker"), ignore)]
|
|
#[test_log::test(tokio::test)]
|
|
async fn test_admin_grant_credits() {
|
|
info!("Starting admin grant credits test");
|
|
let x = TestApp::spawn(31337, true).await;
|
|
let r = reqwest::Client::builder()
|
|
.timeout(Duration::from_secs(3))
|
|
.build()
|
|
.unwrap();
|
|
|
|
// Setup variables that will be used
|
|
let user_wallet = x.wallet(0);
|
|
let admin_wallet = x.wallet(1);
|
|
info!(?admin_wallet);
|
|
|
|
let user_login_response = create_user(&x, &r, &user_wallet, None).await;
|
|
let admin_login_response = create_user_as_admin(&x, &r, &admin_wallet).await;
|
|
info!(?admin_login_response);
|
|
|
|
set_user_tier(&x, user_login_response.user.clone(), "Premium").await.unwrap();
|
|
|
|
let increase_balance_response = admin_increase_balance(
|
|
&x,
|
|
&r,
|
|
&admin_login_response,
|
|
&user_wallet,
|
|
Decimal::from(100),
|
|
)
|
|
.await;
|
|
|
|
assert_eq!(
|
|
Decimal::from_str(increase_balance_response["amount"].as_str().unwrap()).unwrap(),
|
|
Decimal::from(100)
|
|
);
|
|
|
|
let user_balance = user_get_balance(&x, &r, &user_login_response).await;
|
|
assert_eq!(user_balance.remaining(), Decimal::from(100));
|
|
|
|
x.wait().await;
|
|
}
|
|
|
|
// #[cfg_attr(not(feature = "tests-needing-docker"), ignore)]
|
|
#[ignore = "under construction"]
|
|
#[test_log::test(tokio::test)]
|
|
async fn test_admin_change_user_tier() {
|
|
let x = TestApp::spawn(31337, true).await;
|
|
todo!();
|
|
}
|