* Fix for issue #52 * Added missing fixtures. * Added missing validation. * Moved layout creation and validation to the Layout struct. * Ran cargo fmt. * Added creation of tmp folder if needed. * Code review edit. * Code review edit. * Fancied code up. * PR request change. * PR code review. * Merge from upstream/main. * Merge from upstream/main.
92 lines
3.2 KiB
Rust
92 lines
3.2 KiB
Rust
use ::insta::assert_snapshot;
|
|
use std::path::PathBuf;
|
|
|
|
use crate::terminal_pane::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, Opt};
|
|
|
|
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 = Opt::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);
|
|
}
|
|
|
|
#[test]
|
|
#[should_panic(expected = "The total percent for each part should equal 100.")]
|
|
pub fn should_throw_for_more_than_100_percent_total() {
|
|
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(&[QUIT]);
|
|
|
|
let mut opts = Opt::default();
|
|
opts.layout = Some(PathBuf::from(
|
|
"src/tests/fixtures/layouts/parts-total-more-than-100-percent.yaml",
|
|
));
|
|
|
|
start(Box::new(fake_input_output.clone()), opts);
|
|
}
|
|
|
|
#[test]
|
|
#[should_panic(expected = "The total percent for each part should equal 100.")]
|
|
pub fn should_throw_for_less_than_100_percent_total() {
|
|
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(&[QUIT]);
|
|
|
|
let mut opts = Opt::default();
|
|
opts.layout = Some(PathBuf::from(
|
|
"src/tests/fixtures/layouts/parts-total-less-than-100-percent.yaml",
|
|
));
|
|
|
|
start(Box::new(fake_input_output.clone()), opts);
|
|
}
|