cgroups-rs 0.5.0

Native Rust crate for managing control groups on Linux
Documentation
// Copyright (c) 2018 Levente Kurusa
// Copyright (c) 2020 And Group
//
// SPDX-License-Identifier: Apache-2.0 or MIT
//

//! Some simple tests covering the builder pattern for control groups.
use cgroups_rs::fs::blkio::*;
use cgroups_rs::fs::cgroup_builder::*;
use cgroups_rs::fs::cpu::*;
use cgroups_rs::fs::devices::*;
use cgroups_rs::fs::hugetlb::*;
use cgroups_rs::fs::memory::*;
use cgroups_rs::fs::net_cls::*;
use cgroups_rs::fs::pid::*;
use cgroups_rs::fs::*;

#[test]
pub fn test_cpu_res_build() {
    let h = cgroups_rs::fs::hierarchies::auto();
    let cg: Cgroup = CgroupBuilder::new("test_cpu_res_build")
        .cpu()
        .shares(85)
        .done()
        .build(h)
        .unwrap();

    {
        let cpu: &CpuController = cg.controller_of().unwrap();
        assert!(cpu.shares().is_ok());
        assert_eq!(cpu.shares().unwrap(), 85);
    }

    cg.delete().unwrap();
}

#[test]
pub fn test_memory_res_build() {
    let h = cgroups_rs::fs::hierarchies::auto();
    let cg: Cgroup = CgroupBuilder::new("test_memory_res_build")
        .memory()
        .kernel_memory_limit(128 * 1024 * 1024)
        .swappiness(70)
        .memory_hard_limit(1024 * 1024 * 1024)
        .done()
        .build(h)
        .unwrap();

    {
        let c: &MemController = cg.controller_of().unwrap();
        if !c.v2() {
            // Note: we don't tests the value of c.kmem_stat().limit_in_bytes because on Linux
            // kernel >= 5.16 setting this value is unsupported.
            assert_eq!(c.memory_stat().swappiness, 70);
        }
        assert_eq!(c.memory_stat().limit_in_bytes, 1024 * 1024 * 1024);
    }

    cg.delete().unwrap();
}

#[test]
pub fn test_pid_res_build() {
    let h = cgroups_rs::fs::hierarchies::auto();
    let cg: Cgroup = CgroupBuilder::new("test_pid_res_build")
        .pid()
        .maximum_number_of_processes(MaxValue::Value(123))
        .done()
        .build(h)
        .unwrap();

    {
        let c: &PidController = cg.controller_of().unwrap();
        assert!(c.get_pid_max().is_ok());
        assert_eq!(c.get_pid_max().unwrap(), MaxValue::Value(123));
    }

    cg.delete().unwrap();
}

#[test]
#[ignore] // ignore this test for now, not sure why my kernel doesn't like it
pub fn test_devices_res_build() {
    let h = cgroups_rs::fs::hierarchies::auto();
    let cg: Cgroup = CgroupBuilder::new("test_devices_res_build")
        .devices()
        .device(1, 6, DeviceType::Char, true, vec![DevicePermissions::Read])
        .done()
        .build(h)
        .unwrap();

    {
        let c: &DevicesController = cg.controller_of().unwrap();
        assert!(c.allowed_devices().is_ok());
        assert_eq!(
            c.allowed_devices().unwrap(),
            vec![DeviceResource {
                allow: true,
                devtype: DeviceType::Char,
                major: 1,
                minor: 6,
                access: vec![DevicePermissions::Read],
            }]
        );
    }
    cg.delete().unwrap();
}

#[test]
pub fn test_network_res_build() {
    let h = cgroups_rs::fs::hierarchies::auto();
    if h.v2() {
        // FIXME add cases for v2
        return;
    }
    let cg: Cgroup = CgroupBuilder::new("test_network_res_build")
        .network()
        .class_id(1337)
        .done()
        .build(h)
        .unwrap();

    {
        let c: &NetClsController = cg.controller_of().unwrap();
        assert!(c.get_class().is_ok());
        assert_eq!(c.get_class().unwrap(), 1337);
    }
    cg.delete().unwrap();
}

#[test]
pub fn test_hugepages_res_build() {
    let h = cgroups_rs::fs::hierarchies::auto();
    if h.v2() {
        // FIXME add cases for v2
        return;
    }
    let cg: Cgroup = CgroupBuilder::new("test_hugepages_res_build")
        .hugepages()
        .limit("2MB".to_string(), 4 * 2 * 1024 * 1024)
        .done()
        .build(h)
        .unwrap();

    {
        let c: &HugeTlbController = cg.controller_of().unwrap();
        assert!(c.limit_in_bytes("2MB").is_ok());
        assert_eq!(c.limit_in_bytes("2MB").unwrap(), 4 * 2 * 1024 * 1024);
    }
    cg.delete().unwrap();
}

#[test]
#[ignore] // high version kernel not support `blkio.weight`
pub fn test_blkio_res_build() {
    let h = cgroups_rs::fs::hierarchies::auto();
    let cg: Cgroup = CgroupBuilder::new("test_blkio_res_build")
        .blkio()
        .weight(100)
        .done()
        .build(h)
        .unwrap();

    {
        let c: &BlkIoController = cg.controller_of().unwrap();
        assert_eq!(c.blkio().weight, 100);
    }
    cg.delete().unwrap();
}