use nu_test_support::{nu, pipeline}; #[test] fn columns() { let actual = nu!(pipeline( " echo [ [arepas, color]; [3, white] [8, yellow] [4, white] ] | drop column | columns | length " )); assert_eq!(actual.out, "1"); } #[test] fn drop_columns_positive_value() { let actual = nu!("echo [[a, b];[1,2]] | drop column -1"); assert!(actual.err.contains("use a positive value")); } #[test] fn more_columns_than_table_has() { let actual = nu!(pipeline( " echo [ [arepas, color]; [3, white] [8, yellow] [4, white] ] | drop column 3 | columns | is-empty " )); assert_eq!(actual.out, "true"); } #[test] fn rows() { let actual = nu!(pipeline( " echo [ [arepas]; [3] [8] [4] ] | drop 2 | get arepas | math sum " )); assert_eq!(actual.out, "3"); } #[test] fn more_rows_than_table_has() { let actual = nu!("[date] | drop 50 | length"); assert_eq!(actual.out, "0"); } #[test] fn nth_range_inclusive() { let actual = nu!("echo 10..15 | drop nth (2..3) | to json --raw"); assert_eq!(actual.out, "[10,11,14,15]"); } #[test] fn nth_range_exclusive() { let actual = nu!("echo 10..15 | drop nth (1..<3) | to json --raw"); assert_eq!(actual.out, "[10,13,14,15]"); } #[test] fn nth_missing_first_argument() { let actual = nu!("echo 10..15 | drop nth \"\""); assert!(actual.err.contains("int or range")); } #[test] fn fail_on_non_iterator() { let actual = nu!("1 | drop 50"); assert!(actual.err.contains("command doesn't support")); } #[test] fn disjoint_columns_first_row_becomes_empty() { let actual = nu!(pipeline( " [{a: 1}, {b: 2, c: 3}] | drop column | columns | to nuon " )); assert_eq!(actual.out, "[b, c]"); } #[test] fn disjoint_columns() { let actual = nu!(pipeline( " [{a: 1, b: 2}, {c: 3}] | drop column | columns | to nuon " )); assert_eq!(actual.out, "[a, c]"); } #[test] fn record() { let actual = nu!("{a: 1, b: 2} | drop column | to nuon"); assert_eq!(actual.out, "{a: 1}"); } #[test] fn more_columns_than_record_has() { let actual = nu!("{a: 1, b: 2} | drop column 3 | to nuon"); assert_eq!(actual.out, "{}"); } #[test] fn drop_single_index() { let actual = nu!("echo 10..15 | drop nth 2 | to json --raw"); assert_eq!(actual.out, "[10,11,13,14,15]"); } #[test] fn drop_multiple_indices() { let actual = nu!("echo 0..10 | drop nth 1 3 | to json --raw"); assert_eq!(actual.out, "[0,2,4,5,6,7,8,9,10]"); } #[test] fn drop_inclusive_range() { let actual = nu!("echo 10..15 | drop nth (2..4) | to json --raw"); assert_eq!(actual.out, "[10,11,15]"); } #[test] fn drop_exclusive_range() { let actual = nu!("echo 10..15 | drop nth (2..<4) | to json --raw"); assert_eq!(actual.out, "[10,11,14,15]"); } #[test] fn drop_unbounded_range() { let actual = nu!("echo 0..5 | drop nth 3.. | to json --raw"); assert_eq!(actual.out, "[0,1,2]"); } #[test] fn drop_multiple_ranges_including_unbounded() { let actual = nu!(pipeline( r#" 0..30 | drop nth 0..10 20.. | to json --raw "# )); assert_eq!(actual.out, "[11,12,13,14,15,16,17,18,19]"); } #[test] fn drop_combination_of_unbounded_range_and_single_index() { let actual = nu!(pipeline( r#" echo 0..15 | drop nth 10.. 5 | to json --raw "# )); assert_eq!(actual.out, "[0,1,2,3,4,6,7,8,9]"); } #[test] fn drop_combination_of_two_unbounded_ranges() { let actual = nu!(pipeline( r#" echo 0..150 | drop nth 0..100 999.. | to json --raw "# )); let expected: Vec = (101..=150).collect(); let expected_json = serde_json::to_string(&expected).unwrap(); assert_eq!(actual.out, expected_json); }