2021-06-30 23:34:34 +00:00
|
|
|
#![cfg_attr(feature = "nightly", feature(custom_test_frameworks))]
|
|
|
|
#![cfg_attr(feature = "nightly", test_runner(my_runner))]
|
|
|
|
|
|
|
|
mod async_tests;
|
|
|
|
mod testutils;
|
|
|
|
use testutils::*;
|
|
|
|
|
|
|
|
use colored::*;
|
|
|
|
|
|
|
|
use riven::consts::*;
|
|
|
|
|
|
|
|
const ROUTE: PlatformRoute = PlatformRoute::EUW1;
|
|
|
|
|
|
|
|
async_tests!{
|
|
|
|
my_runner {
|
|
|
|
// Champion Mastery tests.
|
|
|
|
championmastery_getscore_ma5tery: async {
|
|
|
|
let sum = RIOT_API.summoner_v4().get_by_summoner_name(ROUTE, "ma5tery");
|
2021-10-30 05:38:48 +00:00
|
|
|
let sum = sum.await.map_err(|e| e.to_string())?.ok_or_else(|| "Failed to get summoner".to_owned())?;
|
2021-06-30 23:34:34 +00:00
|
|
|
|
|
|
|
let p = RIOT_API.champion_mastery_v4().get_champion_mastery_score(ROUTE, &*sum.id);
|
|
|
|
let s = p.await.map_err(|e| e.to_string())?;
|
2021-10-30 05:38:48 +00:00
|
|
|
rassert!((969..=1000).contains(&s), "Unexpected ma5tery score: {}.", s);
|
2021-06-30 23:34:34 +00:00
|
|
|
Ok(())
|
|
|
|
},
|
|
|
|
championmastery_getall_ma5tery: async {
|
|
|
|
let sum = RIOT_API.summoner_v4().get_by_summoner_name(ROUTE, "ma5tery");
|
2021-10-30 05:38:48 +00:00
|
|
|
let sum = sum.await.map_err(|e| e.to_string())?.ok_or_else(|| "Failed to get summoner".to_owned())?;
|
2021-06-30 23:34:34 +00:00
|
|
|
|
|
|
|
let p = RIOT_API.champion_mastery_v4().get_all_champion_masteries(ROUTE, &*sum.id);
|
|
|
|
let s = p.await.map_err(|e| e.to_string())?;
|
|
|
|
rassert!(s.len() >= 142, "Expected masteries: {}.", s.len());
|
|
|
|
Ok(())
|
|
|
|
},
|
2022-02-09 01:18:16 +00:00
|
|
|
|
|
|
|
// TODO: https://github.com/RiotGames/developer-relations/issues/602
|
|
|
|
// spectator_combo: async {
|
|
|
|
// let featured_p = RIOT_API.spectator_v4().get_featured_games(ROUTE);
|
|
|
|
// let featured = featured_p.await.map_err(|e| e.to_string())?;
|
|
|
|
|
|
|
|
// rassert!(!featured.game_list.is_empty());
|
|
|
|
|
|
|
|
// let summoner_name = &featured.game_list[0].participants[0].summoner_name;
|
|
|
|
// let summoner_p = RIOT_API.summoner_v4().get_by_summoner_name(ROUTE, summoner_name);
|
|
|
|
// let summoner = summoner_p.await.map_err(|e| e.to_string())?.ok_or_else(|| "Failed to get summoner".to_owned())?;
|
|
|
|
|
|
|
|
// let livegame_p = RIOT_API.spectator_v4().get_current_game_info_by_summoner(ROUTE, &summoner.id);
|
|
|
|
// let livegame_o = livegame_p.await.map_err(|e| e.to_string())?;
|
|
|
|
// if let Some(livegame) = livegame_o {
|
|
|
|
// let participant_match = livegame.participants.iter().find(|p| p.summoner_name == *summoner_name);
|
|
|
|
// rassert!(participant_match.is_some(), "Failed to find summoner in match: {}.", summoner_name);
|
|
|
|
// }
|
|
|
|
// Ok(())
|
|
|
|
// },
|
|
|
|
|
2023-03-08 19:46:01 +00:00
|
|
|
// TFT tests.
|
|
|
|
// // Don't have acecess to tft-status-v1.
|
|
|
|
// tftstatusv1_getplatformdata: async {
|
|
|
|
// let p = RIOT_API.tft_status_v1().get_platform_data(ROUTE);
|
|
|
|
// let _s = p.await.map_err(|e| e.to_string())?;
|
2021-06-30 23:34:34 +00:00
|
|
|
// Ok(())
|
|
|
|
// },
|
2023-03-08 19:46:01 +00:00
|
|
|
tftleaguev1_getchallengerleague: async {
|
|
|
|
let p = RIOT_API.tft_league_v1().get_challenger_league(ROUTE);
|
|
|
|
let l = p.await.map_err(|e| e.to_string())?;
|
|
|
|
rassert!(l.entries.len() > 10, "Expected a few challenger players, got: {}.", l.entries.len());
|
|
|
|
Ok(())
|
|
|
|
},
|
|
|
|
tftmatchv1_getmatch: async {
|
|
|
|
let p = RIOT_API.tft_match_v1().get_match(ROUTE.to_regional(), "EUW1_4568680990");
|
|
|
|
let _m = p.await.map_err(|e| e.to_string())?.ok_or("Failed to get TFT match.".to_owned())?;
|
|
|
|
Ok(())
|
|
|
|
},
|
|
|
|
tftsummonerv1_getbyname: async {
|
|
|
|
let p = RIOT_API.tft_summoner_v1().get_by_summoner_name(ROUTE, "相当猥琐");
|
|
|
|
let _s = p.await.map_err(|e| e.to_string())?.ok_or("Failed to get TFT summoner.".to_owned())?;
|
|
|
|
Ok(())
|
|
|
|
},
|
|
|
|
tftsummonerv1_getbyname_none: async {
|
|
|
|
let p = RIOT_API.tft_summoner_v1().get_by_summoner_name(ROUTE, "this summoner does not exist");
|
|
|
|
rassert!(p.await.map_err(|e| e.to_string())?.is_none());
|
|
|
|
Ok(())
|
|
|
|
},
|
|
|
|
// Get top rated player, get some of their matches.
|
|
|
|
tft_combo: async {
|
|
|
|
let top_players = RIOT_API.tft_league_v1().get_top_rated_ladder(ROUTE, QueueType::RANKED_TFT_TURBO);
|
|
|
|
let top_players = top_players.await.map_err(|e| e.to_string())?;
|
|
|
|
rassert!(0 < top_players.len());
|
|
|
|
let top_player_entry = &top_players[0];
|
|
|
|
let top_player = RIOT_API.tft_summoner_v1().get_by_summoner_id(ROUTE, &*top_player_entry.summoner_id);
|
|
|
|
let top_player = top_player.await.map_err(|e| e.to_string())?;
|
|
|
|
println!("Top player is {} with `puuid` {}.", top_player.name, top_player.puuid);
|
|
|
|
let match_ids = RIOT_API.tft_match_v1().get_match_ids_by_puuid(
|
|
|
|
ROUTE.to_regional(), &*top_player.puuid, Some(10), None, None, None);
|
|
|
|
let match_ids = match_ids.await.map_err(|e| e.to_string())?;
|
|
|
|
let match_futures = match_ids.iter().map(|match_id| async move {
|
|
|
|
let result = RIOT_API.tft_match_v1().get_match(ROUTE.to_regional(), &**match_id).await;
|
|
|
|
result.map_err(|e| (match_id.clone(), e))
|
|
|
|
});
|
|
|
|
let matches = futures::future::try_join_all(match_futures).await.map_err(|(match_id, e)| format!("{}: {}", match_id, e))?;
|
|
|
|
for match_opt in matches.iter() {
|
|
|
|
rassert!(match_opt.is_some());
|
|
|
|
let mmatch = match_opt.as_ref().unwrap();
|
|
|
|
rassert!(0 < mmatch.info.participants.len());
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
},
|
2021-06-30 23:34:34 +00:00
|
|
|
}
|
|
|
|
}
|