-
Notifications
You must be signed in to change notification settings - Fork 20
/
build_list_sync.rs
54 lines (44 loc) · 1.69 KB
/
build_list_sync.rs
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
// Copyright (c) Microsoft Corporation.
// Licensed under the MIT License.
// build_list_sync.rs
// Repository list example, demonstrating how to call the async API from sync code
// For more info see: https://tokio.rs/tokio/topics/bridging
use anyhow::Result;
use azure_devops_rust_api::build;
use std::env;
use time::{ext::NumericalDuration, OffsetDateTime};
mod utils;
fn main() -> Result<()> {
// Get authentication credential
let credential = utils::get_credential()?;
// Get ADO configuration via environment variables
let organization = env::var("ADO_ORGANIZATION").expect("Must define ADO_ORGANIZATION");
let project = env::var("ADO_PROJECT").expect("Must define ADO_PROJECT");
// Create a `current_thread` tokio runtime to use when invoking async functions
let rt = tokio::runtime::Builder::new_current_thread()
.enable_all()
.build()?;
// Create a build client
println!("Create build client");
let build_client = build::ClientBuilder::new(credential.clone()).build();
// Query all the builds in the past hour
let end_time = OffsetDateTime::now_utc();
let start_time = end_time - 1.hours();
// Get all builds in the specified organization/project in the past hour
let builds = rt
.block_on(async {
println!("Get list");
build_client
.builds_client()
.list(&organization, &project)
.min_time(start_time)
.max_time(end_time)
.await
})?
.value;
println!("Found {} builds", builds.len());
if let Some(build) = builds.first() {
println!("Example build struct: {:#?}", build);
}
Ok(())
}