mod mock_error; use mock_error::setup_error_handler; use octocrab::{params::LockReason, Octocrab}; use wiremock::{ matchers::{method, path}, Mock, MockServer, ResponseTemplate, }; async fn setup_issue_lock_api(template: ResponseTemplate) -> MockServer { let owner: &str = "org"; let repo: &str = "some-repo"; let issue_number: u64 = 123; let mock_server = MockServer::start().await; Mock::given(method("PUT")) .and(path(format!( "/repos/{owner}/{repo}/issues/{issue_number}/lock" ))) .respond_with(template.clone()) .mount(&mock_server) .await; setup_error_handler( &mock_server, &format!("PUT on /repos/{owner}/{repo}/issues/{issue_number}/lock was not received"), ) .await; mock_server } async fn setup_issue_unlock_api(template: ResponseTemplate) -> MockServer { let owner: &str = "org"; let repo: &str = "some-repo"; let issue_number: u64 = 123; let mock_server = MockServer::start().await; Mock::given(method("DELETE")) .and(path(format!( "/repos/{owner}/{repo}/issues/{issue_number}/lock" ))) .respond_with(template.clone()) .mount(&mock_server) .await; setup_error_handler( &mock_server, &format!("DELETE on /repos/{owner}/{repo}/issues/{issue_number}/lock was not received"), ) .await; mock_server } fn setup_octocrab(uri: &str) -> Octocrab { Octocrab::builder().base_uri(uri).unwrap().build().unwrap() } const OWNER: &str = "org"; const REPO: &str = "some-repo"; const ISSUE_NUMBER: u64 = 123; #[tokio::test] async fn lock_no_reason_returns_true() { let template = ResponseTemplate::new(204); let mock_server = setup_issue_lock_api(template).await; let client = setup_octocrab(&mock_server.uri()); let result = client .issues(OWNER.to_owned(), REPO.to_owned()) .lock(ISSUE_NUMBER, None) .await; assert!( result.is_ok(), "expected successful result, got error: {:#?}", result ); let result = result.unwrap(); assert!(result, "expected the result to be true: {}", result); } #[tokio::test] async fn lock_with_reason_returns_true() { let template = ResponseTemplate::new(204); let mock_server = setup_issue_lock_api(template).await; let client = setup_octocrab(&mock_server.uri()); let result = client .issues(OWNER.to_owned(), REPO.to_owned()) .lock(ISSUE_NUMBER, Some(LockReason::TooHeated)) .await; assert!( result.is_ok(), "expected successful result, got error: {:#?}", result ); let result = result.unwrap(); assert!(result, "expected the result to be true: {}", result); } #[tokio::test] async fn lock_no_reason_returns_false() { let template = ResponseTemplate::new(404); let mock_server = setup_issue_lock_api(template).await; let client = setup_octocrab(&mock_server.uri()); let result = client .issues(OWNER.to_owned(), REPO.to_owned()) .lock(ISSUE_NUMBER, Some(LockReason::TooHeated)) .await; assert!( result.is_ok(), "expected successful result, got error: {:#?}", result ); let result = result.unwrap(); assert!(!result, "expected the result to be false: {}", result); } #[tokio::test] async fn unlock_returns_true() { let template = ResponseTemplate::new(204); let mock_server = setup_issue_unlock_api(template).await; let client = setup_octocrab(&mock_server.uri()); let result = client .issues(OWNER.to_owned(), REPO.to_owned()) .unlock(ISSUE_NUMBER) .await; assert!( result.is_ok(), "expected successful result, got error: {:#?}", result ); let result = result.unwrap(); assert!(result, "expected the result to be true: {}", result); } #[tokio::test] async fn lock_returns_false() { let template = ResponseTemplate::new(404); let mock_server = setup_issue_unlock_api(template).await; let client = setup_octocrab(&mock_server.uri()); let result = client .issues(OWNER.to_owned(), REPO.to_owned()) .unlock(ISSUE_NUMBER) .await; assert!( result.is_ok(), "expected successful result, got error: {:#?}", result ); let result = result.unwrap(); assert!(!result, "expected the result to be false: {}", result); }