mlb-api 1.0.3

Endpoints for MLB's public Statcast API.
Documentation
//! Postseason schedule info and endpoints.

pub mod series;

use crate::meta::GameType;
use crate::request::RequestURL;
use crate::schedule::{ScheduleHydrations, ScheduleResponse};
use crate::season::SeasonId;
use crate::sport::SportId;
use crate::team::TeamId;
use bon::Builder;
use itertools::Itertools;
use std::fmt::{Display, Formatter};
use std::marker::PhantomData;

#[derive(Builder)]
#[builder(derive(Into))]
pub struct SchedulePostseasonRequest<H: ScheduleHydrations> {
	#[builder(into)]
	season: SeasonId,
	#[builder(into)]
	#[builder(default)]
	sport_id: SportId,
	#[builder(into)]
	team_id: Option<TeamId>,
	game_types: Option<Vec<GameType>>,
	series_number: Option<u32>,
	#[builder(skip)]
	_marker: PhantomData<H>,
}

impl<H: ScheduleHydrations, S: schedule_postseason_request_builder::State + schedule_postseason_request_builder::IsComplete> crate::request::RequestURLBuilderExt for SchedulePostseasonRequestBuilder<H, S> {
	type Built = SchedulePostseasonRequest<H>;
}

impl<H: ScheduleHydrations> Display for SchedulePostseasonRequest<H> {
	fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
		let hydrations = Some(H::hydration_text(&())).filter(|s| !s.is_empty());

		write!(
			f,
			"http://statsapi.mlb.com/api/v1/schedule/postseason{params}",
			params = gen_params! {
				"season": self.season,
				"sportId": self.sport_id,
				"teamId"?: self.team_id,
				"gameTypes"?: self.game_types.as_ref().map(|x| x.iter().map(|g| format!("{g:?}")).join(",")),
				"seriesNumber"?: self.series_number,
				"hydrate"?: hydrations,
			}
		)
	}
}

impl<H: ScheduleHydrations> RequestURL for SchedulePostseasonRequest<H> {
	type Response = ScheduleResponse<H>;
}

#[cfg(test)]
mod tests {
	use crate::TEST_YEAR;
	use crate::request::RequestURLBuilderExt;
	use crate::schedule::postseason::SchedulePostseasonRequest;

	#[tokio::test]
	async fn test_one_season() {
		let _ = SchedulePostseasonRequest::<()>::builder().season(TEST_YEAR).build_and_get().await.unwrap();
	}

	#[tokio::test]
	#[cfg_attr(not(feature = "_heavy_tests"), ignore)]
	async fn test_all_seasons() {
		for season in 1876..=TEST_YEAR {
			let _ = SchedulePostseasonRequest::<()>::builder().season(season).build_and_get().await.unwrap();
		}
	}
}