Merge pull request 'make the username part of the invalid message.' (#1) from local into master
Reviewed-on: http://git.teilgedanken.de/Rust/useradd/pulls/1
This commit is contained in:
commit
d4d3c0f0cf
@ -37,12 +37,18 @@ impl<'a> TryFrom<&'a str> for Username<'a> {
|
|||||||
fn try_from(source: &'a str) -> std::result::Result<Self, Self::Error> {
|
fn try_from(source: &'a str) -> std::result::Result<Self, Self::Error> {
|
||||||
lazy_static! {
|
lazy_static! {
|
||||||
static ref USERVALIDATION: Regex =
|
static ref USERVALIDATION: Regex =
|
||||||
Regex::new("^[a-z_]([a-z0-9_-]{0,31}|[a-z0-9_-]{0,30}\\$)$").unwrap();
|
Regex::new("^[a-z_]([a-z0-9_\\-]{0,31}|[a-z0-9_\\-]{0,30}\\$)$").unwrap();
|
||||||
}
|
}
|
||||||
if USERVALIDATION.is_match(source) {
|
if USERVALIDATION.is_match(source) {
|
||||||
Ok(Self { username: source })
|
Ok(Self { username: source })
|
||||||
|
} else if source == "Debian-exim" {
|
||||||
|
//warn!("username {} is not a valid username. This might cause problems. (It is default in Debian and Ubuntu)", source);
|
||||||
|
Ok(Self { username: source })
|
||||||
} else {
|
} else {
|
||||||
Err(UserLibError::Message("Invalid username".into()))
|
Err(UserLibError::Message(format!(
|
||||||
|
"Invalid username {}",
|
||||||
|
source
|
||||||
|
)))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -407,22 +413,29 @@ fn test_username_validation() {
|
|||||||
// Failing tests
|
// Failing tests
|
||||||
let umlauts = Username::try_from("täst"); // umlauts
|
let umlauts = Username::try_from("täst"); // umlauts
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
Err(UserLibError::Message("Invalid username".into())),
|
Err(UserLibError::Message("Invalid username täst".into())),
|
||||||
umlauts
|
umlauts
|
||||||
);
|
);
|
||||||
let number_first = Username::try_from("11elf"); // numbers first
|
let number_first = Username::try_from("11elf"); // numbers first
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
Err(UserLibError::Message("Invalid username".into())),
|
Err(UserLibError::Message("Invalid username 11elf".into())),
|
||||||
number_first
|
number_first
|
||||||
);
|
);
|
||||||
let slashes = Username::try_from("test/name"); // slashes in the name
|
let slashes = Username::try_from("test/name"); // slashes in the name
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
Err(UserLibError::Message("Invalid username".into())),
|
Err(UserLibError::Message("Invalid username test/name".into())),
|
||||||
slashes
|
slashes
|
||||||
);
|
);
|
||||||
let long = Username::try_from("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"); // maximum size 32 letters
|
let long = Username::try_from("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"); // maximum size 32 letters
|
||||||
assert_eq!(Err(UserLibError::Message("Invalid username".into())), long);
|
assert_eq!(
|
||||||
|
Err(UserLibError::Message(
|
||||||
|
"Invalid username aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa".into()
|
||||||
|
)),
|
||||||
|
long
|
||||||
|
);
|
||||||
// Working tests
|
// Working tests
|
||||||
|
let ubuntu_exception = Username::try_from("Debian-exim"); // for some reason ubuntu and debian have a capital user.
|
||||||
|
assert_eq!(ubuntu_exception.unwrap().username, "Debian-exim");
|
||||||
let single = Username::try_from("t"); // single characters are ok
|
let single = Username::try_from("t"); // single characters are ok
|
||||||
assert_eq!(single.unwrap().username, "t");
|
assert_eq!(single.unwrap().username, "t");
|
||||||
let normal = Username::try_from("superman"); // regular username
|
let normal = Username::try_from("superman"); // regular username
|
||||||
|
Loading…
Reference in New Issue
Block a user