respect blocks passed without long from cli

When reading from config, we do not take into consideration the value
of blocks until we pass -l in the cli args, but if the user passes
in blocks via the cli, the -l flag is implied.
This commit is contained in:
Abin Simon 2020-12-23 10:24:51 +05:30
parent e3649fede8
commit c089af22ab
3 changed files with 14 additions and 14 deletions

View file

@ -8,6 +8,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
### Added
### Changed
### Fixed
- Fix handling blocks passed without -l in cli from [meain](https://github.com/meain)
## [0.19.0] - 2020-12-13
### Added

View file

@ -35,8 +35,7 @@ impl Blocks {
Ok(Default::default())
};
if matches.is_present("long") {
if !matches.is_present("ignore-config") {
if matches.is_present("long") && !matches.is_present("ignore-config") {
if let Some(value) = Self::from_config(config) {
result = Ok(value);
}
@ -45,7 +44,6 @@ impl Blocks {
if let Some(value) = Self::from_arg_matches(matches) {
result = value;
}
}
if matches.is_present("inode") {
if let Ok(blocks) = result.as_mut() {
@ -238,7 +236,7 @@ mod test_blocks {
#[test]
fn test_configure_from_with_blocks_and_without_long() {
let argv = vec!["lsd", "--blocks", "permission"];
let target = Ok::<_, Error>(Blocks::default());
let target = Ok::<_, Error>(Blocks(vec![Block::Permission]));
let matches = app::build().get_matches_from_safe(argv).unwrap();
let result = Blocks::configure_from(&matches, &Config::with_none());
@ -275,7 +273,7 @@ mod test_blocks {
fn test_configure_from_prepend_inode_without_long() {
let argv = vec!["lsd", "--blocks", "permission", "--inode"];
let mut target_blocks = Blocks::default();
let mut target_blocks = Blocks(vec![Block::Permission]);
target_blocks.0.insert(0, Block::INode);
let target = Ok::<_, Error>(target_blocks);
@ -300,9 +298,7 @@ mod test_blocks {
fn test_configure_from_ignore_prepend_inode_without_long() {
let argv = vec!["lsd", "--blocks", "permission,inode", "--inode"];
let mut target_blocks = Blocks::default();
target_blocks.0.insert(0, Block::INode);
let target = Ok::<_, Error>(target_blocks);
let target = Ok::<_, Error>(Blocks(vec![Block::Permission, Block::INode]));
let matches = app::build().get_matches_from_safe(argv).unwrap();
let result = Blocks::configure_from(&matches, &Config::with_none());

View file

@ -128,7 +128,10 @@ fn test_list_block_inode_populated_directory_without_long() {
dir.child("one").touch().unwrap();
dir.child("two").touch().unwrap();
let matched = "one\ntwo\n$";
#[cfg(windows)]
let matched = "- one\n\\- two\n$";
#[cfg(unix)]
let matched = "\\d+ one\n\\d+ two\n$";
cmd()
.arg("--blocks")