mirror of
https://github.com/nushell/nushell
synced 2025-01-04 09:18:57 +00:00
3b2ed7631f
* Add new path parse subcommand This includes a slight refactor to all the path subcommand `action()` functions. * Remove filestem and extension; Fix example * Add additional description to path parse * Put join arg behind flag; Fix missing import (Win) * Fix error when column path is passed as arg * Add structured path joining Structured path is implicitly joined at every patch subcommand call. * Fix existing path join tests; Fix rustfmt * Remove redundant 'static lifetime (clippy) * Add initial impl of path split subcommand * Add ability to join path from parts * Fix wrong results in path split examples * Fix remaining asyncs after engine change * Do not wrap split path parts into table When the input is just a list of values, the `path split` command will split each value directly into the output stream, similar to `split-row`. Column path--specified values are still wrapped into a table so they can still be used to replace table fields. * Join list of values instead of going one-by-one When `path join` encounters a list of values, it attempts to join them, instead of going one-by-one like the rest of the path commands. You can still `each { echo $it | path join }` to join them one-by-one, if the values are, e.g., tables. Now, the behavior of `path split` and `path join` should match the `split-row` and `str collect` counterparts and should hopefully align better with user's expectations. * Make sure path join detects structured path * Fix panic on empty input stream Also, doesn't collect input into vector unnecessarily. * Fix path join not appending value * Remove argument serialization * Make better errors; Misc refactor * OsStr -> String encoding is now lossy, instead of throwing an error * The consequence is action() now always returns Value instead of Result * Removed redundant handle_value() call in `path join` * Fix possible incorrect error detection in `path split` * Applied rustfmt + clippy * Add more usage, examples & test; Fix type error The 'parent' column was required to be a path but didn't work with string. * Add more help & examples; Maybe fix Windows error * Refactor operate function Reducing code repetition * Review usages and examples * Add the option to manually specify the extension * Add more tests; Fix failures on Windows * Move path commands to engine-p * Small refactor
136 lines
2.6 KiB
Rust
136 lines
2.6 KiB
Rust
use nu_test_support::{nu, pipeline};
|
|
|
|
#[cfg(windows)]
|
|
#[test]
|
|
fn parses_single_path_prefix() {
|
|
let actual = nu!(
|
|
cwd: "tests", pipeline(
|
|
r#"
|
|
echo 'C:\users\viking\spam.txt'
|
|
| path parse
|
|
| get prefix
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "C:");
|
|
}
|
|
|
|
#[test]
|
|
fn parses_single_path_parent() {
|
|
let actual = nu!(
|
|
cwd: "tests", pipeline(
|
|
r#"
|
|
echo 'home/viking/spam.txt'
|
|
| path parse
|
|
| get parent
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "home/viking");
|
|
}
|
|
|
|
#[test]
|
|
fn parses_single_path_stem() {
|
|
let actual = nu!(
|
|
cwd: "tests", pipeline(
|
|
r#"
|
|
echo 'home/viking/spam.txt'
|
|
| path parse
|
|
| get stem
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "spam");
|
|
}
|
|
|
|
#[test]
|
|
fn parses_custom_extension_gets_extension() {
|
|
let actual = nu!(
|
|
cwd: "tests", pipeline(
|
|
r#"
|
|
echo 'home/viking/spam.tar.gz'
|
|
| path parse -e tar.gz
|
|
| get extension
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "tar.gz");
|
|
}
|
|
|
|
#[test]
|
|
fn parses_custom_extension_gets_stem() {
|
|
let actual = nu!(
|
|
cwd: "tests", pipeline(
|
|
r#"
|
|
echo 'home/viking/spam.tar.gz'
|
|
| path parse -e tar.gz
|
|
| get stem
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "spam");
|
|
}
|
|
|
|
#[test]
|
|
fn parses_ignoring_extension_gets_extension() {
|
|
let actual = nu!(
|
|
cwd: "tests", pipeline(
|
|
r#"
|
|
echo 'home/viking/spam.tar.gz'
|
|
| path parse -e ''
|
|
| get extension
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "");
|
|
}
|
|
|
|
#[test]
|
|
fn parses_ignoring_extension_gets_stem() {
|
|
let actual = nu!(
|
|
cwd: "tests", pipeline(
|
|
r#"
|
|
echo 'home/viking/spam.tar.gz'
|
|
| path parse -e ""
|
|
| get stem
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "spam.tar.gz");
|
|
}
|
|
|
|
#[test]
|
|
fn parses_column_path_extension() {
|
|
let actual = nu!(
|
|
cwd: "tests", pipeline(
|
|
r#"
|
|
echo [[home, barn]; ['home/viking/spam.txt', 'barn/cow/moo.png']]
|
|
| path parse home barn
|
|
| get barn
|
|
| get extension
|
|
"#
|
|
));
|
|
|
|
assert_eq!(actual.out, "png");
|
|
}
|
|
|
|
#[test]
|
|
fn parses_into_correct_number_of_columns() {
|
|
let actual = nu!(
|
|
cwd: "tests", pipeline(
|
|
r#"
|
|
echo 'home/viking/spam.txt'
|
|
| path parse
|
|
| pivot
|
|
| get Column0
|
|
| length
|
|
"#
|
|
));
|
|
|
|
#[cfg(windows)]
|
|
let expected = "4";
|
|
#[cfg(not(windows))]
|
|
let expected = "3";
|
|
|
|
assert_eq!(actual.out, expected);
|
|
}
|