From d42c0a3580b2588d5b936e903a4a4df0bb3154d6 Mon Sep 17 00:00:00 2001 From: Mike Stemle Date: Fri, 26 Jan 2024 01:58:15 -0500 Subject: [PATCH] Tests for locking and unlocking issue comments (#557) --- tests/issues_locking_test.rs | 162 +++++++++++++++++++++++++++++++++++ 1 file changed, 162 insertions(+) create mode 100644 tests/issues_locking_test.rs diff --git a/tests/issues_locking_test.rs b/tests/issues_locking_test.rs new file mode 100644 index 00000000..866638aa --- /dev/null +++ b/tests/issues_locking_test.rs @@ -0,0 +1,162 @@ +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); +}