2023-02-27 23:52:47 +00:00
|
|
|
use std.nu
|
|
|
|
|
|
|
|
def test_assert [] {
|
|
|
|
def test_failing [code: closure] {
|
|
|
|
let code_did_run = (try { do $code; true } catch { false })
|
|
|
|
|
|
|
|
if $code_did_run {
|
|
|
|
error make {msg: (view source $code)}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
std assert true
|
|
|
|
std assert (1 + 2 == 3)
|
|
|
|
test_failing { std assert false }
|
|
|
|
test_failing { std assert (1 + 2 == 4) }
|
|
|
|
|
|
|
|
std assert eq (1 + 2) 3
|
|
|
|
test_failing { std assert eq 1 "foo" }
|
|
|
|
test_failing { std assert eq (1 + 2) 4) }
|
|
|
|
|
|
|
|
std assert ne (1 + 2) 4
|
|
|
|
test_failing { std assert ne 1 "foo" }
|
|
|
|
test_failing { std assert ne (1 + 2) 3) }
|
|
|
|
}
|
|
|
|
|
|
|
|
def tests [] {
|
|
|
|
use std.nu assert
|
|
|
|
|
|
|
|
let branches = {
|
|
|
|
1: { -1 }
|
|
|
|
2: { -2 }
|
|
|
|
}
|
|
|
|
|
|
|
|
assert ((std match 1 $branches) == -1)
|
|
|
|
assert ((std match 2 $branches) == -2)
|
|
|
|
assert ((std match 3 $branches) == $nothing)
|
|
|
|
|
|
|
|
assert ((std match 1 $branches { 0 }) == -1)
|
|
|
|
assert ((std match 2 $branches { 0 }) == -2)
|
|
|
|
assert ((std match 3 $branches { 0 }) == 0)
|
|
|
|
}
|
|
|
|
|
2023-03-07 23:06:14 +00:00
|
|
|
def test_path_add [] {
|
|
|
|
use std.nu "assert eq"
|
|
|
|
|
|
|
|
with-env [PATH []] {
|
|
|
|
assert eq $env.PATH []
|
|
|
|
|
|
|
|
std path add "/foo/"
|
|
|
|
assert eq $env.PATH ["/foo/"]
|
|
|
|
|
|
|
|
std path add "/bar/" "/baz/"
|
|
|
|
assert eq $env.PATH ["/bar/", "/baz/", "/foo/"]
|
|
|
|
|
|
|
|
let-env PATH = []
|
|
|
|
|
|
|
|
std path add "foo"
|
|
|
|
std path add "bar" "baz" --append
|
|
|
|
assert eq $env.PATH ["foo", "bar", "baz"]
|
|
|
|
|
|
|
|
assert eq (std path add "fooooo" --ret) ["fooooo", "foo", "bar", "baz"]
|
|
|
|
assert eq $env.PATH ["fooooo", "foo", "bar", "baz"]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
add `dirs` command to std lib (#8368)
# Description
Prototype replacement for `enter`, `n`, `p`, `exit` built-ins
implemented as scripts in standard library.
MVP-level capabilities (rough hack), for feedback please. Not intended
to merge and ship as is.
_(Description of your pull request goes here. **Provide examples and/or
screenshots** if your changes affect the user experience.)_
# User-Facing Changes
New command in standard library
```nushell
〉use ~/src/rust/nushell/crates/nu-utils/standard_library/dirs.nu
---------------------------------------------- /home/bobhy ----------------------------------------------
〉help dirs
module dirs.nu -- maintain list of remembered directories + navigate them
todo:
* expand relative to absolute paths (or relative to some prefix?)
* what if user does `cd` by hand?
Module: dirs
Exported commands:
add (dirs add), drop, next (dirs next), prev (dirs prev), show (dirs show)
This module exports environment.
---------------------------------------------- /home/bobhy ----------------------------------------------
〉dirs add ~/src/rust/nushell /etc ~/.cargo
-------------------------------------- /home/bobhy/src/rust/nushell --------------------------------------
〉dirs next 2
------------------------------------------- /home/bobhy/.cargo -------------------------------------------
〉dirs show
╭───┬─────────┬────────────────────╮
│ # │ current │ path │
├───┼─────────┼────────────────────┤
│ 0 │ │ /home/bobhy │
│ 1 │ │ ~/src/rust/nushell │
│ 2 │ │ /etc │
│ 3 │ ==> │ ~/.cargo │
╰───┴─────────┴────────────────────╯
------------------------------------------- /home/bobhy/.cargo -------------------------------------------
〉dirs drop
---------------------------------------------- /home/bobhy ----------------------------------------------
〉dirs show
╭───┬─────────┬────────────────────╮
│ # │ current │ path │
├───┼─────────┼────────────────────┤
│ 0 │ ==> │ /home/bobhy │
│ 1 │ │ ~/src/rust/nushell │
│ 2 │ │ /etc │
╰───┴─────────┴────────────────────╯
---------------------------------------------- /home/bobhy ----------------------------------------------
〉
```
# Tests + Formatting
Haven't even looked at stdlib `tests.nu` yet.
Other todos:
* address module todos.
* integrate into std lib, rather than as standalone module. Somehow
arrange for `use .../standard_library/std.nu` to load this module
without having to put all the source in `std.nu`?
* Maybe command should be `std dirs ...`?
* what else do `enter` and `exit` do that this should do? Then deprecate
those commands.
Don't forget to add tests that cover your changes.
Make sure you've run and fixed any issues with these commands:
- `cargo fmt --all -- --check` to check standard code formatting (`cargo
fmt --all` applies these changes)
- `cargo clippy --workspace -- -D warnings -D clippy::unwrap_used -A
clippy::needless_collect` to check that you're using the standard code
style
- `cargo test --workspace` to check that all tests pass
# After Submitting
If your PR had any user-facing changes, update [the
documentation](https://github.com/nushell/nushell.github.io) after the
PR is merged, if necessary. This will help us keep the docs up to date.
2023-03-11 22:31:09 +00:00
|
|
|
|
|
|
|
def test_dirs [] {
|
|
|
|
|
|
|
|
def "myassert" [
|
|
|
|
predicate: bool
|
|
|
|
msg?:string = "..."
|
|
|
|
--verbose = false (-v) # enable to see successful tests
|
|
|
|
] {
|
|
|
|
if not $predicate {
|
|
|
|
let span = (metadata $predicate).span
|
|
|
|
error make {msg: $"Assertion failed checking ($msg)",
|
|
|
|
label: {text: "Condition not true" start: $span.start end: $span.end}}
|
|
|
|
} else {
|
|
|
|
if $verbose {
|
|
|
|
echo $"check succeeded: ($msg)"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# need some directories to play with
|
|
|
|
let base_path = (($nu.temp-path) | path join $"test_dirs_(random uuid)" | path expand )
|
|
|
|
let path_a = ($base_path | path join "a")
|
|
|
|
let path_b = ($base_path | path join "b")
|
|
|
|
|
|
|
|
try {
|
|
|
|
mkdir $base_path $path_a $path_b
|
|
|
|
cd $base_path
|
|
|
|
use dirs.nu
|
|
|
|
|
|
|
|
myassert (1 == ($env.DIRS_LIST | length)) "list is just pwd after initialization"
|
|
|
|
myassert ($base_path == $env.DIRS_LIST.0) "list is just pwd after initialization"
|
|
|
|
|
|
|
|
dirs next
|
|
|
|
myassert ($base_path == $env.DIRS_LIST.0) "next wraps at end of list"
|
|
|
|
|
|
|
|
dirs prev
|
|
|
|
myassert ($base_path == $env.DIRS_LIST.0) "prev wraps at top of list"
|
|
|
|
|
|
|
|
dirs add $path_b $path_a
|
|
|
|
myassert ($path_b == $env.PWD) "add changes PWD to first added dir"
|
|
|
|
myassert (3 == ($env.DIRS_LIST | length)) "add in fact adds to list"
|
|
|
|
myassert ($path_a == $env.DIRS_LIST.2) "add in fact adds to list"
|
|
|
|
|
|
|
|
dirs next 2
|
|
|
|
myassert ($base_path == $env.PWD) "next wraps at end of list"
|
|
|
|
|
|
|
|
dirs prev 1
|
|
|
|
myassert ($path_a == $env.PWD) "prev wraps at start of list"
|
|
|
|
|
|
|
|
dirs drop
|
|
|
|
myassert (2 == ($env.DIRS_LIST | length)) "drop removes from list"
|
|
|
|
myassert ($base_path == $env.PWD) "drop changes PWD to next in list (after dropped element)"
|
|
|
|
|
|
|
|
myassert ((dirs show) == [[active path]; [true $base_path] [false $path_b]]) "show table contains expected information"
|
|
|
|
} catch { |error|
|
|
|
|
$error | debug
|
|
|
|
true
|
|
|
|
}
|
|
|
|
|
|
|
|
cd $base_path
|
|
|
|
cd ..
|
|
|
|
rm -r $base_path
|
|
|
|
}
|
|
|
|
|
2023-02-27 23:52:47 +00:00
|
|
|
def main [] {
|
|
|
|
test_assert
|
|
|
|
tests
|
2023-03-07 23:06:14 +00:00
|
|
|
test_path_add
|
add `dirs` command to std lib (#8368)
# Description
Prototype replacement for `enter`, `n`, `p`, `exit` built-ins
implemented as scripts in standard library.
MVP-level capabilities (rough hack), for feedback please. Not intended
to merge and ship as is.
_(Description of your pull request goes here. **Provide examples and/or
screenshots** if your changes affect the user experience.)_
# User-Facing Changes
New command in standard library
```nushell
〉use ~/src/rust/nushell/crates/nu-utils/standard_library/dirs.nu
---------------------------------------------- /home/bobhy ----------------------------------------------
〉help dirs
module dirs.nu -- maintain list of remembered directories + navigate them
todo:
* expand relative to absolute paths (or relative to some prefix?)
* what if user does `cd` by hand?
Module: dirs
Exported commands:
add (dirs add), drop, next (dirs next), prev (dirs prev), show (dirs show)
This module exports environment.
---------------------------------------------- /home/bobhy ----------------------------------------------
〉dirs add ~/src/rust/nushell /etc ~/.cargo
-------------------------------------- /home/bobhy/src/rust/nushell --------------------------------------
〉dirs next 2
------------------------------------------- /home/bobhy/.cargo -------------------------------------------
〉dirs show
╭───┬─────────┬────────────────────╮
│ # │ current │ path │
├───┼─────────┼────────────────────┤
│ 0 │ │ /home/bobhy │
│ 1 │ │ ~/src/rust/nushell │
│ 2 │ │ /etc │
│ 3 │ ==> │ ~/.cargo │
╰───┴─────────┴────────────────────╯
------------------------------------------- /home/bobhy/.cargo -------------------------------------------
〉dirs drop
---------------------------------------------- /home/bobhy ----------------------------------------------
〉dirs show
╭───┬─────────┬────────────────────╮
│ # │ current │ path │
├───┼─────────┼────────────────────┤
│ 0 │ ==> │ /home/bobhy │
│ 1 │ │ ~/src/rust/nushell │
│ 2 │ │ /etc │
╰───┴─────────┴────────────────────╯
---------------------------------------------- /home/bobhy ----------------------------------------------
〉
```
# Tests + Formatting
Haven't even looked at stdlib `tests.nu` yet.
Other todos:
* address module todos.
* integrate into std lib, rather than as standalone module. Somehow
arrange for `use .../standard_library/std.nu` to load this module
without having to put all the source in `std.nu`?
* Maybe command should be `std dirs ...`?
* what else do `enter` and `exit` do that this should do? Then deprecate
those commands.
Don't forget to add tests that cover your changes.
Make sure you've run and fixed any issues with these commands:
- `cargo fmt --all -- --check` to check standard code formatting (`cargo
fmt --all` applies these changes)
- `cargo clippy --workspace -- -D warnings -D clippy::unwrap_used -A
clippy::needless_collect` to check that you're using the standard code
style
- `cargo test --workspace` to check that all tests pass
# After Submitting
If your PR had any user-facing changes, update [the
documentation](https://github.com/nushell/nushell.github.io) after the
PR is merged, if necessary. This will help us keep the docs up to date.
2023-03-11 22:31:09 +00:00
|
|
|
test_dirs
|
2023-02-27 23:52:47 +00:00
|
|
|
}
|