cgroups-rs 0.2.4

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::blkio::*;
use cgroups_rs::cgroup_builder::*;
use cgroups_rs::cpu::*;
use cgroups_rs::devices::*;
use cgroups_rs::hugetlb::*;
use cgroups_rs::memory::*;
use cgroups_rs::net_cls::*;
use cgroups_rs::pid::*;
use cgroups_rs::*;

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

    {
        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::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);

    {
        let c: &MemController = cg.controller_of().unwrap();
        if !c.v2() {
            assert_eq!(c.kmem_stat().limit_in_bytes, 128 * 1024 * 1024);
            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::hierarchies::auto();
    let cg: Cgroup = CgroupBuilder::new("test_pid_res_build")
        .pid()
        .maximum_number_of_processes(MaxValue::Value(123))
        .done()
        .build(h);

    {
        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::hierarchies::auto();
    let cg: Cgroup = CgroupBuilder::new("test_devices_res_build")
        .devices()
        .device(1, 6, DeviceType::Char, true, vec![DevicePermissions::Read])
        .done()
        .build(h);

    {
        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::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);

    {
        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::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);

    {
        let c: &HugeTlbController = cg.controller_of().unwrap();
        assert!(c.limit_in_bytes(&"2MB".to_string()).is_ok());
        assert_eq!(
            c.limit_in_bytes(&"2MB".to_string()).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::hierarchies::auto();
    let cg: Cgroup = CgroupBuilder::new("test_blkio_res_build")
        .blkio()
        .weight(100)
        .done()
        .build(h);

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