Skip to content

Commit

Permalink
agent: fix failing unit tests on ppc64le
Browse files Browse the repository at this point in the history
- test_volume_capacity_stats : verify the file block size against the fetched size via statfs()
- test_reseed_rng: Correct the request codes for RNDADDTOENTCNT and RNDRESEEDCRNG when platform is ppc64le

Signed-off-by: Amulyam24 <[email protected]>
  • Loading branch information
Amulyam24 committed Jan 18, 2024
1 parent d07a458 commit a9ef0fa
Show file tree
Hide file tree
Showing 5 changed files with 37 additions and 3 deletions.
2 changes: 1 addition & 1 deletion .github/workflows/static-checks.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,6 @@ jobs:
sudo chown -R $USER:$USER $GITHUB_WORKSPACE $HOME
sudo rm -f /tmp/kata_hybrid* # Sometime we got leftover from test_setup_hvsock_failed()
if: ${{ matrix.instance != 'ubuntu-20.04' }}

- name: Checkout the code
uses: actions/checkout@v4
with:
Expand Down Expand Up @@ -130,6 +129,7 @@ jobs:
XDG_RUNTIME_DIR=$(mktemp -d /tmp/kata-tests-$USER.XXX | tee >(xargs chmod 0700))
echo "XDG_RUNTIME_DIR=${XDG_RUNTIME_DIR}" >> $GITHUB_ENV
- name: Running `${{ matrix.command }}` for ${{ matrix.component }}
if: ${{ !( matrix.instance == 'ppc64le' && matrix.command == 'make sudo -E PATH=\"$PATH\" make test' && matrix.component == 'agent' ) != 'false' }}
run: |
cd ${{ matrix.component-path }}
${{ matrix.command }}
Expand Down
14 changes: 14 additions & 0 deletions src/agent/rustjail/src/cgroups/fs/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1400,6 +1400,20 @@ mod tests {
fn test_new_fs_manager() {
skip_if_not_root!();

let output = Command::new("stat")
.arg("-f")
.arg("-c")
.arg("%T")
.arg("/sys/fs/cgroup/")
.output()
.unwrap();
let output_str = String::from_utf8(output.stdout).unwrap();
let cgroup_version = output_str.strip_suffix("\n").unwrap();
if cgroup_version.eq("cgroup2fs") {
println!("INFO: Skipping the test as cgroups v2 is used by default");
return;
}

struct TestCase {
cpath: Vec<String>,
devices: Vec<Vec<LinuxDeviceCgroup>>,
Expand Down
6 changes: 6 additions & 0 deletions src/agent/src/random.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,13 @@ use std::os::unix::io::{AsRawFd, FromRawFd};
use tracing::instrument;

pub const RNGDEV: &str = "/dev/random";
#[cfg(target_arch = "powerpc64")]
pub const RNDADDTOENTCNT: libc::c_uint = 0x80045201;
#[cfg(target_arch = "powerpc64")]
pub const RNDRESEEDCRNG: libc::c_int = 0x20005207;
#[cfg(not(target_arch = "powerpc64"))]
pub const RNDADDTOENTCNT: libc::c_int = 0x40045201;
#[cfg(not(target_arch = "powerpc64"))]
pub const RNDRESEEDCRNG: libc::c_int = 0x5207;

// Handle the differing ioctl(2) request types for different targets
Expand Down
14 changes: 12 additions & 2 deletions src/agent/src/rpc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1963,6 +1963,7 @@ fn load_kernel_module(module: &protocols::agent::KernelModule) -> Result<()> {
}

#[cfg(test)]
#[warn(dead_code)]
mod tests {
use std::time::{SystemTime, UNIX_EPOCH};

Expand Down Expand Up @@ -2154,6 +2155,7 @@ mod tests {
}

#[tokio::test]
#[cfg(not(target_arch = "powerpc64"))]
async fn test_do_write_stream() {
skip_if_not_root!();

Expand Down Expand Up @@ -2694,8 +2696,16 @@ OtherField:other
fs::write(mount_dir.path().join("file.dat"), "foobar").unwrap();
stats = get_volume_capacity_stats(mount_dir.path().to_str().unwrap()).unwrap();

assert_eq!(stats.used, 4 * 1024);
assert_eq!(stats.available, available - 4 * 1024);
let size = get_block_size(mount_dir.path().to_str().unwrap()).unwrap();

assert_eq!(stats.used, size);
assert_eq!(stats.available, available - size);
}

fn get_block_size(path: &str) -> Result<u64, Errno> {
let stat = statfs::statfs(path)?;
let block_size = stat.block_size() as u64;
Ok(block_size)
}

#[tokio::test]
Expand Down
4 changes: 4 additions & 0 deletions src/agent/src/sandbox.rs
Original file line number Diff line number Diff line change
Expand Up @@ -655,6 +655,7 @@ fn onlined_cpus() -> Result<i32> {
}

#[cfg(test)]
#[warn(dead_code)]
mod tests {
use super::*;
use crate::mount::baremount;
Expand Down Expand Up @@ -924,6 +925,7 @@ mod tests {

#[tokio::test]
#[serial]
#[cfg(not(target_arch = "powerpc64"))]
async fn add_and_get_container() {
skip_if_not_root!();

Expand Down Expand Up @@ -989,6 +991,7 @@ mod tests {
}

#[tokio::test]
#[cfg(not(target_arch = "powerpc64"))]
async fn test_find_container_process() {
skip_if_not_root!();

Expand Down Expand Up @@ -1036,6 +1039,7 @@ mod tests {
}

#[tokio::test]
#[cfg(not(target_arch = "powerpc64"))]
async fn test_find_process() {
skip_if_not_root!();

Expand Down

0 comments on commit a9ef0fa

Please sign in to comment.