52 lines
2.1 KiB
Rust
52 lines
2.1 KiB
Rust
use insta::assert_snapshot;
|
|
use std::path::PathBuf;
|
|
|
|
use crate::panes::PositionAndSize;
|
|
use crate::tests::fakes::FakeInputOutput;
|
|
use crate::tests::utils::commands::{COMMAND_TOGGLE, QUIT};
|
|
use crate::tests::utils::get_output_frame_snapshots;
|
|
use crate::{start, CliArgs};
|
|
|
|
fn get_fake_os_input(fake_win_size: &PositionAndSize) -> FakeInputOutput {
|
|
FakeInputOutput::new(fake_win_size.clone())
|
|
}
|
|
|
|
#[test]
|
|
pub fn accepts_basic_layout() {
|
|
let fake_win_size = PositionAndSize {
|
|
columns: 121,
|
|
rows: 20,
|
|
x: 0,
|
|
y: 0,
|
|
};
|
|
let mut fake_input_output = get_fake_os_input(&fake_win_size);
|
|
fake_input_output.add_terminal_input(&[&COMMAND_TOGGLE, &COMMAND_TOGGLE, &QUIT]);
|
|
let mut opts = CliArgs::default();
|
|
opts.layout = Some(PathBuf::from(
|
|
"src/tests/fixtures/layouts/three-panes-with-nesting.yaml",
|
|
));
|
|
|
|
start(Box::new(fake_input_output.clone()), opts);
|
|
let output_frames = fake_input_output
|
|
.stdout_writer
|
|
.output_frames
|
|
.lock()
|
|
.unwrap();
|
|
let snapshots = get_output_frame_snapshots(&output_frames, &fake_win_size);
|
|
|
|
let snapshot_count = snapshots.len();
|
|
let first_snapshot = snapshots.get(0).unwrap();
|
|
let next_to_last_snapshot = snapshots.get(snapshot_count - 2).unwrap();
|
|
let last_snapshot = snapshots.last().unwrap();
|
|
// here we only test the first, next to last and last snapshot because there's a race condition
|
|
// with the other snapshots. Namely all the terminals are created asynchronously and read in an
|
|
// async task, so we have no way to guarantee the order in which their bytes will be read, and
|
|
// it doesn't really matter in this context. We just want to see that the layout is initially
|
|
// created properly and that in the end it's populated properly with its content
|
|
//
|
|
// we read the next to last as well as the last, because the last includes the "Bye from
|
|
// Mosaic" message, and we also want to make sure things are fine before that
|
|
assert_snapshot!(first_snapshot);
|
|
assert_snapshot!(next_to_last_snapshot);
|
|
assert_snapshot!(last_snapshot);
|
|
}
|