mirror of
https://github.com/nushell/nushell
synced 2025-01-02 16:29:00 +00:00
9e667cc879
# Description
<!--
Thank you for improving Nushell. Please, check our [contributing
guide](../CONTRIBUTING.md) and talk to the core team before making major
changes.
Description of your pull request goes here. **Provide examples and/or
screenshots** if your changes affect the user experience.
-->
Add "os record" support.
# User-Facing Changes
<!-- List of all changes that impact the user experience here. This
helps us keep track of breaking changes. -->
This don't change how path add works but just adds support for "os
records" aka records whose key are at least one of:
- linux
- macos
- windows
Check the
[test](a917f1a924/crates/nu-std/tests/test_std.nu (L31-L32)
)
if that's not clear enough
# Tests + Formatting
<!--
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 -A clippy::result_large_err` to check that
you're using the standard code style
- `cargo test --workspace` to check that all tests pass
- `cargo run -- crates/nu-std/tests/run.nu` to run the tests for the
standard library
> **Note**
> from `nushell` you can also use the `toolkit` as follows
> ```bash
> use toolkit.nu # or use an `env_change` hook to activate it
automatically
> toolkit check pr
> ```
-->
# 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.
-->
---------
Co-authored-by: amtoine <stevan.antoine@gmail.com>
40 lines
1 KiB
Text
40 lines
1 KiB
Text
use std
|
|
|
|
export def test_path_add [] {
|
|
use std "assert equal"
|
|
|
|
let path_name = if "PATH" in $env { "PATH" } else { "Path" }
|
|
|
|
with-env [$path_name []] {
|
|
def get_path [] { $env | get $path_name }
|
|
|
|
assert equal (get_path) []
|
|
|
|
std path add "/foo/"
|
|
assert equal (get_path) ["/foo/"]
|
|
|
|
std path add "/bar/" "/baz/"
|
|
assert equal (get_path) ["/bar/", "/baz/", "/foo/"]
|
|
|
|
let-env $path_name = []
|
|
|
|
std path add "foo"
|
|
std path add "bar" "baz" --append
|
|
assert equal (get_path) ["foo", "bar", "baz"]
|
|
|
|
assert equal (std path add "fooooo" --ret) ["fooooo", "foo", "bar", "baz"]
|
|
assert equal (get_path) ["fooooo", "foo", "bar", "baz"]
|
|
|
|
let-env $path_name = []
|
|
let target_paths = {linux: "foo", windows: "bar", macos: "baz"}
|
|
|
|
std path add $target_paths
|
|
assert equal (get_path) [($target_paths | get $nu.os-info.name)]
|
|
|
|
|
|
}
|
|
}
|
|
|
|
export def test_banner [] {
|
|
std assert ((std banner | lines | length) == 15)
|
|
}
|