From 63243851bf73469dae2a8826441cdf50b10fabc3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Marin=20Ver=C5=A1i=C4=87?= Date: Tue, 29 Oct 2024 16:11:42 +0100 Subject: [PATCH] chore: move tests to separate repo MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Marin Veršić --- .gitignore | 1 - Cargo.lock | 249 +++--------------- Cargo.toml | 51 +++- crates/iroha/Cargo.toml | 13 +- crates/iroha/tests/status_response.rs | 54 ---- scripts/build_wasm.sh | 2 +- {crates/iroha/tests => tests}/asset.rs | 0 .../tests => tests}/asset_propagation.rs | 0 {crates/iroha/tests => tests}/events/data.rs | 8 +- {crates/iroha/tests => tests}/events/mod.rs | 0 .../tests => tests}/events/notification.rs | 0 .../iroha/tests => tests}/events/pipeline.rs | 0 .../extra_functional/connected_peers.rs | 10 +- .../extra_functional/genesis.rs | 0 .../tests => tests}/extra_functional/mod.rs | 0 .../multiple_blocks_created.rs | 0 .../extra_functional/normal.rs | 0 .../extra_functional/offline_peers.rs | 0 .../extra_functional/restart_peer.rs | 0 .../extra_functional/unregister_peer.rs | 0 {crates/iroha/tests => tests}/mod.rs | 0 {crates/iroha/tests => tests}/multisig.rs | 20 +- {crates/iroha/tests => tests}/non_mintable.rs | 0 {crates/iroha/tests => tests}/pagination.rs | 0 {crates/iroha/tests => tests}/permissions.rs | 0 .../iroha/tests => tests}/queries/account.rs | 0 .../iroha/tests => tests}/queries/asset.rs | 0 {crates/iroha/tests => tests}/queries/mod.rs | 4 +- .../tests => tests}/queries/query_errors.rs | 0 {crates/iroha/tests => tests}/queries/role.rs | 0 .../tests => tests}/queries/smart_contract.rs | 0 {crates/iroha/tests => tests}/roles.rs | 0 .../iroha/tests => tests}/set_parameter.rs | 0 {crates/iroha/tests => tests}/sorting.rs | 0 tests/status_response.rs | 54 ++++ .../iroha/tests => tests}/transfer_asset.rs | 0 .../iroha/tests => tests}/transfer_domain.rs | 0 .../triggers/by_call_trigger.rs | 0 .../tests => tests}/triggers/data_trigger.rs | 0 .../tests => tests}/triggers/event_trigger.rs | 0 {crates/iroha/tests => tests}/triggers/mod.rs | 0 .../iroha/tests => tests}/triggers/orphans.rs | 0 .../tests => tests}/triggers/time_trigger.rs | 0 .../triggers/trigger_rollback.rs | 0 {crates/iroha/tests => tests}/tx_chain_id.rs | 1 - {crates/iroha/tests => tests}/tx_history.rs | 0 {crates/iroha/tests => tests}/tx_rollback.rs | 0 {crates/iroha/tests => tests}/upgrade.rs | 0 48 files changed, 145 insertions(+), 322 deletions(-) delete mode 100644 crates/iroha/tests/status_response.rs rename {crates/iroha/tests => tests}/asset.rs (100%) rename {crates/iroha/tests => tests}/asset_propagation.rs (100%) rename {crates/iroha/tests => tests}/events/data.rs (97%) rename {crates/iroha/tests => tests}/events/mod.rs (100%) rename {crates/iroha/tests => tests}/events/notification.rs (100%) rename {crates/iroha/tests => tests}/events/pipeline.rs (100%) rename {crates/iroha/tests => tests}/extra_functional/connected_peers.rs (93%) rename {crates/iroha/tests => tests}/extra_functional/genesis.rs (100%) rename {crates/iroha/tests => tests}/extra_functional/mod.rs (100%) rename {crates/iroha/tests => tests}/extra_functional/multiple_blocks_created.rs (100%) rename {crates/iroha/tests => tests}/extra_functional/normal.rs (100%) rename {crates/iroha/tests => tests}/extra_functional/offline_peers.rs (100%) rename {crates/iroha/tests => tests}/extra_functional/restart_peer.rs (100%) rename {crates/iroha/tests => tests}/extra_functional/unregister_peer.rs (100%) rename {crates/iroha/tests => tests}/mod.rs (100%) rename {crates/iroha/tests => tests}/multisig.rs (96%) rename {crates/iroha/tests => tests}/non_mintable.rs (100%) rename {crates/iroha/tests => tests}/pagination.rs (100%) rename {crates/iroha/tests => tests}/permissions.rs (100%) rename {crates/iroha/tests => tests}/queries/account.rs (100%) rename {crates/iroha/tests => tests}/queries/asset.rs (100%) rename {crates/iroha/tests => tests}/queries/mod.rs (94%) rename {crates/iroha/tests => tests}/queries/query_errors.rs (100%) rename {crates/iroha/tests => tests}/queries/role.rs (100%) rename {crates/iroha/tests => tests}/queries/smart_contract.rs (100%) rename {crates/iroha/tests => tests}/roles.rs (100%) rename {crates/iroha/tests => tests}/set_parameter.rs (100%) rename {crates/iroha/tests => tests}/sorting.rs (100%) create mode 100644 tests/status_response.rs rename {crates/iroha/tests => tests}/transfer_asset.rs (100%) rename {crates/iroha/tests => tests}/transfer_domain.rs (100%) rename {crates/iroha/tests => tests}/triggers/by_call_trigger.rs (100%) rename {crates/iroha/tests => tests}/triggers/data_trigger.rs (100%) rename {crates/iroha/tests => tests}/triggers/event_trigger.rs (100%) rename {crates/iroha/tests => tests}/triggers/mod.rs (100%) rename {crates/iroha/tests => tests}/triggers/orphans.rs (100%) rename {crates/iroha/tests => tests}/triggers/time_trigger.rs (100%) rename {crates/iroha/tests => tests}/triggers/trigger_rollback.rs (100%) rename {crates/iroha/tests => tests}/tx_chain_id.rs (98%) rename {crates/iroha/tests => tests}/tx_history.rs (100%) rename {crates/iroha/tests => tests}/tx_rollback.rs (100%) rename {crates/iroha/tests => tests}/upgrade.rs (100%) diff --git a/.gitignore b/.gitignore index 70d5f05109b..f908d42e3b6 100644 --- a/.gitignore +++ b/.gitignore @@ -46,7 +46,6 @@ result *.deb \#* /cargo-timing*.html -/test/ /iroha-java/ /lcov.info test_docker diff --git a/Cargo.lock b/Cargo.lock index bd767492c67..dc85920adc4 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -350,12 +350,6 @@ dependencies = [ "syn 2.0.79", ] -[[package]] -name = "atomic-waker" -version = "1.1.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1505bd5d3d116872e7271a6d4e16d81d0c8570876c8de68093a09ac269d8aac0" - [[package]] name = "attohttpc" version = "0.28.0" @@ -365,7 +359,7 @@ dependencies = [ "http 1.1.0", "log", "native-tls", - "rustls 0.22.4", + "rustls", "rustls-native-certs", "url", "webpki-roots", @@ -2447,25 +2441,6 @@ dependencies = [ "tracing", ] -[[package]] -name = "h2" -version = "0.4.6" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "524e8ac6999421f49a846c2d4411f337e53497d8ec55d67753beffa43c5d9205" -dependencies = [ - "atomic-waker", - "bytes", - "fnv", - "futures-core", - "futures-sink", - "http 1.1.0", - "indexmap 2.6.0", - "slab", - "tokio", - "tokio-util", - "tracing", -] - [[package]] name = "half" version = "2.4.1" @@ -2671,7 +2646,7 @@ dependencies = [ "futures-channel", "futures-core", "futures-util", - "h2 0.3.26", + "h2", "http 0.2.12", "http-body 0.4.6", "httparse", @@ -2694,7 +2669,6 @@ dependencies = [ "bytes", "futures-channel", "futures-util", - "h2 0.4.6", "http 1.1.0", "http-body 1.0.1", "httparse", @@ -2703,24 +2677,6 @@ dependencies = [ "pin-project-lite", "smallvec", "tokio", - "want", -] - -[[package]] -name = "hyper-rustls" -version = "0.27.3" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "08afdbb5c31130e3034af566421053ab03787c640246a446327f550d11bcb333" -dependencies = [ - "futures-util", - "http 1.1.0", - "hyper 1.4.1", - "hyper-util", - "rustls 0.23.13", - "rustls-pki-types", - "tokio", - "tokio-rustls 0.26.0", - "tower-service", ] [[package]] @@ -2735,22 +2691,6 @@ dependencies = [ "tokio-io-timeout", ] -[[package]] -name = "hyper-tls" -version = "0.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "70206fc6890eaca9fde8a0bf71caa2ddfc9fe045ac9e5c70df101a7dbde866e0" -dependencies = [ - "bytes", - "http-body-util", - "hyper 1.4.1", - "hyper-util", - "native-tls", - "tokio", - "tokio-native-tls", - "tower-service", -] - [[package]] name = "hyper-util" version = "0.1.9" @@ -2758,16 +2698,13 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "41296eb09f183ac68eec06e03cdbea2e759633d4067b2f6552fc2e009bcad08b" dependencies = [ "bytes", - "futures-channel", "futures-util", "http 1.1.0", "http-body 1.0.1", "hyper 1.4.1", "pin-project-lite", - "socket2", "tokio", "tower-service", - "tracing", ] [[package]] @@ -2894,47 +2831,33 @@ dependencies = [ "cfg-if", ] -[[package]] -name = "ipnet" -version = "2.10.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ddc24109865250148c2e0f3d25d4f0f479571723792d3802153c60922a4fb708" - [[package]] name = "iroha" version = "2.0.0-rc.1.0" dependencies = [ - "assert_matches", "assertables", "attohttpc", "base64 0.22.1", - "color-eyre", "derive_more", "displaydoc", "error-stack", - "executor_custom_data_model", "eyre", "futures-util", - "hex", "http 1.1.0", "iroha_config", "iroha_config_base", "iroha_crypto", "iroha_data_model", - "iroha_executor_data_model", - "iroha_genesis", "iroha_logger", "iroha_multisig_data_model", "iroha_primitives", "iroha_telemetry", - "iroha_test_network", "iroha_test_samples", "iroha_torii_const", "iroha_version", "nonzero_ext", "parity-scale-codec", "rand", - "reqwest", "serde", "serde_json", "serde_with", @@ -2943,7 +2866,6 @@ dependencies = [ "tokio", "tokio-tungstenite 0.21.0", "toml", - "trybuild", "tungstenite 0.21.0", "url", ] @@ -3627,6 +3549,30 @@ dependencies = [ "serde", ] +[[package]] +name = "iroha_tests" +version = "2.0.0-rc.1.0" +dependencies = [ + "assert_matches", + "assertables", + "color-eyre", + "executor_custom_data_model", + "eyre", + "futures-util", + "hex", + "iroha", + "iroha_executor_data_model", + "iroha_primitives", + "iroha_test_network", + "iroha_test_samples", + "nonzero_ext", + "rand", + "serde_json", + "tempfile", + "tokio", + "trybuild", +] + [[package]] name = "iroha_torii" version = "2.0.0-rc.1.0" @@ -5035,49 +4981,6 @@ version = "0.8.5" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "2b15c43186be67a4fd63bee50d0303afffcef381492ebe2c5d87f324e1b8815c" -[[package]] -name = "reqwest" -version = "0.12.8" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f713147fbe92361e52392c73b8c9e48c04c6625bce969ef54dc901e58e042a7b" -dependencies = [ - "base64 0.22.1", - "bytes", - "encoding_rs", - "futures-core", - "futures-util", - "h2 0.4.6", - "http 1.1.0", - "http-body 1.0.1", - "http-body-util", - "hyper 1.4.1", - "hyper-rustls", - "hyper-tls", - "hyper-util", - "ipnet", - "js-sys", - "log", - "mime", - "native-tls", - "once_cell", - "percent-encoding", - "pin-project-lite", - "rustls-pemfile", - "serde", - "serde_json", - "serde_urlencoded", - "sync_wrapper 1.0.1", - "system-configuration", - "tokio", - "tokio-native-tls", - "tower-service", - "url", - "wasm-bindgen", - "wasm-bindgen-futures", - "web-sys", - "windows-registry", -] - [[package]] name = "rfc6979" version = "0.4.0" @@ -5168,19 +5071,6 @@ dependencies = [ "zeroize", ] -[[package]] -name = "rustls" -version = "0.23.13" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f2dabaac7466917e566adb06783a81ca48944c6898a1b08b9374106dd671f4c8" -dependencies = [ - "once_cell", - "rustls-pki-types", - "rustls-webpki", - "subtle", - "zeroize", -] - [[package]] name = "rustls-native-certs" version = "0.7.3" @@ -5819,30 +5709,6 @@ name = "sync_wrapper" version = "1.0.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "a7065abeca94b6a8a577f9bd45aa0867a2238b74e8eb67cf10d492bc39351394" -dependencies = [ - "futures-core", -] - -[[package]] -name = "system-configuration" -version = "0.6.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c879d448e9d986b661742763247d3693ed13609438cf3d006f51f5368a5ba6b" -dependencies = [ - "bitflags 2.6.0", - "core-foundation", - "system-configuration-sys", -] - -[[package]] -name = "system-configuration-sys" -version = "0.6.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8e1d1b10ced5ca923a1fcb8d03e96b8d3268065d724548c0211415ff6ac6bac4" -dependencies = [ - "core-foundation-sys", - "libc", -] [[package]] name = "tap" @@ -6042,18 +5908,7 @@ version = "0.25.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "775e0c0f0adb3a2f22a00c4745d728b479985fc15ee7ca6a2608388c5569860f" dependencies = [ - "rustls 0.22.4", - "rustls-pki-types", - "tokio", -] - -[[package]] -name = "tokio-rustls" -version = "0.26.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0c7bc40d0e5a97695bb96e27995cd3a08538541b0a846f65bba7a359f36700d4" -dependencies = [ - "rustls 0.23.13", + "rustls", "rustls-pki-types", "tokio", ] @@ -6079,12 +5934,12 @@ dependencies = [ "futures-util", "log", "native-tls", - "rustls 0.22.4", + "rustls", "rustls-native-certs", "rustls-pki-types", "tokio", "tokio-native-tls", - "tokio-rustls 0.25.0", + "tokio-rustls", "tungstenite 0.21.0", "webpki-roots", ] @@ -6161,7 +6016,7 @@ dependencies = [ "axum 0.6.20", "base64 0.21.7", "bytes", - "h2 0.3.26", + "h2", "http 0.2.12", "http-body 0.4.6", "hyper 0.14.30", @@ -6358,7 +6213,7 @@ dependencies = [ "log", "native-tls", "rand", - "rustls 0.22.4", + "rustls", "rustls-native-certs", "rustls-pki-types", "sha1", @@ -6633,18 +6488,6 @@ dependencies = [ "wasm-bindgen-shared", ] -[[package]] -name = "wasm-bindgen-futures" -version = "0.4.43" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "61e9300f63a621e96ed275155c108eb6f843b6a26d053f122ab69724559dc8ed" -dependencies = [ - "cfg-if", - "js-sys", - "wasm-bindgen", - "web-sys", -] - [[package]] name = "wasm-bindgen-macro" version = "0.2.93" @@ -7129,36 +6972,6 @@ dependencies = [ "windows-targets 0.52.6", ] -[[package]] -name = "windows-registry" -version = "0.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e400001bb720a623c1c69032f8e3e4cf09984deec740f007dd2b03ec864804b0" -dependencies = [ - "windows-result", - "windows-strings", - "windows-targets 0.52.6", -] - -[[package]] -name = "windows-result" -version = "0.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1d1043d8214f791817bab27572aaa8af63732e11bf84aa21a45a78d6c317ae0e" -dependencies = [ - "windows-targets 0.52.6", -] - -[[package]] -name = "windows-strings" -version = "0.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4cd9b125c486025df0eabcb585e62173c6c9eddcec5d117d3b6e8c30e2ee4d10" -dependencies = [ - "windows-result", - "windows-targets 0.52.6", -] - [[package]] name = "windows-sys" version = "0.48.0" diff --git a/Cargo.toml b/Cargo.toml index eeb917bca99..b93bc8cb255 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,3 +1,9 @@ +[workspace] +resolver = "2" +members = [ + "crates/*" +] + [workspace.package] edition = "2021" version = "2.0.0-rc.1.0" @@ -196,11 +202,46 @@ clippy.useless_let_if_seq = "warn" clippy.redundant_feature_names = "deny" clippy.wildcard_dependencies = "deny" -[workspace] -resolver = "2" -members = [ - "crates/*" -] +[package] +name = "iroha_tests" + +edition.workspace = true +version.workspace = true +authors.workspace = true + +description.workspace = true +repository.workspace = true +homepage.workspace = true +documentation.workspace = true + +license.workspace = true +keywords.workspace = true +categories.workspace = true + +[lints] +workspace = true + +[dev-dependencies] +iroha = { workspace = true } +iroha_primitives = { workspace = true } +iroha_test_samples = { workspace = true } +iroha_test_network = { workspace = true } + +iroha_executor_data_model = { workspace = true } +executor_custom_data_model = { version = "=2.0.0-rc.1.0", path = "wasm/samples/executor_custom_data_model" } + +tokio = { workspace = true, features = ["rt-multi-thread"] } +nonzero_ext = { workspace = true } +color-eyre = { workspace = true } +tempfile = { workspace = true } +hex = { workspace = true } +assertables = { workspace = true } +serde_json = { workspace = true } +trybuild = { workspace = true } +eyre = { workspace = true } +rand = { workspace = true } +assert_matches = "1.5.0" +futures-util = "0.3.30" [profile.deploy] inherits = "release" diff --git a/crates/iroha/Cargo.toml b/crates/iroha/Cargo.toml index 13ece91a788..afa22e088f0 100644 --- a/crates/iroha/Cargo.toml +++ b/crates/iroha/Cargo.toml @@ -81,17 +81,6 @@ toml = { workspace = true } nonzero_ext = { workspace = true } [dev-dependencies] -iroha_genesis = { workspace = true } iroha_test_samples = { workspace = true } -iroha_test_network = { workspace = true } -iroha_executor_data_model = { workspace = true } -executor_custom_data_model = { version = "=2.0.0-rc.1.0", path = "../../wasm/samples/executor_custom_data_model" } - -tokio = { workspace = true, features = ["rt-multi-thread"] } -reqwest = { version = "0.12.7", features = ["json"] } -color-eyre = { workspace = true } -tempfile = { workspace = true } -hex = { workspace = true } assertables = { workspace = true } -trybuild = { workspace = true } -assert_matches = "1.5.0" +tempfile = { workspace = true } diff --git a/crates/iroha/tests/status_response.rs b/crates/iroha/tests/status_response.rs deleted file mode 100644 index 41e4982cff3..00000000000 --- a/crates/iroha/tests/status_response.rs +++ /dev/null @@ -1,54 +0,0 @@ -use eyre::Result; -use iroha::{client, data_model::prelude::*}; -use iroha_telemetry::metrics::Status; -use iroha_test_network::*; -use tokio::task::spawn_blocking; - -fn status_eq_excluding_uptime_and_queue(lhs: &Status, rhs: &Status) -> bool { - lhs.peers == rhs.peers - && lhs.blocks == rhs.blocks - && lhs.txs_accepted == rhs.txs_accepted - && lhs.txs_rejected == rhs.txs_rejected - && lhs.view_changes == rhs.view_changes -} - -async fn check(client: &client::Client, blocks: u64) -> Result<()> { - let status_json = reqwest::get(client.torii_url.join("/status").unwrap()) - .await? - .json() - .await?; - - let status_scale = { - let client = client.clone(); - spawn_blocking(move || client.get_status()).await?? - }; - - assert!(status_eq_excluding_uptime_and_queue( - &status_json, - &status_scale - )); - assert_eq!(status_json.blocks, blocks); - - Ok(()) -} - -#[tokio::test] -async fn json_and_scale_statuses_equality() -> Result<()> { - let network = NetworkBuilder::new().start().await?; - let client = network.client(); - - check(&client, 1).await?; - - { - let client = client.clone(); - spawn_blocking(move || { - client.submit_blocking(Register::domain(Domain::new("looking_glass".parse()?))) - }) - } - .await??; - network.ensure_blocks(2).await?; - - check(&client, 2).await?; - - Ok(()) -} diff --git a/scripts/build_wasm.sh b/scripts/build_wasm.sh index ef95f6fbfce..e657ab44553 100755 --- a/scripts/build_wasm.sh +++ b/scripts/build_wasm.sh @@ -26,7 +26,7 @@ build() { mkdir -p "$TARGET_DIR/$1" for name in ${NAMES[@]}; do out_file="$TARGET_DIR/$1/$name.wasm" - cargo run --bin iroha_wasm_builder -- build "$CRATES_DIR/$1/$name" --optimize --out-file "$out_file" + cargo run --package iroha_wasm_builder --bin iroha_wasm_builder -- build "$CRATES_DIR/$1/$name" --optimize --out-file "$out_file" done echo "info: WASM $1 build complete" echo "artifacts written to $TARGET_DIR/$1/" diff --git a/crates/iroha/tests/asset.rs b/tests/asset.rs similarity index 100% rename from crates/iroha/tests/asset.rs rename to tests/asset.rs diff --git a/crates/iroha/tests/asset_propagation.rs b/tests/asset_propagation.rs similarity index 100% rename from crates/iroha/tests/asset_propagation.rs rename to tests/asset_propagation.rs diff --git a/crates/iroha/tests/events/data.rs b/tests/events/data.rs similarity index 97% rename from crates/iroha/tests/events/data.rs rename to tests/events/data.rs index cce8763dc57..3cd8f268e7c 100644 --- a/crates/iroha/tests/events/data.rs +++ b/tests/events/data.rs @@ -3,13 +3,12 @@ use std::fmt::Write as _; use assert_matches::assert_matches; use eyre::Result; use futures_util::StreamExt; -use iroha::data_model::{prelude::*, transaction::WasmSmartContract}; +use iroha::data_model::{isi::BuiltInInstruction, prelude::*, transaction::WasmSmartContract}; use iroha_executor_data_model::permission::{ account::CanModifyAccountMetadata, domain::CanModifyDomainMetadata, }; use iroha_test_network::*; use iroha_test_samples::{ALICE_ID, BOB_ID}; -use parity_scale_codec::Encode as _; use tokio::task::spawn_blocking; /// Return string containing exported memory, dummy allocator, and @@ -17,8 +16,9 @@ use tokio::task::spawn_blocking; /// /// Memory is initialized with the given hex encoded string value // NOTE: It's expected that hex value is of even length -#[allow(clippy::integer_division)] pub fn wasm_template(hex_val: &str) -> String { + #![allow(clippy::integer_division)] + format!( r#" ;; Import host function to execute instruction @@ -92,7 +92,7 @@ async fn wasm_execution_should_produce_events() -> Result<()> { #![allow(clippy::integer_division)] let isi_hex: Vec = produce_instructions() .into_iter() - .map(|isi| isi.encode()) + .map(|isi| isi.encode_as_instruction_box()) .map(hex::encode) .collect(); diff --git a/crates/iroha/tests/events/mod.rs b/tests/events/mod.rs similarity index 100% rename from crates/iroha/tests/events/mod.rs rename to tests/events/mod.rs diff --git a/crates/iroha/tests/events/notification.rs b/tests/events/notification.rs similarity index 100% rename from crates/iroha/tests/events/notification.rs rename to tests/events/notification.rs diff --git a/crates/iroha/tests/events/pipeline.rs b/tests/events/pipeline.rs similarity index 100% rename from crates/iroha/tests/events/pipeline.rs rename to tests/events/pipeline.rs diff --git a/crates/iroha/tests/extra_functional/connected_peers.rs b/tests/extra_functional/connected_peers.rs similarity index 93% rename from crates/iroha/tests/extra_functional/connected_peers.rs rename to tests/extra_functional/connected_peers.rs index 7dbab107963..5e4cb6bf52a 100644 --- a/crates/iroha/tests/extra_functional/connected_peers.rs +++ b/tests/extra_functional/connected_peers.rs @@ -7,7 +7,6 @@ use iroha::data_model::{ isi::{Register, Unregister}, peer::Peer, }; -use iroha_config_base::toml::WriteExt; use iroha_test_network::*; use rand::{prelude::IteratorRandom, seq::SliceRandom, thread_rng}; use tokio::{task::spawn_blocking, time::timeout}; @@ -27,14 +26,7 @@ async fn register_new_peer() -> Result<()> { let network = NetworkBuilder::new().with_peers(4).start().await?; let peer = NetworkPeer::generate(); - peer.start( - network - .config() - // only one random peer - .write(["sumeragi", "trusted_peers"], [network.peer().id()]), - None, - ) - .await; + peer.start(network.config(), None).await; let register = Register::peer(Peer::new(peer.id())); let client = network.client(); diff --git a/crates/iroha/tests/extra_functional/genesis.rs b/tests/extra_functional/genesis.rs similarity index 100% rename from crates/iroha/tests/extra_functional/genesis.rs rename to tests/extra_functional/genesis.rs diff --git a/crates/iroha/tests/extra_functional/mod.rs b/tests/extra_functional/mod.rs similarity index 100% rename from crates/iroha/tests/extra_functional/mod.rs rename to tests/extra_functional/mod.rs diff --git a/crates/iroha/tests/extra_functional/multiple_blocks_created.rs b/tests/extra_functional/multiple_blocks_created.rs similarity index 100% rename from crates/iroha/tests/extra_functional/multiple_blocks_created.rs rename to tests/extra_functional/multiple_blocks_created.rs diff --git a/crates/iroha/tests/extra_functional/normal.rs b/tests/extra_functional/normal.rs similarity index 100% rename from crates/iroha/tests/extra_functional/normal.rs rename to tests/extra_functional/normal.rs diff --git a/crates/iroha/tests/extra_functional/offline_peers.rs b/tests/extra_functional/offline_peers.rs similarity index 100% rename from crates/iroha/tests/extra_functional/offline_peers.rs rename to tests/extra_functional/offline_peers.rs diff --git a/crates/iroha/tests/extra_functional/restart_peer.rs b/tests/extra_functional/restart_peer.rs similarity index 100% rename from crates/iroha/tests/extra_functional/restart_peer.rs rename to tests/extra_functional/restart_peer.rs diff --git a/crates/iroha/tests/extra_functional/unregister_peer.rs b/tests/extra_functional/unregister_peer.rs similarity index 100% rename from crates/iroha/tests/extra_functional/unregister_peer.rs rename to tests/extra_functional/unregister_peer.rs diff --git a/crates/iroha/tests/mod.rs b/tests/mod.rs similarity index 100% rename from crates/iroha/tests/mod.rs rename to tests/mod.rs diff --git a/crates/iroha/tests/multisig.rs b/tests/multisig.rs similarity index 96% rename from crates/iroha/tests/multisig.rs rename to tests/multisig.rs index 84c6c453f9a..abb42649b39 100644 --- a/crates/iroha/tests/multisig.rs +++ b/tests/multisig.rs @@ -7,10 +7,12 @@ use eyre::Result; use iroha::{ client::Client, crypto::KeyPair, - data_model::{prelude::*, query::trigger::FindTriggers, Level}, + data_model::{ + events::execute_trigger::ExecuteTriggerEventFilter, prelude::*, + query::trigger::FindTriggers, Level, + }, + multisig_data_model::{MultisigAccountArgs, MultisigTransactionArgs}, }; -use iroha_data_model::events::execute_trigger::ExecuteTriggerEventFilter; -use iroha_multisig_data_model::{MultisigAccountArgs, MultisigTransactionArgs}; use iroha_test_network::*; use iroha_test_samples::{ gen_account_in, ALICE_ID, BOB_ID, BOB_KEYPAIR, CARPENTER_ID, CARPENTER_KEYPAIR, @@ -476,15 +478,3 @@ fn multisig_transactions_registry_of(multisig_account: &AccountId) -> TriggerId .parse() .unwrap() } - -#[allow(dead_code)] -fn debug_mst_registry(msa: &AccountId, client: &Client) { - let mst_registry = client - .query(FindTriggers::new()) - .filter_with(|trigger| trigger.id.eq(multisig_transactions_registry_of(msa))) - .execute_single() - .unwrap(); - let mst_metadata = mst_registry.action().metadata(); - - iroha_logger::error!(%msa, ?mst_metadata); -} diff --git a/crates/iroha/tests/non_mintable.rs b/tests/non_mintable.rs similarity index 100% rename from crates/iroha/tests/non_mintable.rs rename to tests/non_mintable.rs diff --git a/crates/iroha/tests/pagination.rs b/tests/pagination.rs similarity index 100% rename from crates/iroha/tests/pagination.rs rename to tests/pagination.rs diff --git a/crates/iroha/tests/permissions.rs b/tests/permissions.rs similarity index 100% rename from crates/iroha/tests/permissions.rs rename to tests/permissions.rs diff --git a/crates/iroha/tests/queries/account.rs b/tests/queries/account.rs similarity index 100% rename from crates/iroha/tests/queries/account.rs rename to tests/queries/account.rs diff --git a/crates/iroha/tests/queries/asset.rs b/tests/queries/asset.rs similarity index 100% rename from crates/iroha/tests/queries/asset.rs rename to tests/queries/asset.rs diff --git a/crates/iroha/tests/queries/mod.rs b/tests/queries/mod.rs similarity index 94% rename from crates/iroha/tests/queries/mod.rs rename to tests/queries/mod.rs index c2551ff1fe2..5b57fab8e44 100644 --- a/crates/iroha/tests/queries/mod.rs +++ b/tests/queries/mod.rs @@ -41,9 +41,9 @@ fn find_blocks_reversed() -> eyre::Result<()> { let blocks = client.query(FindBlocks).execute_all()?; assert_eq!(blocks.len(), 2); - assert_eq!(blocks[1].header().prev_block_hash, None); + assert_eq!(blocks[1].header().prev_block_hash(), None); assert_eq!( - blocks[0].header().prev_block_hash, + blocks[0].header().prev_block_hash(), Some(blocks[1].header().hash()) ); diff --git a/crates/iroha/tests/queries/query_errors.rs b/tests/queries/query_errors.rs similarity index 100% rename from crates/iroha/tests/queries/query_errors.rs rename to tests/queries/query_errors.rs diff --git a/crates/iroha/tests/queries/role.rs b/tests/queries/role.rs similarity index 100% rename from crates/iroha/tests/queries/role.rs rename to tests/queries/role.rs diff --git a/crates/iroha/tests/queries/smart_contract.rs b/tests/queries/smart_contract.rs similarity index 100% rename from crates/iroha/tests/queries/smart_contract.rs rename to tests/queries/smart_contract.rs diff --git a/crates/iroha/tests/roles.rs b/tests/roles.rs similarity index 100% rename from crates/iroha/tests/roles.rs rename to tests/roles.rs diff --git a/crates/iroha/tests/set_parameter.rs b/tests/set_parameter.rs similarity index 100% rename from crates/iroha/tests/set_parameter.rs rename to tests/set_parameter.rs diff --git a/crates/iroha/tests/sorting.rs b/tests/sorting.rs similarity index 100% rename from crates/iroha/tests/sorting.rs rename to tests/sorting.rs diff --git a/tests/status_response.rs b/tests/status_response.rs new file mode 100644 index 00000000000..139fae9d862 --- /dev/null +++ b/tests/status_response.rs @@ -0,0 +1,54 @@ +//use eyre::Result; +//use iroha::{client, data_model::prelude::*}; +//use iroha_test_network::*; +//use tokio::task::spawn_blocking; +// +//#[ignore] +//fn status_eq_excluding_uptime_and_queue(lhs: &Status, rhs: &Status) -> bool { +// lhs.peers == rhs.peers +// && lhs.blocks == rhs.blocks +// && lhs.txs_accepted == rhs.txs_accepted +// && lhs.txs_rejected == rhs.txs_rejected +// && lhs.view_changes == rhs.view_changes +//} +// +//async fn check(client: &client::Client, blocks: u64) -> Result<()> { +// let status_json = reqwest::get(client.torii_url.join("/status").unwrap()) +// .await? +// .json() +// .await?; +// +// let status_scale = { +// let client = client.clone(); +// spawn_blocking(move || client.get_status()).await?? +// }; +// +// assert!(status_eq_excluding_uptime_and_queue( +// &status_json, +// &status_scale +// )); +// assert_eq!(status_json.blocks, blocks); +// +// Ok(()) +//} +// +//#[tokio::test] +//async fn json_and_scale_statuses_equality() -> Result<()> { +// let network = NetworkBuilder::new().start().await?; +// let client = network.client(); +// +// check(&client, 1).await?; +// +// { +// let client = client.clone(); +// spawn_blocking(move || { +// client.submit_blocking(Register::domain(Domain::new("looking_glass".parse()?))) +// }) +// } +// .await??; +// network.ensure_blocks(2).await?; +// +// check(&client, 2).await?; +// +// Ok(()) +//} diff --git a/crates/iroha/tests/transfer_asset.rs b/tests/transfer_asset.rs similarity index 100% rename from crates/iroha/tests/transfer_asset.rs rename to tests/transfer_asset.rs diff --git a/crates/iroha/tests/transfer_domain.rs b/tests/transfer_domain.rs similarity index 100% rename from crates/iroha/tests/transfer_domain.rs rename to tests/transfer_domain.rs diff --git a/crates/iroha/tests/triggers/by_call_trigger.rs b/tests/triggers/by_call_trigger.rs similarity index 100% rename from crates/iroha/tests/triggers/by_call_trigger.rs rename to tests/triggers/by_call_trigger.rs diff --git a/crates/iroha/tests/triggers/data_trigger.rs b/tests/triggers/data_trigger.rs similarity index 100% rename from crates/iroha/tests/triggers/data_trigger.rs rename to tests/triggers/data_trigger.rs diff --git a/crates/iroha/tests/triggers/event_trigger.rs b/tests/triggers/event_trigger.rs similarity index 100% rename from crates/iroha/tests/triggers/event_trigger.rs rename to tests/triggers/event_trigger.rs diff --git a/crates/iroha/tests/triggers/mod.rs b/tests/triggers/mod.rs similarity index 100% rename from crates/iroha/tests/triggers/mod.rs rename to tests/triggers/mod.rs diff --git a/crates/iroha/tests/triggers/orphans.rs b/tests/triggers/orphans.rs similarity index 100% rename from crates/iroha/tests/triggers/orphans.rs rename to tests/triggers/orphans.rs diff --git a/crates/iroha/tests/triggers/time_trigger.rs b/tests/triggers/time_trigger.rs similarity index 100% rename from crates/iroha/tests/triggers/time_trigger.rs rename to tests/triggers/time_trigger.rs diff --git a/crates/iroha/tests/triggers/trigger_rollback.rs b/tests/triggers/trigger_rollback.rs similarity index 100% rename from crates/iroha/tests/triggers/trigger_rollback.rs rename to tests/triggers/trigger_rollback.rs diff --git a/crates/iroha/tests/tx_chain_id.rs b/tests/tx_chain_id.rs similarity index 98% rename from crates/iroha/tests/tx_chain_id.rs rename to tests/tx_chain_id.rs index c885ed2bec6..d821432b3e3 100644 --- a/crates/iroha/tests/tx_chain_id.rs +++ b/tests/tx_chain_id.rs @@ -1,5 +1,4 @@ use iroha::data_model::prelude::*; -use iroha_primitives::numeric::numeric; use iroha_test_network::*; use iroha_test_samples::gen_account_in; diff --git a/crates/iroha/tests/tx_history.rs b/tests/tx_history.rs similarity index 100% rename from crates/iroha/tests/tx_history.rs rename to tests/tx_history.rs diff --git a/crates/iroha/tests/tx_rollback.rs b/tests/tx_rollback.rs similarity index 100% rename from crates/iroha/tests/tx_rollback.rs rename to tests/tx_rollback.rs diff --git a/crates/iroha/tests/upgrade.rs b/tests/upgrade.rs similarity index 100% rename from crates/iroha/tests/upgrade.rs rename to tests/upgrade.rs