helix-mirror/helix-term/tests/integration/write.rs

147 lines
3.7 KiB
Rust
Raw Normal View History

use std::{
io::{Read, Write},
2022-05-01 04:47:53 +04:00
ops::RangeInclusive,
2022-05-01 04:44:54 +04:00
time::Duration,
};
2022-05-01 04:44:54 +04:00
use helix_core::diagnostic::Severity;
use helix_term::application::Application;
2022-05-01 04:44:54 +04:00
use helix_view::doc;
use super::*;
#[tokio::test]
async fn test_write() -> anyhow::Result<()> {
let mut file = tempfile::NamedTempFile::new().unwrap();
test_key_sequence(
&mut Application::new(
Args {
files: vec![(file.path().to_path_buf(), Position::default())],
..Default::default()
},
Config::default(),
)?,
2022-05-01 04:47:53 +04:00
Some("ii can eat glass, it will not hurt me<ret><esc>:w<ret>"),
None,
2022-05-01 04:44:54 +04:00
Some(Duration::from_millis(1000)),
)
.await?;
file.as_file_mut().flush()?;
file.as_file_mut().sync_all()?;
let mut file_content = String::new();
file.as_file_mut().read_to_string(&mut file_content)?;
assert_eq!("i can eat glass, it will not hurt me\n", file_content);
Ok(())
}
2022-05-01 04:47:53 +04:00
#[tokio::test]
async fn test_write_concurrent() -> anyhow::Result<()> {
let mut file = tempfile::NamedTempFile::new().unwrap();
let mut command = String::new();
const RANGE: RangeInclusive<i32> = 1..=5000;
for i in RANGE {
let cmd = format!("%c{}<esc>:w<ret>", i);
command.push_str(&cmd);
}
test_key_sequence(
&mut Application::new(
Args {
files: vec![(file.path().to_path_buf(), Position::default())],
..Default::default()
},
Config::default(),
)?,
Some(&command),
None,
Some(Duration::from_millis(10000)),
)
.await?;
file.as_file_mut().flush()?;
file.as_file_mut().sync_all()?;
let mut file_content = String::new();
file.as_file_mut().read_to_string(&mut file_content)?;
assert_eq!(RANGE.end().to_string(), file_content);
Ok(())
}
#[tokio::test]
2022-05-01 04:44:54 +04:00
async fn test_write_fail_mod_flag() -> anyhow::Result<()> {
test_key_sequences(
&mut Application::new(
Args {
2022-05-01 04:44:54 +04:00
files: vec![(PathBuf::from("/foo"), Position::default())],
..Default::default()
},
Config::default(),
)?,
2022-05-01 04:44:54 +04:00
vec![
(
2022-05-01 04:47:53 +04:00
None,
2022-05-01 04:44:54 +04:00
Some(&|app| {
let doc = doc!(app.editor);
assert!(!doc.is_modified());
}),
),
(
2022-05-01 04:47:53 +04:00
Some("ihello<esc>"),
2022-05-01 04:44:54 +04:00
Some(&|app| {
let doc = doc!(app.editor);
assert!(doc.is_modified());
}),
),
(
2022-05-01 04:47:53 +04:00
Some(":w<ret>"),
2022-05-01 04:44:54 +04:00
Some(&|app| {
assert_eq!(&Severity::Error, app.editor.get_status().unwrap().1);
let doc = doc!(app.editor);
assert!(doc.is_modified());
}),
),
],
None,
)
.await?;
2022-05-01 04:44:54 +04:00
Ok(())
}
2022-05-01 04:44:54 +04:00
#[tokio::test]
#[ignore]
async fn test_write_fail_new_path() -> anyhow::Result<()> {
test_key_sequences(
&mut Application::new(Args::default(), Config::default())?,
vec![
(
2022-05-01 04:47:53 +04:00
None,
2022-05-01 04:44:54 +04:00
Some(&|app| {
let doc = doc!(app.editor);
assert_eq!(None, app.editor.get_status());
assert_eq!(None, doc.path());
}),
),
(
2022-05-01 04:47:53 +04:00
Some(":w /foo<ret>"),
2022-05-01 04:44:54 +04:00
Some(&|app| {
let doc = doc!(app.editor);
assert_eq!(&Severity::Error, app.editor.get_status().unwrap().1);
assert_eq!(None, doc.path());
}),
),
],
Some(Duration::from_millis(1000)),
)
.await?;
Ok(())
}