mirror of
https://chromium.googlesource.com/crosvm/crosvm
synced 2025-02-09 03:57:24 +00:00
e2e_tests: Add vsock tests
Add vsock tests to confirm the vsock device works at crosvm upstream BUG=b:254375643 TEST=`./tools/presubmit` Change-Id: I24137e00dc449c97be8ee7e9101906541ea843d1 Reviewed-on: https://chromium-review.googlesource.com/c/crosvm/crosvm/+/3998914 Reviewed-by: Takaya Saeki <takayas@chromium.org> Commit-Queue: Ryuichiro Chiba <chibar@chromium.org> Reviewed-by: Keiichi Watanabe <keiichiw@chromium.org>
This commit is contained in:
parent
df7a2e51bf
commit
9406b788c3
1 changed files with 86 additions and 0 deletions
86
e2e_tests/tests/vsock.rs
Normal file
86
e2e_tests/tests/vsock.rs
Normal file
|
@ -0,0 +1,86 @@
|
|||
// Copyright 2022 The ChromiumOS Authors
|
||||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
//! Testing vsock.
|
||||
|
||||
pub mod fixture;
|
||||
|
||||
use std::process::Command;
|
||||
use std::process::Stdio;
|
||||
use std::thread;
|
||||
use std::time::Duration;
|
||||
|
||||
use fixture::Config;
|
||||
use fixture::TestVm;
|
||||
|
||||
const HOST_CID: u64 = 2;
|
||||
const GUEST_CID: u64 = 5;
|
||||
const VSOCK_COM_PORT: u64 = 11111;
|
||||
|
||||
const SERVER_TIMEOUT_IN_SEC: u64 = 3;
|
||||
const CLIENT_WAIT_DURATION: Duration = Duration::from_millis(1000);
|
||||
|
||||
const MESSAGE_TO_HOST: &str = "Connection from the host is successfully established";
|
||||
const MESSAGE_TO_GUEST: &str = "Connection from the guest is successfully established";
|
||||
|
||||
#[test]
|
||||
fn host_to_guest_connection() {
|
||||
let config = Config::new().extra_args(vec!["--cid".to_string(), GUEST_CID.to_string()]);
|
||||
let mut vm = TestVm::new(config).unwrap();
|
||||
|
||||
let handle_guest = thread::spawn(move || {
|
||||
let cmd = format!(
|
||||
"echo {MESSAGE_TO_HOST} | timeout {SERVER_TIMEOUT_IN_SEC}s ncat -l --vsock {VSOCK_COM_PORT}",
|
||||
);
|
||||
vm.exec_in_guest(&cmd).unwrap();
|
||||
});
|
||||
|
||||
// wait until the server is ready
|
||||
thread::sleep(CLIENT_WAIT_DURATION);
|
||||
|
||||
let output = Command::new("ncat")
|
||||
.args(["--idle-timeout", "1"])
|
||||
.args([
|
||||
"--vsock",
|
||||
&GUEST_CID.to_string(),
|
||||
&VSOCK_COM_PORT.to_string(),
|
||||
])
|
||||
.output()
|
||||
.expect("failed to execute process");
|
||||
let host_stdout = std::str::from_utf8(&output.stdout).unwrap();
|
||||
|
||||
handle_guest.join().unwrap();
|
||||
|
||||
assert_eq!(host_stdout.trim(), MESSAGE_TO_HOST);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn guest_to_host_connection() {
|
||||
let config = Config::new().extra_args(vec!["--cid".to_string(), GUEST_CID.to_string()]);
|
||||
let mut vm = TestVm::new(config).unwrap();
|
||||
|
||||
let echo = Command::new("echo")
|
||||
.arg(MESSAGE_TO_GUEST)
|
||||
.stdout(Stdio::piped())
|
||||
.spawn()
|
||||
.unwrap();
|
||||
let mut handle_host = Command::new("timeout")
|
||||
.arg(format!("{SERVER_TIMEOUT_IN_SEC}s"))
|
||||
.arg("ncat")
|
||||
.arg("-l")
|
||||
.args(["--vsock", &VSOCK_COM_PORT.to_string()])
|
||||
.stdin(echo.stdout.unwrap())
|
||||
.spawn()
|
||||
.expect("failed to execute process");
|
||||
|
||||
// wait until the server is ready
|
||||
thread::sleep(CLIENT_WAIT_DURATION);
|
||||
|
||||
let cmd = format!("ncat --idle-timeout 1 --vsock {HOST_CID} {VSOCK_COM_PORT}");
|
||||
let guest_stdout = vm.exec_in_guest(&cmd).unwrap();
|
||||
|
||||
handle_host.wait().unwrap();
|
||||
|
||||
assert_eq!(guest_stdout.trim(), MESSAGE_TO_GUEST);
|
||||
}
|
Loading…
Reference in a new issue