mirror of
https://github.com/sharkdp/bat.git
synced 2025-01-23 14:08:58 +01:00
Add unix specific integration test about running bat without any arguments
This commit is contained in:
parent
ace655e164
commit
b600f62ab6
1
Cargo.lock
generated
1
Cargo.lock
generated
@ -117,6 +117,7 @@ dependencies = [
|
|||||||
"syntect",
|
"syntect",
|
||||||
"tempdir",
|
"tempdir",
|
||||||
"unicode-width",
|
"unicode-width",
|
||||||
|
"wait-timeout",
|
||||||
"wild",
|
"wild",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -76,6 +76,7 @@ default-features = false
|
|||||||
tempdir = "0.3"
|
tempdir = "0.3"
|
||||||
assert_cmd = "1.0.2"
|
assert_cmd = "1.0.2"
|
||||||
predicates = "1.0.6"
|
predicates = "1.0.6"
|
||||||
|
wait-timeout = "0.2.0"
|
||||||
|
|
||||||
[build-dependencies]
|
[build-dependencies]
|
||||||
clap = { version = "2.33", optional = true }
|
clap = { version = "2.33", optional = true }
|
||||||
|
@ -5,8 +5,11 @@ use std::fs::File;
|
|||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
use std::process::{Command, Stdio};
|
use std::process::{Command, Stdio};
|
||||||
use std::str::from_utf8;
|
use std::str::from_utf8;
|
||||||
|
use std::time::Duration;
|
||||||
|
|
||||||
const EXAMPLES_DIR: &str = "tests/examples";
|
const EXAMPLES_DIR: &str = "tests/examples";
|
||||||
|
const SAFE_CHILD_PROCESS_CREATION_TIME: Duration = Duration::from_millis(100);
|
||||||
|
const CHILD_WAIT_TIMEOUT: Duration = Duration::from_secs(15);
|
||||||
|
|
||||||
fn bat_raw_command() -> Command {
|
fn bat_raw_command() -> Command {
|
||||||
let mut cmd = Command::cargo_bin("bat").unwrap();
|
let mut cmd = Command::cargo_bin("bat").unwrap();
|
||||||
@ -220,6 +223,56 @@ fn stdin_to_stdout_cycle() {
|
|||||||
.failure();
|
.failure();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(unix)]
|
||||||
|
#[test]
|
||||||
|
fn no_args_doesnt_break() {
|
||||||
|
use std::io::Write;
|
||||||
|
use std::os::unix::io::FromRawFd;
|
||||||
|
use std::thread;
|
||||||
|
|
||||||
|
use clircle::nix::pty::{openpty, OpenptyResult};
|
||||||
|
use wait_timeout::ChildExt;
|
||||||
|
|
||||||
|
// To simulate bat getting started from the shell, a process is created with stdin and stdout
|
||||||
|
// as the slave end of a pseudo terminal. Although both point to the same "file", bat should
|
||||||
|
// not exit, because in this case it is safe to read and write to the same fd, which is why
|
||||||
|
// this test exists.
|
||||||
|
let OpenptyResult { master, slave } = openpty(None, None).expect("Couldn't open pty.");
|
||||||
|
let mut master = unsafe { File::from_raw_fd(master) };
|
||||||
|
let stdin = unsafe { Stdio::from_raw_fd(slave) };
|
||||||
|
let stdout = unsafe { Stdio::from_raw_fd(slave) };
|
||||||
|
|
||||||
|
let mut child = bat_raw_command()
|
||||||
|
.stdin(stdin)
|
||||||
|
.stdout(stdout)
|
||||||
|
.spawn()
|
||||||
|
.expect("Failed to start.");
|
||||||
|
|
||||||
|
// Some time for the child process to start and to make sure, that we can poll the exit status.
|
||||||
|
// Although this waiting period is not necessary, it is best to keep it in and be absolutely
|
||||||
|
// sure, that the try_wait does not error later.
|
||||||
|
thread::sleep(SAFE_CHILD_PROCESS_CREATION_TIME);
|
||||||
|
|
||||||
|
// The child process should be running and waiting for input,
|
||||||
|
// therefore no exit status should be available.
|
||||||
|
let exit_status = child
|
||||||
|
.try_wait()
|
||||||
|
.expect("Error polling exit status, this should never happen.");
|
||||||
|
assert!(exit_status.is_none());
|
||||||
|
|
||||||
|
// Write Ctrl-D (end of transmission) to the pty.
|
||||||
|
master
|
||||||
|
.write_all(&[0x04])
|
||||||
|
.expect("Couldn't write EOT character to master end.");
|
||||||
|
|
||||||
|
let exit_status = child
|
||||||
|
.wait_timeout(CHILD_WAIT_TIMEOUT)
|
||||||
|
.expect("Error polling exit status, this should never happen.")
|
||||||
|
.expect("Exit status not set, but the child should have exited already.");
|
||||||
|
|
||||||
|
assert!(exit_status.success());
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn tabs_numbers() {
|
fn tabs_numbers() {
|
||||||
bat()
|
bat()
|
||||||
|
Loading…
Reference in New Issue
Block a user