Files
nushell/crates/nu-std/tests/logger_tests/test_basic_commands.nu
Bahex beb3ec6a49 refactor(get,select,reject)!: deprecate --ignore-errors in favor of --optional (#16007)
# Description
As decided on the team meeting on 2025-06-19, rename `--ignore-errors
(-i)` to `--optional (-o)` with a (currently) indefinite grace period.

After `--ignore-errors (-i)` is removed, the short flag `-i` can be used
for `--ignore-case` (not implemented as of this PR)

# User-Facing Changes
`get`/`select`/`reject`: rename `--ignore-errors (-i)` to `--optional
(-o)` to better reflect its behavior.

# Tests + Formatting
- 🟢 toolkit fmt
- 🟢 toolkit clippy
- 🟢 toolkit test
- 🟢 toolkit test stdlib

# After Submitting
Update docs and inform third parties that integrate with nushell.

---------

Co-authored-by: Bahex <17417311+Bahex@users.noreply.github.com>
2025-07-15 00:26:41 -04:00

99 lines
2.0 KiB
Plaintext

use std/testing *
use std/assert
def run [
system_level,
message_level
--short
] {
if $short {
^$nu.current-exe --no-config-file --commands $'use std; use std/log; NU_LOG_LEVEL=($system_level) log ($message_level) --short "test message"'
} else {
^$nu.current-exe --no-config-file --commands $'use std; use std/log; NU_LOG_LEVEL=($system_level) log ($message_level) "test message"'
}
| complete | get --optional stderr
}
def "assert no message" [
system_level,
message_level
] {
let output = (run $system_level $message_level)
assert equal "" $output
}
def "assert message" [
system_level,
message_level,
message_level_str
] {
let output = (run $system_level $message_level)
assert str contains $output $message_level_str
assert str contains $output "test message"
}
def "assert message short" [
system_level,
message_level,
message_level_str
] {
let output = (run --short $system_level $message_level)
assert str contains $output $message_level_str
assert str contains $output "test message"
}
@test
def critical [] {
assert no message 99 critical
assert message CRITICAL critical CRT
}
@test
def critical_short [] {
assert message short CRITICAL critical C
}
@test
def error [] {
assert no message CRITICAL error
assert message ERROR error ERR
}
@test
def error_short [] {
assert message short ERROR error E
}
@test
def warning [] {
assert no message ERROR warning
assert message WARNING warning WRN
}
@test
def warning_short [] {
assert message short WARNING warning W
}
@test
def info [] {
assert no message WARNING info
assert message INFO info "INF" # INF has to be quoted, otherwise it is the `inf` float
}
@test
def info_short [] {
assert message short INFO info I
}
@test
def debug [] {
assert no message INFO debug
assert message DEBUG debug DBG
}
@test
def debug_short [] {
assert message short DEBUG debug D
}