Skip to content

Commit

Permalink
core: fix the repo name from url
Browse files Browse the repository at this point in the history
Signed-off-by: Vincenzo Palazzo <[email protected]>
  • Loading branch information
vincenzopalazzo committed Apr 12, 2024
1 parent f4208f9 commit c7b8820
Showing 1 changed file with 13 additions and 4 deletions.
17 changes: 13 additions & 4 deletions coffee_lib/src/url.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ pub struct URL {
}

/// Handle GitHub HTTP links
fn remove_dot_git_from_url(url: &str) -> &str {
pub(crate) fn remove_dot_git_from_url(url: &str) -> &str {
match url.strip_suffix(".git") {
Some(s) => s,
None => url,
Expand All @@ -42,8 +42,9 @@ fn handle_incorrect_url(mut url: &str) -> String {

/// Get repo_name field from the URL
fn get_repo_name_from_url(url: &str) -> String {
let repo_name = url.split('/').last().unwrap().to_string();
repo_name
let repo_name = url.split('/').last().unwrap_or(url);
let repo_name = remove_dot_git_from_url(repo_name);
repo_name.to_owned()
}

impl URL {
Expand Down Expand Up @@ -71,13 +72,21 @@ impl fmt::Display for URL {
#[cfg(test)]
mod tests {
use super::URL;
use super::remove_dot_git_from_url;

#[test]
fn test_remote() {
let u = "https://github.com/lightningd/plugins";
let url = URL::new("/tmp/", u, "lightningd_plugins");
assert_eq!(url.repo_name, "plugins");
assert_eq!(url.url_string, u);
println!("{}", &url);
}

#[test]
fn test_remote_git_prefix() {
let u = "https://github.com/lightningd/plugins.git";
let url = URL::new("/tmp/", u, "lightningd_plugins");
assert_eq!(url.repo_name, "plugins");
assert_eq!(url.url_string, remove_dot_git_from_url(u));
}
}

0 comments on commit c7b8820

Please sign in to comment.