mirror of
https://github.com/bspeice/dtparse
synced 2024-11-14 09:58:09 -05:00
Continuing to clean up tests
This commit is contained in:
parent
965aed40e3
commit
8787e321e2
@ -13,6 +13,8 @@ tests = {
|
|||||||
"01h02m03", "01h02", "01h02s", "01m02", "01m02h", "2004 10 Apr 11h30m",
|
"01h02m03", "01h02", "01h02s", "01m02", "01m02h", "2004 10 Apr 11h30m",
|
||||||
# testPertain
|
# testPertain
|
||||||
'Sep 03', 'Sep of 03',
|
'Sep 03', 'Sep of 03',
|
||||||
|
# test_hmBY - Note: This appears to be Python 3 only, no idea why
|
||||||
|
'02:17NOV2017'
|
||||||
],
|
],
|
||||||
'test_parse_simple': [
|
'test_parse_simple': [
|
||||||
"Thu Sep 25 10:36:28 2003", "Thu Sep 25 2003", "2003-09-25T10:49:41",
|
"Thu Sep 25 10:36:28 2003", "Thu Sep 25 2003", "2003-09-25T10:49:41",
|
||||||
@ -37,8 +39,6 @@ tests = {
|
|||||||
'090107',
|
'090107',
|
||||||
# test_mstridx
|
# test_mstridx
|
||||||
'2015-15-May',
|
'2015-15-May',
|
||||||
# test_hmBY
|
|
||||||
'02:17NOV2017'
|
|
||||||
],
|
],
|
||||||
'test_parse_tzinfo': [
|
'test_parse_tzinfo': [
|
||||||
'Thu Sep 25 10:36:28 BRST 2003', '2003 10:36:28 BRST 25 Sep Thu',
|
'Thu Sep 25 10:36:28 BRST 2003', '2003 10:36:28 BRST 25 Sep Thu',
|
||||||
|
70
src/lib.rs
70
src/lib.rs
@ -462,7 +462,10 @@ fn days_in_month(year: i32, month: i32) -> Result<u32, ParseError> {
|
|||||||
},
|
},
|
||||||
1 | 3 | 5 | 7 | 8 | 10 | 12 => Ok(31),
|
1 | 3 | 5 | 7 | 8 | 10 | 12 => Ok(31),
|
||||||
4 | 6 | 9 | 11 => Ok(30),
|
4 | 6 | 9 | 11 => Ok(30),
|
||||||
_ => Err(ParseError::InvalidMonth),
|
_ => {
|
||||||
|
println!("Invalid month: {}", month);
|
||||||
|
Err(ParseError::InvalidMonth)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -482,6 +485,11 @@ struct YMD {
|
|||||||
ystridx: Option<usize>,
|
ystridx: Option<usize>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
enum YMDAppendEither {
|
||||||
|
Number(i32),
|
||||||
|
Stringy(String), // TODO: Better name?
|
||||||
|
}
|
||||||
|
|
||||||
impl YMD {
|
impl YMD {
|
||||||
fn len(&self) -> usize {
|
fn len(&self) -> usize {
|
||||||
self._ymd.len()
|
self._ymd.len()
|
||||||
@ -504,10 +512,27 @@ impl YMD {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn append(&mut self, val: i32, label: Option<YMDLabel>) -> ParseIResult<()> {
|
fn append(&mut self, val: i32, token: &str, label: Option<YMDLabel>) -> ParseIResult<()> {
|
||||||
let mut label = label;
|
let mut label = label;
|
||||||
|
|
||||||
// TODO: Duck typing with val being an array type?
|
println!("Val: {}, Token: {}", val, token);
|
||||||
|
|
||||||
|
// Python auto-detects strings using the '__len__' function here.
|
||||||
|
// We instead take in both and handle as necessary.
|
||||||
|
if Decimal::from_str(token).is_ok() && token.len() > 2 {
|
||||||
|
self.century_specified = true;
|
||||||
|
match label {
|
||||||
|
None | Some(YMDLabel::Year) => label = Some(YMDLabel::Year),
|
||||||
|
_ => {
|
||||||
|
return Err(ParseInternalError::ValueError(format!(
|
||||||
|
"Invalid label {:?} for token {:?}",
|
||||||
|
label,
|
||||||
|
token
|
||||||
|
)))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if val > 100 {
|
if val > 100 {
|
||||||
self.century_specified = true;
|
self.century_specified = true;
|
||||||
match label {
|
match label {
|
||||||
@ -515,8 +540,9 @@ impl YMD {
|
|||||||
Some(YMDLabel::Year) => (),
|
Some(YMDLabel::Year) => (),
|
||||||
_ => {
|
_ => {
|
||||||
return Err(ParseInternalError::ValueError(format!(
|
return Err(ParseInternalError::ValueError(format!(
|
||||||
"Invalid label: {:?}",
|
"Invalid label {:?} for token {:?}",
|
||||||
label
|
label,
|
||||||
|
token
|
||||||
)))
|
)))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -823,18 +849,18 @@ impl Parser {
|
|||||||
} else if let Some(value) = self.info.get_weekday(&l[i]) {
|
} else if let Some(value) = self.info.get_weekday(&l[i]) {
|
||||||
res.weekday = Some(value != 0);
|
res.weekday = Some(value != 0);
|
||||||
} else if let Some(value) = self.info.get_month(&l[i]) {
|
} else if let Some(value) = self.info.get_month(&l[i]) {
|
||||||
ymd.append(value as i32, Some(YMDLabel::Month));
|
ymd.append(value as i32, &l[i], Some(YMDLabel::Month));
|
||||||
|
|
||||||
if i + 1 < len_l {
|
if i + 1 < len_l {
|
||||||
if l[i + 1] == "-" || l[i + 1] == "/" {
|
if l[i + 1] == "-" || l[i + 1] == "/" {
|
||||||
// Jan-01[-99]
|
// Jan-01[-99]
|
||||||
let sep = &l[i + 1];
|
let sep = &l[i + 1];
|
||||||
// TODO: This seems like a very unsafe unwrap
|
// TODO: This seems like a very unsafe unwrap
|
||||||
ymd.append(l[i + 2].parse::<i32>().unwrap(), None);
|
ymd.append(l[i + 2].parse::<i32>().unwrap(), &l[i + 2], None);
|
||||||
|
|
||||||
if i + 3 < len_l && &l[i + 3] == sep {
|
if i + 3 < len_l && &l[i + 3] == sep {
|
||||||
// Jan-01-99
|
// Jan-01-99
|
||||||
ymd.append(l[i + 4].parse::<i32>().unwrap(), None);
|
ymd.append(l[i + 4].parse::<i32>().unwrap(), &l[i + 4], None);
|
||||||
i += 2;
|
i += 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -845,7 +871,7 @@ impl Parser {
|
|||||||
// Jan of 01
|
// Jan of 01
|
||||||
if let Some(value) = l[i + 4].parse::<i32>().ok() {
|
if let Some(value) = l[i + 4].parse::<i32>().ok() {
|
||||||
let year = self.info.convertyear(value, false);
|
let year = self.info.convertyear(value, false);
|
||||||
ymd.append(year, Some(YMDLabel::Year));
|
ymd.append(year, &l[i + 4], Some(YMDLabel::Year));
|
||||||
}
|
}
|
||||||
|
|
||||||
i += 4;
|
i += 4;
|
||||||
@ -1070,9 +1096,9 @@ impl Parser {
|
|||||||
let s = &tokens[idx];
|
let s = &tokens[idx];
|
||||||
|
|
||||||
if ymd.len() == 0 && tokens[idx].find(".") == None {
|
if ymd.len() == 0 && tokens[idx].find(".") == None {
|
||||||
ymd.append(s[0..2].parse::<i32>().unwrap(), None);
|
ymd.append(s[0..2].parse::<i32>().unwrap(), &s[0..2], None);
|
||||||
ymd.append(s[2..4].parse::<i32>().unwrap(), None);
|
ymd.append(s[2..4].parse::<i32>().unwrap(), &s[2..4], None);
|
||||||
ymd.append(s[4..6].parse::<i32>().unwrap(), None);
|
ymd.append(s[4..6].parse::<i32>().unwrap(), &s[4..6], None);
|
||||||
} else {
|
} else {
|
||||||
// 19990101T235959[.59]
|
// 19990101T235959[.59]
|
||||||
res.hour = s[0..2].parse::<i32>().ok();
|
res.hour = s[0..2].parse::<i32>().ok();
|
||||||
@ -1085,9 +1111,9 @@ impl Parser {
|
|||||||
} else if vec![8, 12, 14].contains(&len_li) {
|
} else if vec![8, 12, 14].contains(&len_li) {
|
||||||
// YYMMDD
|
// YYMMDD
|
||||||
let s = &tokens[idx];
|
let s = &tokens[idx];
|
||||||
ymd.append(s[..4].parse::<i32>().unwrap(), Some(YMDLabel::Year));
|
ymd.append(s[..4].parse::<i32>().unwrap(), &s[..4], Some(YMDLabel::Year));
|
||||||
ymd.append(s[4..6].parse::<i32>().unwrap(), None);
|
ymd.append(s[4..6].parse::<i32>().unwrap(), &s[4..6], None);
|
||||||
ymd.append(s[6..8].parse::<i32>().unwrap(), None);
|
ymd.append(s[6..8].parse::<i32>().unwrap(), &s[6..8], None);
|
||||||
|
|
||||||
if len_li > 8 {
|
if len_li > 8 {
|
||||||
res.hour = Some(s[8..10].parse::<i32>()?);
|
res.hour = Some(s[8..10].parse::<i32>()?);
|
||||||
@ -1129,20 +1155,20 @@ impl Parser {
|
|||||||
{
|
{
|
||||||
// TODO: There's got to be a better way of handling the condition above
|
// TODO: There's got to be a better way of handling the condition above
|
||||||
let sep = &tokens[idx + 1];
|
let sep = &tokens[idx + 1];
|
||||||
ymd.append(value_repr.parse::<i32>().unwrap(), None);
|
ymd.append(value_repr.parse::<i32>().unwrap(), &value_repr, None);
|
||||||
|
|
||||||
if idx + 2 < len_l && !info.get_jump(&tokens[idx + 2]) {
|
if idx + 2 < len_l && !info.get_jump(&tokens[idx + 2]) {
|
||||||
if let Ok(val) = tokens[idx + 2].parse::<i32>() {
|
if let Ok(val) = tokens[idx + 2].parse::<i32>() {
|
||||||
ymd.append(val, None);
|
ymd.append(val, &tokens[idx + 2], None);
|
||||||
} else if let Some(val) = info.get_month(&tokens[idx + 2]) {
|
} else if let Some(val) = info.get_month(&tokens[idx + 2]) {
|
||||||
ymd.append(val as i32, Some(YMDLabel::Month));
|
ymd.append(val as i32, &value_repr, Some(YMDLabel::Month));
|
||||||
}
|
}
|
||||||
|
|
||||||
if idx + 3 < len_l && &tokens[idx + 3] == sep {
|
if idx + 3 < len_l && &tokens[idx + 3] == sep {
|
||||||
if let Some(value) = info.get_month(&tokens[idx + 4]) {
|
if let Some(value) = info.get_month(&tokens[idx + 4]) {
|
||||||
ymd.append(value as i32, Some(YMDLabel::Month));
|
ymd.append(value as i32, &tokens[idx + 4], Some(YMDLabel::Month));
|
||||||
} else {
|
} else {
|
||||||
ymd.append(tokens[idx + 4].parse::<i32>().unwrap(), None);
|
ymd.append(tokens[idx + 4].parse::<i32>().unwrap(), &tokens[idx + 4], None);
|
||||||
}
|
}
|
||||||
|
|
||||||
idx += 2;
|
idx += 2;
|
||||||
@ -1158,7 +1184,7 @@ impl Parser {
|
|||||||
let ampm = info.get_ampm(&tokens[idx + 2]).unwrap();
|
let ampm = info.get_ampm(&tokens[idx + 2]).unwrap();
|
||||||
res.hour = Some(self.adjust_ampm(hour, ampm));
|
res.hour = Some(self.adjust_ampm(hour, ampm));
|
||||||
} else {
|
} else {
|
||||||
ymd.append(value.floor().to_i64().unwrap() as i32, None);
|
ymd.append(value.floor().to_i64().unwrap() as i32, &value_repr, None);
|
||||||
}
|
}
|
||||||
} else if info.get_ampm(&tokens[idx + 1]).is_some()
|
} else if info.get_ampm(&tokens[idx + 1]).is_some()
|
||||||
&& (*ZERO <= value && value < *TWENTY_FOUR)
|
&& (*ZERO <= value && value < *TWENTY_FOUR)
|
||||||
@ -1168,7 +1194,7 @@ impl Parser {
|
|||||||
res.hour = Some(self.adjust_ampm(hour, info.get_ampm(&tokens[idx + 1]).unwrap()));
|
res.hour = Some(self.adjust_ampm(hour, info.get_ampm(&tokens[idx + 1]).unwrap()));
|
||||||
idx += 1;
|
idx += 1;
|
||||||
} else if ymd.could_be_day(value.to_i64().unwrap() as i32) {
|
} else if ymd.could_be_day(value.to_i64().unwrap() as i32) {
|
||||||
ymd.append(value.to_i64().unwrap() as i32, None);
|
ymd.append(value.to_i64().unwrap() as i32, &value_repr, None);
|
||||||
} else if !fuzzy {
|
} else if !fuzzy {
|
||||||
return Err(ParseInternalError::ValueError("".to_owned()));
|
return Err(ParseInternalError::ValueError("".to_owned()));
|
||||||
}
|
}
|
||||||
|
@ -678,6 +678,19 @@ fn test_parse_default45() {
|
|||||||
Some(default_rsdate), false, HashMap::new());
|
Some(default_rsdate), false, HashMap::new());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn test_parse_default46() {
|
||||||
|
let info = ParserInfo::default();
|
||||||
|
let default_rsdate = &NaiveDate::from_ymd(2003, 9, 25).and_hms(0, 0, 0);
|
||||||
|
let pdt = PyDateTime {
|
||||||
|
year: 2017, month: 11, day: 25,
|
||||||
|
hour: 2, minute: 17, second: 0,
|
||||||
|
micros: 0, tzo: None
|
||||||
|
};
|
||||||
|
parse_and_assert(pdt, info, "02:17NOV2017", None, None, false, false,
|
||||||
|
Some(default_rsdate), false, HashMap::new());
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_parse_simple0() {
|
fn test_parse_simple0() {
|
||||||
let pdt = PyDateTime {
|
let pdt = PyDateTime {
|
||||||
@ -1298,16 +1311,6 @@ fn test_parse_simple61() {
|
|||||||
parse_and_assert_simple(pdt, "2015-15-May");
|
parse_and_assert_simple(pdt, "2015-15-May");
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn test_parse_simple62() {
|
|
||||||
let pdt = PyDateTime {
|
|
||||||
year: 2017, month: 11, day: 13,
|
|
||||||
hour: 2, minute: 17, second: 0,
|
|
||||||
micros: 0, tzo: None,
|
|
||||||
};
|
|
||||||
parse_and_assert_simple(pdt, "02:17NOV2017");
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_parse_tzinfo0() {
|
fn test_parse_tzinfo0() {
|
||||||
let info = ParserInfo::default();
|
let info = ParserInfo::default();
|
||||||
|
Loading…
Reference in New Issue
Block a user