respect the default_formatter config
This commit is contained in:
parent
7a79878886
commit
751f4aa750
|
@ -91,7 +91,7 @@ pub struct Args {
|
||||||
ids: bool,
|
ids: bool,
|
||||||
start: Option<DateTime<Utc>>,
|
start: Option<DateTime<Utc>>,
|
||||||
end: Option<DateTime<Utc>>,
|
end: Option<DateTime<Utc>>,
|
||||||
format: Formatter,
|
format: Option<Formatter>,
|
||||||
grep: Option<Regex>,
|
grep: Option<Regex>,
|
||||||
sheet: Option<Sheet>,
|
sheet: Option<Sheet>,
|
||||||
}
|
}
|
||||||
|
@ -104,7 +104,7 @@ impl<'a> TryFrom<&'a ArgMatches<'a>> for Args {
|
||||||
ids: matches.is_present("ids"),
|
ids: matches.is_present("ids"),
|
||||||
start: matches.value_of("start").map(|s| parse_time(s)).transpose()?,
|
start: matches.value_of("start").map(|s| parse_time(s)).transpose()?,
|
||||||
end: matches.value_of("end").map(|s| parse_time(s)).transpose()?,
|
end: matches.value_of("end").map(|s| parse_time(s)).transpose()?,
|
||||||
format: matches.value_of("format").unwrap().parse()?,
|
format: matches.value_of("format").map(|v| v.parse()).transpose()?,
|
||||||
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
||||||
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
||||||
})
|
})
|
||||||
|
@ -116,13 +116,24 @@ pub struct DisplayCommand { }
|
||||||
impl<'a> Command<'a> for DisplayCommand {
|
impl<'a> Command<'a> for DisplayCommand {
|
||||||
type Args = Args;
|
type Args = Args;
|
||||||
|
|
||||||
fn handle<D, O, E>(args: Self::Args, db: &mut D, out: &mut O, err: &mut E, _config: &Config, now: DateTime<Utc>) -> Result<()>
|
fn handle<D, O, E>(args: Self::Args, db: &mut D, out: &mut O, err: &mut E, config: &Config, now: DateTime<Utc>) -> Result<()>
|
||||||
where
|
where
|
||||||
D: Database,
|
D: Database,
|
||||||
O: Write,
|
O: Write,
|
||||||
E: Write,
|
E: Write,
|
||||||
{
|
{
|
||||||
entries_for_display(args.start, args.end, args.sheet, db, out, err, args.format, args.ids, args.grep, now)
|
entries_for_display(
|
||||||
|
args.start,
|
||||||
|
args.end,
|
||||||
|
args.sheet,
|
||||||
|
db,
|
||||||
|
out,
|
||||||
|
err,
|
||||||
|
args.format.unwrap_or_else(|| config.default_formatter.clone()),
|
||||||
|
args.ids,
|
||||||
|
args.grep,
|
||||||
|
now
|
||||||
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -165,7 +176,7 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn filter_by_start() {
|
fn filter_by_start() {
|
||||||
let args = Args {
|
let args = Args {
|
||||||
format: Formatter::Csv,
|
format: Some(Formatter::Csv),
|
||||||
start: Some(Utc.ymd(2021, 6, 30).and_hms(10, 5, 0)),
|
start: Some(Utc.ymd(2021, 6, 30).and_hms(10, 5, 0)),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
|
@ -298,7 +309,7 @@ Timesheet: sheet1
|
||||||
std::env::set_var("TZ", "CST+6");
|
std::env::set_var("TZ", "CST+6");
|
||||||
|
|
||||||
let args = Args {
|
let args = Args {
|
||||||
format: Formatter::Csv,
|
format: Some(Formatter::Csv),
|
||||||
start: Some(Utc.ymd(2021, 6, 29).and_hms(12, 0, 0)),
|
start: Some(Utc.ymd(2021, 6, 29).and_hms(12, 0, 0)),
|
||||||
end: Some(Utc.ymd(2021, 6, 29).and_hms(13, 0, 0)),
|
end: Some(Utc.ymd(2021, 6, 29).and_hms(13, 0, 0)),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
|
@ -323,4 +334,28 @@ Timesheet: sheet1
|
||||||
format!("{} You are using the old timetrap format, it is advised that you update your database using t migrate\n", Yellow.bold().paint("[WARNING]")),
|
format!("{} You are using the old timetrap format, it is advised that you update your database using t migrate\n", Yellow.bold().paint("[WARNING]")),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn respect_default_formatter() {
|
||||||
|
std::env::set_var("TZ", "CST+6");
|
||||||
|
|
||||||
|
let args = Default::default();
|
||||||
|
let mut db = SqliteDatabase::from_memory().unwrap();
|
||||||
|
let mut out = Vec::new();
|
||||||
|
let mut err = Vec::new();
|
||||||
|
let config = Config {
|
||||||
|
default_formatter: Formatter::Ids,
|
||||||
|
..Default::default()
|
||||||
|
};
|
||||||
|
|
||||||
|
db.init().unwrap();
|
||||||
|
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 0, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 10, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
|
||||||
|
DisplayCommand::handle(args, &mut db, &mut out, &mut err, &config, Utc::now()).unwrap();
|
||||||
|
|
||||||
|
assert_eq!(&String::from_utf8_lossy(&out), "1 2\n");
|
||||||
|
assert_eq!(String::from_utf8_lossy(&err), "");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,7 +69,7 @@ impl FromStr for MonthSpec {
|
||||||
pub struct Args {
|
pub struct Args {
|
||||||
ids: bool,
|
ids: bool,
|
||||||
month: MonthSpec,
|
month: MonthSpec,
|
||||||
format: Formatter,
|
format: Option<Formatter>,
|
||||||
grep: Option<Regex>,
|
grep: Option<Regex>,
|
||||||
sheet: Option<Sheet>,
|
sheet: Option<Sheet>,
|
||||||
}
|
}
|
||||||
|
@ -81,7 +81,7 @@ impl<'a> TryFrom<&'a ArgMatches<'a>> for Args {
|
||||||
Ok(Args {
|
Ok(Args {
|
||||||
ids: matches.is_present("ids"),
|
ids: matches.is_present("ids"),
|
||||||
month: matches.value_of("month").map(|s| s.parse()).transpose()?.unwrap_or(MonthSpec::This),
|
month: matches.value_of("month").map(|s| s.parse()).transpose()?.unwrap_or(MonthSpec::This),
|
||||||
format: matches.value_of("format").unwrap().parse()?,
|
format: matches.value_of("format").map(|v| v.parse()).transpose()?,
|
||||||
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
||||||
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
||||||
})
|
})
|
||||||
|
@ -93,7 +93,7 @@ pub struct MonthCommand { }
|
||||||
impl<'a> Command<'a> for MonthCommand {
|
impl<'a> Command<'a> for MonthCommand {
|
||||||
type Args = Args;
|
type Args = Args;
|
||||||
|
|
||||||
fn handle<D, O, E>(args: Self::Args, db: &mut D, out: &mut O, err: &mut E, _config: &Config, now: DateTime<Utc>) -> Result<()>
|
fn handle<D, O, E>(args: Self::Args, db: &mut D, out: &mut O, err: &mut E, config: &Config, now: DateTime<Utc>) -> Result<()>
|
||||||
where
|
where
|
||||||
D: Database,
|
D: Database,
|
||||||
O: Write,
|
O: Write,
|
||||||
|
@ -129,6 +129,37 @@ impl<'a> Command<'a> for MonthCommand {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
entries_for_display(Some(start), Some(end), args.sheet, db, out, err, args.format, args.ids, args.grep, now)
|
entries_for_display(Some(start), Some(end), args.sheet, db, out, err, args.format.unwrap_or_else(|| config.default_formatter.clone()), args.ids, args.grep, now)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use crate::database::SqliteDatabase;
|
||||||
|
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn respect_default_formatter() {
|
||||||
|
std::env::set_var("TZ", "CST+6");
|
||||||
|
|
||||||
|
let args = Default::default();
|
||||||
|
let mut db = SqliteDatabase::from_memory().unwrap();
|
||||||
|
let mut out = Vec::new();
|
||||||
|
let mut err = Vec::new();
|
||||||
|
let config = Config {
|
||||||
|
default_formatter: Formatter::Ids,
|
||||||
|
..Default::default()
|
||||||
|
};
|
||||||
|
|
||||||
|
db.init().unwrap();
|
||||||
|
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 0, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 10, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
|
||||||
|
MonthCommand::handle(args, &mut db, &mut out, &mut err, &config, Utc.ymd(2021, 6, 30).and_hms(11, 0, 0)).unwrap();
|
||||||
|
|
||||||
|
assert_eq!(&String::from_utf8_lossy(&out), "1 2\n");
|
||||||
|
assert_eq!(String::from_utf8_lossy(&err), "");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,7 @@ use super::{Command, display::{Sheet, entries_for_display}};
|
||||||
pub struct Args {
|
pub struct Args {
|
||||||
ids: bool,
|
ids: bool,
|
||||||
end: Option<DateTime<Utc>>,
|
end: Option<DateTime<Utc>>,
|
||||||
format: Formatter,
|
format: Option<Formatter>,
|
||||||
grep: Option<Regex>,
|
grep: Option<Regex>,
|
||||||
sheet: Option<Sheet>,
|
sheet: Option<Sheet>,
|
||||||
}
|
}
|
||||||
|
@ -30,7 +30,7 @@ impl<'a> TryFrom<&'a ArgMatches<'a>> for Args {
|
||||||
Ok(Args {
|
Ok(Args {
|
||||||
ids: matches.is_present("ids"),
|
ids: matches.is_present("ids"),
|
||||||
end: matches.value_of("end").map(|s| parse_time(s)).transpose()?,
|
end: matches.value_of("end").map(|s| parse_time(s)).transpose()?,
|
||||||
format: matches.value_of("format").unwrap().parse()?,
|
format: matches.value_of("format").map(|v| v.parse()).transpose()?,
|
||||||
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
||||||
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
||||||
})
|
})
|
||||||
|
@ -42,7 +42,7 @@ pub struct TodayCommand { }
|
||||||
impl<'a> Command<'a> for TodayCommand {
|
impl<'a> Command<'a> for TodayCommand {
|
||||||
type Args = Args;
|
type Args = Args;
|
||||||
|
|
||||||
fn handle<D, O, E>(args: Self::Args, db: &mut D, out: &mut O, err: &mut E, _config: &Config, now: DateTime<Utc>) -> Result<()>
|
fn handle<D, O, E>(args: Self::Args, db: &mut D, out: &mut O, err: &mut E, config: &Config, now: DateTime<Utc>) -> Result<()>
|
||||||
where
|
where
|
||||||
D: Database,
|
D: Database,
|
||||||
O: Write,
|
O: Write,
|
||||||
|
@ -50,6 +50,39 @@ impl<'a> Command<'a> for TodayCommand {
|
||||||
{
|
{
|
||||||
let start = Some(now.with_timezone(&Local).date().and_hms(0, 0, 0).with_timezone(&Utc));
|
let start = Some(now.with_timezone(&Local).date().and_hms(0, 0, 0).with_timezone(&Utc));
|
||||||
|
|
||||||
entries_for_display(start, args.end, args.sheet, db, out, err, args.format, args.ids, args.grep, now)
|
entries_for_display(start, args.end, args.sheet, db, out, err, args.format.unwrap_or_else(|| config.default_formatter.clone()), args.ids, args.grep, now)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(test)]
|
||||||
|
mod tests {
|
||||||
|
use chrono::TimeZone;
|
||||||
|
|
||||||
|
use crate::database::SqliteDatabase;
|
||||||
|
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn respect_default_formatter() {
|
||||||
|
std::env::set_var("TZ", "CST+6");
|
||||||
|
|
||||||
|
let args = Default::default();
|
||||||
|
let mut db = SqliteDatabase::from_memory().unwrap();
|
||||||
|
let mut out = Vec::new();
|
||||||
|
let mut err = Vec::new();
|
||||||
|
let config = Config {
|
||||||
|
default_formatter: Formatter::Ids,
|
||||||
|
..Default::default()
|
||||||
|
};
|
||||||
|
|
||||||
|
db.init().unwrap();
|
||||||
|
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 0, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 10, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
|
||||||
|
TodayCommand::handle(args, &mut db, &mut out, &mut err, &config, Utc.ymd(2021, 6, 30).and_hms(11, 0, 0)).unwrap();
|
||||||
|
|
||||||
|
assert_eq!(&String::from_utf8_lossy(&out), "1 2\n");
|
||||||
|
assert_eq!(String::from_utf8_lossy(&err), "");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -62,7 +62,7 @@ fn prev_day(now: DateTime<Local>, week_start: WeekDay) -> DateTime<Utc> {
|
||||||
pub struct Args {
|
pub struct Args {
|
||||||
ids: bool,
|
ids: bool,
|
||||||
end: Option<DateTime<Utc>>,
|
end: Option<DateTime<Utc>>,
|
||||||
format: Formatter,
|
format: Option<Formatter>,
|
||||||
grep: Option<Regex>,
|
grep: Option<Regex>,
|
||||||
sheet: Option<Sheet>,
|
sheet: Option<Sheet>,
|
||||||
}
|
}
|
||||||
|
@ -74,7 +74,7 @@ impl<'a> TryFrom<&'a ArgMatches<'a>> for Args {
|
||||||
Ok(Args {
|
Ok(Args {
|
||||||
ids: matches.is_present("ids"),
|
ids: matches.is_present("ids"),
|
||||||
end: matches.value_of("end").map(|s| parse_time(s)).transpose()?,
|
end: matches.value_of("end").map(|s| parse_time(s)).transpose()?,
|
||||||
format: matches.value_of("format").unwrap().parse()?,
|
format: matches.value_of("format").map(|v| v.parse()).transpose()?,
|
||||||
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
||||||
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
||||||
})
|
})
|
||||||
|
@ -94,16 +94,18 @@ impl<'a> Command<'a> for WeekCommand {
|
||||||
{
|
{
|
||||||
let start = prev_day(now.with_timezone(&Local), config.week_start);
|
let start = prev_day(now.with_timezone(&Local), config.week_start);
|
||||||
|
|
||||||
entries_for_display(Some(start), args.end, args.sheet, db, out, err, args.format, args.ids, args.grep, now)
|
entries_for_display(Some(start), args.end, args.sheet, db, out, err, args.format.unwrap_or_else(|| config.default_formatter.clone()), args.ids, args.grep, now)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
|
||||||
|
|
||||||
use chrono::TimeZone;
|
use chrono::TimeZone;
|
||||||
|
|
||||||
|
use crate::database::SqliteDatabase;
|
||||||
|
|
||||||
|
use super::*;
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn test_prev_day() {
|
fn test_prev_day() {
|
||||||
// starting a saturday
|
// starting a saturday
|
||||||
|
@ -117,4 +119,28 @@ mod tests {
|
||||||
assert_eq!(prev_day(now, WeekDay::Saturday), Local.ymd(2021, 7, 10).and_hms(0, 0, 0).with_timezone(&Utc));
|
assert_eq!(prev_day(now, WeekDay::Saturday), Local.ymd(2021, 7, 10).and_hms(0, 0, 0).with_timezone(&Utc));
|
||||||
assert_eq!(prev_day(now, WeekDay::Sunday), Local.ymd(2021, 7, 4).and_hms(0, 0, 0).with_timezone(&Utc));
|
assert_eq!(prev_day(now, WeekDay::Sunday), Local.ymd(2021, 7, 4).and_hms(0, 0, 0).with_timezone(&Utc));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn respect_default_formatter() {
|
||||||
|
std::env::set_var("TZ", "CST+6");
|
||||||
|
|
||||||
|
let args = Default::default();
|
||||||
|
let mut db = SqliteDatabase::from_memory().unwrap();
|
||||||
|
let mut out = Vec::new();
|
||||||
|
let mut err = Vec::new();
|
||||||
|
let config = Config {
|
||||||
|
default_formatter: Formatter::Ids,
|
||||||
|
..Default::default()
|
||||||
|
};
|
||||||
|
|
||||||
|
db.init().unwrap();
|
||||||
|
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 0, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 10, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
|
||||||
|
WeekCommand::handle(args, &mut db, &mut out, &mut err, &config, Utc.ymd(2021, 7, 1).and_hms(10, 0, 0)).unwrap();
|
||||||
|
|
||||||
|
assert_eq!(&String::from_utf8_lossy(&out), "1 2\n");
|
||||||
|
assert_eq!(String::from_utf8_lossy(&err), "");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,7 +16,7 @@ use super::{Command, display::{Sheet, entries_for_display}};
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
pub struct Args {
|
pub struct Args {
|
||||||
ids: bool,
|
ids: bool,
|
||||||
format: Formatter,
|
format: Option<Formatter>,
|
||||||
grep: Option<Regex>,
|
grep: Option<Regex>,
|
||||||
sheet: Option<Sheet>,
|
sheet: Option<Sheet>,
|
||||||
}
|
}
|
||||||
|
@ -27,7 +27,7 @@ impl<'a> TryFrom<&'a ArgMatches<'a>> for Args {
|
||||||
fn try_from(matches: &'a ArgMatches) -> Result<Args> {
|
fn try_from(matches: &'a ArgMatches) -> Result<Args> {
|
||||||
Ok(Args {
|
Ok(Args {
|
||||||
ids: matches.is_present("ids"),
|
ids: matches.is_present("ids"),
|
||||||
format: matches.value_of("format").unwrap().parse()?,
|
format: matches.value_of("format").map(|v| v.parse()).transpose()?,
|
||||||
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
grep: matches.value_of("grep").map(parse_regex).transpose()?,
|
||||||
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
sheet: matches.value_of("sheet").map(|s| s.parse()).transpose()?,
|
||||||
})
|
})
|
||||||
|
@ -39,7 +39,7 @@ pub struct YesterdayCommand { }
|
||||||
impl<'a> Command<'a> for YesterdayCommand {
|
impl<'a> Command<'a> for YesterdayCommand {
|
||||||
type Args = Args;
|
type Args = Args;
|
||||||
|
|
||||||
fn handle<D, O, E>(args: Self::Args, db: &mut D, out: &mut O, err: &mut E, _config: &Config, now: DateTime<Utc>) -> Result<()>
|
fn handle<D, O, E>(args: Self::Args, db: &mut D, out: &mut O, err: &mut E, config: &Config, now: DateTime<Utc>) -> Result<()>
|
||||||
where
|
where
|
||||||
D: Database,
|
D: Database,
|
||||||
O: Write,
|
O: Write,
|
||||||
|
@ -49,13 +49,13 @@ impl<'a> Command<'a> for YesterdayCommand {
|
||||||
let start = Some((today - Duration::days(1)).and_hms(0, 0, 0).with_timezone(&Utc));
|
let start = Some((today - Duration::days(1)).and_hms(0, 0, 0).with_timezone(&Utc));
|
||||||
let end = Some(today.and_hms(0, 0, 0).with_timezone(&Utc));
|
let end = Some(today.and_hms(0, 0, 0).with_timezone(&Utc));
|
||||||
|
|
||||||
entries_for_display(start, end, args.sheet, db, out, err, args.format, args.ids, args.grep, now)
|
entries_for_display(start, end, args.sheet, db, out, err, args.format.unwrap_or_else(|| config.default_formatter.clone()), args.ids, args.grep, now)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use chrono::Duration;
|
use chrono::{Duration, TimeZone};
|
||||||
use pretty_assertions::assert_eq;
|
use pretty_assertions::assert_eq;
|
||||||
|
|
||||||
use crate::database::SqliteDatabase;
|
use crate::database::SqliteDatabase;
|
||||||
|
@ -66,7 +66,7 @@ mod tests {
|
||||||
#[test]
|
#[test]
|
||||||
fn returns_yesterday_entries_only() {
|
fn returns_yesterday_entries_only() {
|
||||||
let args = Args {
|
let args = Args {
|
||||||
format: Formatter::Csv,
|
format: Some(Formatter::Csv),
|
||||||
..Default::default()
|
..Default::default()
|
||||||
};
|
};
|
||||||
let mut db = SqliteDatabase::from_memory().unwrap();
|
let mut db = SqliteDatabase::from_memory().unwrap();
|
||||||
|
@ -95,4 +95,28 @@ mod tests {
|
||||||
String::new(),
|
String::new(),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn respect_default_formatter() {
|
||||||
|
std::env::set_var("TZ", "CST+6");
|
||||||
|
|
||||||
|
let args = Default::default();
|
||||||
|
let mut db = SqliteDatabase::from_memory().unwrap();
|
||||||
|
let mut out = Vec::new();
|
||||||
|
let mut err = Vec::new();
|
||||||
|
let config = Config {
|
||||||
|
default_formatter: Formatter::Ids,
|
||||||
|
..Default::default()
|
||||||
|
};
|
||||||
|
|
||||||
|
db.init().unwrap();
|
||||||
|
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 0, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
db.entry_insert(Utc.ymd(2021, 6, 30).and_hms(10, 10, 0), None, Some("hola".into()), "default".into()).unwrap();
|
||||||
|
|
||||||
|
YesterdayCommand::handle(args, &mut db, &mut out, &mut err, &config, Utc.ymd(2021, 7, 1).and_hms(10, 0, 0)).unwrap();
|
||||||
|
|
||||||
|
assert_eq!(&String::from_utf8_lossy(&out), "1 2\n");
|
||||||
|
assert_eq!(String::from_utf8_lossy(&err), "");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -79,7 +79,7 @@ fn main() {
|
||||||
|
|
||||||
let format_arg = Arg::with_name("format")
|
let format_arg = Arg::with_name("format")
|
||||||
.short("f").long("format")
|
.short("f").long("format")
|
||||||
.takes_value(true).value_name("FORMAT").default_value("text")
|
.takes_value(true).value_name("FORMAT")
|
||||||
.help(
|
.help(
|
||||||
"The output format. Valid built-in formats are ical, csv, json, \
|
"The output format. Valid built-in formats are ical, csv, json, \
|
||||||
ids, and text. Documentation on defining custom formats can be \
|
ids, and text. Documentation on defining custom formats can be \
|
||||||
|
|
Loading…
Reference in New Issue