1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
|
mod mock_error;
use mock_error::setup_error_handler;
use octocrab::{models, Octocrab};
use wiremock::{
matchers::{method, path},
Mock, MockServer, ResponseTemplate,
};
async fn setup_remove_label_api(template: ResponseTemplate) -> MockServer {
let owner: &str = "org";
let repo: &str = "some-repo";
let issue_number: u64 = 123;
// Gotta love URL encoding
let label_name: &str = "some%2Dlabel";
let mock_server = MockServer::start().await;
Mock::given(method("DELETE"))
.and(path(format!(
"/repos/{owner}/{repo}/issues/{issue_number}/labels/{label_name}"
)))
.respond_with(template.clone())
.mount(&mock_server)
.await;
setup_error_handler(
&mock_server,
&format!("DELETE on /repos/{owner}/{repo}/issues/{issue_number}/labels/{label_name} was not received"),
)
.await;
mock_server
}
async fn setup_delete_label_api(template: ResponseTemplate) -> MockServer {
let owner: &str = "org";
let repo: &str = "some-repo";
let label_name: &str = "some%2Dlabel";
let mock_server = MockServer::start().await;
Mock::given(method("DELETE"))
.and(path(format!("/repos/{owner}/{repo}/labels/{label_name}")))
.respond_with(template.clone())
.mount(&mock_server)
.await;
setup_error_handler(
&mock_server,
&format!("DELETE on /repos/{owner}/{repo}/labels/{label_name} 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;
const LABEL_NAME: &str = "some-label";
#[tokio::test]
async fn should_remove_label() {
let remaining_issue_labels: Vec<models::Label> =
serde_json::from_str(include_str!("resources/issues_remove_label.json")).unwrap();
let template = ResponseTemplate::new(200).set_body_json(&remaining_issue_labels);
let mock_server = setup_remove_label_api(template).await;
let client = setup_octocrab(&mock_server.uri());
let issues = client.issues(OWNER.to_owned(), REPO.to_owned());
let result = issues
.remove_label(ISSUE_NUMBER, LABEL_NAME.to_owned())
.await;
assert!(
result.is_ok(),
"expected successful result, got error: {:#?}",
result
);
}
#[tokio::test]
async fn should_delete_label() {
let template = ResponseTemplate::new(204);
let mock_server = setup_delete_label_api(template).await;
let client = setup_octocrab(&mock_server.uri());
let issues = client.issues(OWNER.to_owned(), REPO.to_owned());
let result = issues.delete_label(LABEL_NAME.to_owned()).await;
assert!(
result.is_ok(),
"expected successful result, got error: {:#?}",
result
);
}
|