From 00a70b8e4b995443fb6ebca2984cf10d65551908 Mon Sep 17 00:00:00 2001 From: Polochon_street Date: Fri, 20 Sep 2024 15:52:04 +0200 Subject: [PATCH] Add some integration tests --- .github/workflows/rust.yml | 6 +- Cargo.lock | 232 ++++++++++++++++++++++++++++++++++++- Cargo.toml | 11 +- tests/cli.rs | 92 +++++++++++++++ 4 files changed, 335 insertions(+), 6 deletions(-) create mode 100644 tests/cli.rs diff --git a/.github/workflows/rust.yml b/.github/workflows/rust.yml index e92d268..f300d07 100644 --- a/.github/workflows/rust.yml +++ b/.github/workflows/rust.yml @@ -19,12 +19,12 @@ jobs: with: submodules: recursive - name: Packages - run: sudo apt-get update && sudo apt-get install build-essential yasm libavutil-dev libavcodec-dev libavformat-dev libavfilter-dev libavfilter-dev libavdevice-dev libswresample-dev libfftw3-dev ffmpeg + run: sudo apt-get update && sudo apt-get install build-essential yasm libavutil-dev libavcodec-dev libavformat-dev libavfilter-dev libavfilter-dev libavdevice-dev libswresample-dev libfftw3-dev ffmpeg mpd - name: Check format run: cargo fmt -- --check - name: Lint - run: cargo clippy --examples -- -D warnings + run: cargo clippy --features=integration-tests --examples -- -D warnings - name: Build run: cargo build --verbose - name: Run tests - run: cargo test --verbose + run: cargo test --verbose --features=integration-tests diff --git a/Cargo.lock b/Cargo.lock index e1f7ffa..fa91f56 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -44,12 +44,49 @@ dependencies = [ "winapi", ] +[[package]] +name = "anstyle" +version = "1.0.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1bec1de6f59aedf83baf9ff929c98f2ad654b97c9510f4e70cf6f661d49fd5b1" + [[package]] name = "anyhow" version = "1.0.86" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "b3d1d046238990b9cf5bcde22a3fb3584ee5cf65fb2765f454ed428c7a0063da" +[[package]] +name = "assert_cmd" +version = "2.0.16" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc1835b7f27878de8525dc71410b5a31cdcc5f230aed5ba5df968e09c201b23d" +dependencies = [ + "anstyle", + "bstr", + "doc-comment", + "libc", + "predicates", + "predicates-core", + "predicates-tree", + "wait-timeout", +] + +[[package]] +name = "assert_fs" +version = "1.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7efdb1fdb47602827a342857666feb372712cbc64b414172bd6b167a02927674" +dependencies = [ + "anstyle", + "doc-comment", + "globwalk", + "predicates", + "predicates-core", + "predicates-tree", + "tempfile", +] + [[package]] name = "atty" version = "0.2.14" @@ -102,8 +139,6 @@ checksum = "b048fb63fd8b5923fc5aa7b340d8e156aec7ec02f0c78fa8a6ddc2613f6f71de" [[package]] name = "bliss-audio" version = "0.9.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "fa9fdef7455f9ba48e51aac3eb8ab8863404c333a968710e4750a003a12c7d49" dependencies = [ "adler32", "anyhow", @@ -152,6 +187,8 @@ name = "blissify" version = "0.5.1" dependencies = [ "anyhow", + "assert_cmd", + "assert_fs", "bliss-audio", "clap", "dirs 3.0.2", @@ -161,12 +198,24 @@ dependencies = [ "log", "mpd", "noisy_float", + "predicates", "pretty_assertions", "serde", "tempdir", "termion", ] +[[package]] +name = "bstr" +version = "1.10.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "40723b8fb387abc38f4f4a37c09073622e41dd12327033091ef8950659e6dc0c" +dependencies = [ + "memchr", + "regex-automata", + "serde", +] + [[package]] name = "bufstream" version = "0.1.4" @@ -275,6 +324,12 @@ version = "0.1.13" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "56254986775e3233ffa9c4d7d3faaf6d36a2c09d30b20687e9f88bc8bafc16c8" +[[package]] +name = "difflib" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6184e33543162437515c2e2b48714794e37845ec9851711914eec9d308f6ebe8" + [[package]] name = "dirs" version = "3.0.2" @@ -316,6 +371,12 @@ dependencies = [ "windows-sys 0.48.0", ] +[[package]] +name = "doc-comment" +version = "0.3.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "fea41bba32d969b513997752735605054bc0dfa92b4c56bf1189f2e174be7a10" + [[package]] name = "either" version = "1.13.0" @@ -341,6 +402,16 @@ dependencies = [ "termcolor", ] +[[package]] +name = "errno" +version = "0.3.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "534c5cf6194dfab3db3242765c03bbe257cf92f22b38f6bc0c58d59108a820ba" +dependencies = [ + "libc", + "windows-sys 0.52.0", +] + [[package]] name = "extended-isolation-forest" version = "0.2.3" @@ -365,6 +436,12 @@ version = "0.1.9" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "7360491ce676a36bf9bb3c56c1aa791658183a54d2744120f27285738d90465a" +[[package]] +name = "fastrand" +version = "2.1.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e8c02a5121d4ea3eb16a80748c74f5549a5665e4c21333c6098f283870fbdea6" + [[package]] name = "ffmpeg-next" version = "7.0.4" @@ -390,6 +467,15 @@ dependencies = [ "vcpkg", ] +[[package]] +name = "float-cmp" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "98de4bbd547a563b716d8dfa9aad1cb19bfab00f4fa09a6a4ed21dbcf44ce9c4" +dependencies = [ + "num-traits", +] + [[package]] name = "fuchsia-cprng" version = "0.1.1" @@ -413,6 +499,30 @@ version = "0.3.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "d2fabcfbdc87f4758337ca535fb41a6d701b65693ce38287d856d1674551ec9b" +[[package]] +name = "globset" +version = "0.4.15" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "15f1ce686646e7f1e19bf7d5533fe443a45dbfb990e00629110797578b42fb19" +dependencies = [ + "aho-corasick", + "bstr", + "log", + "regex-automata", + "regex-syntax", +] + +[[package]] +name = "globwalk" +version = "0.9.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0bf760ebf69878d9fd8f110c89703d90ce35095324d1f1edcb595c63945ee757" +dependencies = [ + "bitflags 2.6.0", + "ignore", + "walkdir", +] + [[package]] name = "hashbrown" version = "0.12.3" @@ -465,6 +575,22 @@ version = "2.1.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "9a3a5bfb195931eeb336b2a7b4d761daec841b97f947d34394601737a7bba5e4" +[[package]] +name = "ignore" +version = "0.4.23" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6d89fd380afde86567dfba715db065673989d6253f42b88179abd3eae47bda4b" +dependencies = [ + "crossbeam-deque", + "globset", + "log", + "memchr", + "regex-automata", + "same-file", + "walkdir", + "winapi-util", +] + [[package]] name = "indexmap" version = "1.9.3" @@ -596,6 +722,12 @@ dependencies = [ "vcpkg", ] +[[package]] +name = "linux-raw-sys" +version = "0.4.14" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "78b3ae25bc7c8c38cec158d1f2757ee79e9b3740fbc7ccf0e59e4b08d793fa89" + [[package]] name = "log" version = "0.4.22" @@ -682,6 +814,12 @@ dependencies = [ "minimal-lexical", ] +[[package]] +name = "normalize-line-endings" +version = "0.3.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "61807f77802ff30975e01f4f071c8ba10c022052f98b3294119f3e615d13e5be" + [[package]] name = "num-complex" version = "0.4.6" @@ -765,6 +903,36 @@ dependencies = [ "zerocopy", ] +[[package]] +name = "predicates" +version = "3.1.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7e9086cc7640c29a356d1a29fd134380bee9d8f79a17410aa76e7ad295f42c97" +dependencies = [ + "anstyle", + "difflib", + "float-cmp", + "normalize-line-endings", + "predicates-core", + "regex", +] + +[[package]] +name = "predicates-core" +version = "1.0.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ae8177bee8e75d6846599c6b9ff679ed51e882816914eec639944d7c9aa11931" + +[[package]] +name = "predicates-tree" +version = "1.0.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "41b740d195ed3166cd147c8047ec98db0e22ec019eb8eeb76d343b795304fb13" +dependencies = [ + "predicates-core", + "termtree", +] + [[package]] name = "pretty_assertions" version = "1.4.0" @@ -1016,6 +1184,19 @@ dependencies = [ "version_check", ] +[[package]] +name = "rustix" +version = "0.38.34" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "70dc5ec042f7a43c4a73241207cecc9873a06d45debb38b329f8541d85c2730f" +dependencies = [ + "bitflags 2.6.0", + "errno", + "libc", + "linux-raw-sys", + "windows-sys 0.52.0", +] + [[package]] name = "rustversion" version = "1.0.17" @@ -1028,6 +1209,15 @@ version = "1.0.18" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f3cb5ba0dc43242ce17de99c180e96db90b235b8a9fdc9543c96d2209116bd9f" +[[package]] +name = "same-file" +version = "1.0.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "93fc1dc3aaa9bfed95e02e6eadabb4baf7e3078b0bd1b4d7b6b0b68378900502" +dependencies = [ + "winapi-util", +] + [[package]] name = "serde" version = "1.0.206" @@ -1146,6 +1336,19 @@ dependencies = [ "remove_dir_all", ] +[[package]] +name = "tempfile" +version = "3.12.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "04cbcdd0c794ebb0d4cf35e88edd2f7d2c4c3e9a5a6dab322839b321c6a87a64" +dependencies = [ + "cfg-if", + "fastrand", + "once_cell", + "rustix", + "windows-sys 0.59.0", +] + [[package]] name = "term_size" version = "0.3.2" @@ -1177,6 +1380,12 @@ dependencies = [ "redox_termios", ] +[[package]] +name = "termtree" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3369f5ac52d5eb6ab48c6b4ffdc8efbcad6b89c765749064ba298f2c68a16a76" + [[package]] name = "textwrap" version = "0.11.0" @@ -1253,6 +1462,25 @@ version = "1.0.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "6a02e4885ed3bc0f2de90ea6dd45ebcbb66dacffe03547fadbb0eeae2770887d" +[[package]] +name = "wait-timeout" +version = "0.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9f200f5b12eb75f8c1ed65abd4b2db8a6e1b138a20de009dacee265a2498f3f6" +dependencies = [ + "libc", +] + +[[package]] +name = "walkdir" +version = "2.5.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "29790946404f91d9c5d06f9874efddea1dc06c5efe94541a7d6863108e3a5e4b" +dependencies = [ + "same-file", + "winapi-util", +] + [[package]] name = "wasi" version = "0.11.0+wasi-snapshot-preview1" diff --git a/Cargo.toml b/Cargo.toml index 5c7b9e3..7db97d8 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -15,9 +15,13 @@ readme = "README.md" default = ["bliss-audio/library"] # Build for raspberry pis rpi = ["bliss-audio/rpi"] +# Make `cargo test` also run the integration tests. You need to have +# MPD installed for it to work, and it will launch its own instance of +# MPD. +integration-tests = ["bliss-audio/integration-tests"] [dependencies] -bliss-audio = "0.9.1" +bliss-audio = {git = "https://github.com/Polochon-street/bliss-rs/", branch = "add-integrations-test"} mpd = "0.1.0" dirs = "3.0.1" tempdir = "0.3.7" @@ -31,3 +35,8 @@ termion = "1.5.6" serde = "1.0" pretty_assertions = "1.2.1" extended-isolation-forest = { version = "0.2.3", default-features = false } + +[dev-dependencies] +assert_cmd = "2.0.14" +predicates = "3.1.0" +assert_fs = "1.1.1" diff --git a/tests/cli.rs b/tests/cli.rs new file mode 100644 index 0000000..718ff51 --- /dev/null +++ b/tests/cli.rs @@ -0,0 +1,92 @@ +// TODO before publishing: gate it behind the feature +mod tests { + use assert_cmd::prelude::*; + use assert_fs::prelude::*; + use predicates::prelude::*; + use std::env; + use std::net::TcpStream; + use std::process::{Child, Command, Stdio}; + use std::{thread, time}; + + static MPD_CONF: &str = r#" + music_directory "MUSIC_DIRECTORY" + port "PORT" + db_file "DATABASE_FILE" + audio_output { + type "null" + name "dummy" + } + "#; + + struct TestSettings { + mpd_conf_file: assert_fs::NamedTempFile, + mpd_port: String, + handle: Child, + } + + fn start_mpd() -> Result> { + let mut data_directory = env::current_dir()?; + data_directory.push("./data"); + let mpd_conf_file = assert_fs::NamedTempFile::new("mpd.conf")?; + let port: String = format!("{}", 7777); + let mpd_conf = MPD_CONF + .replace("MUSIC_DIRECTORY", &data_directory.to_string_lossy()) + .replace( + "DATABASE_FILE", + &data_directory.as_path().join("database").to_string_lossy(), + ) + .replace("PORT", &port); + mpd_conf_file.write_str(&mpd_conf)?; + let handle = Command::new("mpd") + .arg(mpd_conf_file.to_owned().to_str().unwrap()) + .arg("--no-daemon") + .stderr(Stdio::null()) + .spawn()?; + + Ok(TestSettings { + mpd_conf_file, + mpd_port: port, + handle, + }) + } + + #[test] + // TODO verify that config has been written where it should, + // and that the db file exists. + fn test_init() -> Result<(), Box> { + let mut data_directory = env::current_dir()?; + data_directory.push("./data"); + let test_settings = start_mpd()?; + for i in 0..10 { + match TcpStream::connect(format!("127.0.0.1:{}", test_settings.mpd_port)) { + Ok(_) => break, + Err(_) => thread::sleep(time::Duration::from_millis(500)), + }; + if i == 9 { + panic!( + "Could not start MPD for testing, port {} still closed", + test_settings.mpd_port + ); + } + } + + let mut cmd = Command::cargo_bin("blissify")?; + cmd.arg("init") + .arg(data_directory) + .env("MPD_PORT", test_settings.mpd_port); + cmd.assert().success(); + Ok(()) + } + + #[test] + fn test_list_db_fail() -> Result<(), Box> { + let mut cmd = Command::cargo_bin("blissify")?; + + cmd.arg("-c").arg("/tmp/nonexisting").arg("list-db"); + cmd.assert() + .failure() + .stderr(predicate::str::contains("No such file or directory")); + + Ok(()) + } +}