use BuildQuery;
use ::errors::*;
#[derive(Debug, Clone)]
pub struct ProjectsLister<'a> {
gl: &'a ::GitLab,
id: ::projects::ListingId,
}
impl<'a> ProjectsLister<'a> {
pub fn new(gl: &'a ::GitLab, id: ::projects::ListingId) -> ProjectsLister {
ProjectsLister { gl: gl, id: id }
}
pub fn list(&self) -> Result<::projects::Project> {
let query = self.build_query();
debug!("query: {:?}", query);
self.gl.get(&query, None, None).chain_err(|| format!("cannot get query {}", query))
}
pub fn issues(self) -> Result<::issues::project::IssuesLister<'a>> {
let project = self.list().chain_err(|| "failure to find project")?;
Ok(::issues::project::IssuesLister::new(self.gl, project.id))
}
pub fn merge_requests(self) -> Result<::merge_requests::MergeRequestsLister<'a>> {
let project = self.list().chain_err(|| "failure to find project")?;
Ok(::merge_requests::MergeRequestsLister::new(self.gl, project.id))
}
}
impl<'a> BuildQuery for ProjectsLister<'a> {
fn build_query(&self) -> String {
let mut query = String::from("projects/");
query.push_str(&match self.id {
::projects::ListingId::Id(id) => id.to_string(),
::projects::ListingId::NamespaceProject(ref s) => s.replace("/", "%2F"),
});
query
}
}
#[cfg(test)]
mod tests {
use BuildQuery;
const TEST_PROJECT_ID: i64 = 123;
const TEST_PROJECT_NAME: &'static str = "group/project";
#[test]
fn build_query_id() {
let gl = ::GitLab::new(&"localhost", "XXXXXXXXXXXXXXXXXXXX").unwrap();
let expected_string = format!("projects/{}", TEST_PROJECT_ID);
let query = gl.projects()
.id(::projects::ListingId::Id(TEST_PROJECT_ID))
.build_query();
assert_eq!(query, expected_string);
let expected_string = format!("projects/{}",
TEST_PROJECT_NAME.to_string().replace("/", "%2F"));
let query = gl.projects()
.id(::projects::ListingId::NamespaceProject(TEST_PROJECT_NAME.to_string()))
.build_query();
assert_eq!(query, expected_string);
}
}