4666047395
Updated 4763 files with dual copyright: - Parity Technologies (UK) Ltd. - Dijital Kurdistan Tech Institute
76 lines
2.1 KiB
Rust
76 lines
2.1 KiB
Rust
// This file is part of Bizinikiwi.
|
|
|
|
// Copyright (C) Parity Technologies (UK) Ltd. and Dijital Kurdistan Tech Institute
|
|
// SPDX-License-Identifier: GPL-3.0-or-later WITH Classpath-exception-2.0
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
#![allow(deprecated)]
|
|
|
|
use assert_cmd::cargo::cargo_bin;
|
|
use std::process::Command;
|
|
|
|
/// Tests that the `benchmark machine` command works for the bizinikiwi dev runtime.
|
|
#[test]
|
|
fn benchmark_machine_works() {
|
|
let status = Command::new(cargo_bin("bizinikiwi-node"))
|
|
.args(["benchmark", "machine", "--dev"])
|
|
.args([
|
|
"--verify-duration",
|
|
"0.1",
|
|
"--disk-duration",
|
|
"0.1",
|
|
"--memory-duration",
|
|
"0.1",
|
|
"--hash-duration",
|
|
"0.1",
|
|
])
|
|
// Make it succeed.
|
|
.args(["--allow-fail"])
|
|
.status()
|
|
.unwrap();
|
|
|
|
assert!(status.success());
|
|
}
|
|
|
|
/// Test that the hardware does not meet the requirements.
|
|
///
|
|
/// This is most likely to succeed since it uses a test profile.
|
|
#[test]
|
|
#[cfg(debug_assertions)]
|
|
fn benchmark_machine_fails_with_slow_hardware() {
|
|
let output = Command::new(cargo_bin("bizinikiwi-node"))
|
|
.args(["benchmark", "machine", "--dev"])
|
|
.args([
|
|
"--verify-duration",
|
|
"1.0",
|
|
"--disk-duration",
|
|
"2",
|
|
"--hash-duration",
|
|
"1.0",
|
|
"--memory-duration",
|
|
"1.0",
|
|
"--tolerance",
|
|
"0",
|
|
])
|
|
.output()
|
|
.unwrap();
|
|
|
|
// Command should have failed.
|
|
assert!(!output.status.success());
|
|
// An `UnmetRequirement` error should have been printed.
|
|
let log = String::from_utf8_lossy(&output.stderr).to_string();
|
|
assert!(log.contains("UnmetRequirement"));
|
|
}
|