Skip to main content

mlb_api/requests/team/
coaches.rs

1//! Returns a list of coaches affiliated with the team; [`PeopleResponse`]
2
3use crate::person::PeopleResponse;
4use crate::season::SeasonId;
5use crate::team::TeamId;
6use crate::MLB_API_DATE_FORMAT;
7use crate::request::RequestURL;
8use bon::Builder;
9use chrono::NaiveDate;
10use std::fmt::{Display, Formatter};
11use crate::person::PersonHydrations;
12
13#[derive(Builder)]
14#[builder(derive(Into))]
15pub struct CoachesRequest<H: PersonHydrations = ()> {
16    #[builder(into)]
17    team_id: TeamId,
18    #[builder(into)]
19    season: Option<SeasonId>,
20    date: Option<NaiveDate>,
21    #[builder(into)]
22    hydrations: H::RequestData,
23}
24
25impl CoachesRequest {
26    pub fn for_team(team_id: impl Into<TeamId>) -> CoachesRequestBuilder<(), coaches_request_builder::SetHydrations<coaches_request_builder::SetTeamId>> {
27        Self::builder()
28            .team_id(team_id.into())
29            .hydrations(())
30    }
31}
32
33impl<H: PersonHydrations, S: coaches_request_builder::State + coaches_request_builder::IsComplete> crate::request::RequestURLBuilderExt for CoachesRequestBuilder<H, S> {
34    type Built = CoachesRequest<H>;
35}
36
37impl<H: PersonHydrations> Display for CoachesRequest<H> {
38    fn fmt(&self, f: &mut Formatter<'_>) -> std::fmt::Result {
39        let hydrations = Some(H::hydration_text(&self.hydrations)).filter(|s| !s.is_empty());
40        write!(f, "http://statsapi.mlb.com/api/v1/teams/{}/coaches{}", self.team_id, gen_params! { "season"?: self.season, "date"?: self.date.as_ref().map(|date| date.format(MLB_API_DATE_FORMAT)), "hydrate"?: hydrations })
41    }
42}
43
44impl<H: PersonHydrations> RequestURL for CoachesRequest<H> {
45    type Response = PeopleResponse<H>;
46}
47
48#[cfg(test)]
49mod tests {
50    use crate::request::RequestURLBuilderExt;
51    use crate::team::coaches::CoachesRequest;
52	use crate::team::TeamsRequest;
53    use crate::TEST_YEAR;
54
55    #[tokio::test]
56    #[cfg_attr(not(feature = "_heavy_tests"), ignore)]
57    async fn test_heavy() {
58        let season = TEST_YEAR;
59        let teams = TeamsRequest::mlb_teams().season(season).build_and_get().await.unwrap();
60        for team in teams.teams {
61            let _ = CoachesRequest::<()>::for_team(team.id).season(season).build_and_get().await.unwrap();
62        }
63    }
64}