WorksButNotTested 728b1216bb
Librasan (#3023)
* Fixes to main

* Add librasan

* Party like it's 2024

* Fix snapshot module to work with guest asan

* Fix guest_asan module

* Fixes to runner

* Fix linking issues using a REL

* Fix qemu_launcher

* Change modify_mapping to a method

* Fix gasan_test

* Remove debug from Justfile

* Optimize release build of librasan

* Set ulimit for qasan and gasan tests

* Tidy up symbol renaming

* Add missing symbols for PPC

* Change to support rustix 1.0.0

* Canonicalize the CUSTOM_ASAN_PATH

* Review changes

* Restructure backends

* release_max_level_info

* More review changes

* Clippy fixes

* Changes to reduce the burden on the CI

* Fix macos clippy

---------

Co-authored-by: Your Name <you@example.com>
2025-03-10 17:27:55 +01:00

183 lines
4.6 KiB
Rust

#[cfg(test)]
#[cfg(feature = "hooks")]
mod tests {
use core::{ffi::c_char, ptr::null};
use asan::{expect_panic, hooks::strncasecmp::strncasecmp};
#[test]
fn test_strncasecmp_zero_length() {
expect_panic();
let ret = unsafe { strncasecmp(null(), null(), 0) };
assert_eq!(ret, 0);
}
#[test]
fn test_strncasecmp_null_s1() {
expect_panic();
let data = [0u8; 10];
unsafe { strncasecmp(null(), data.as_ptr() as *const c_char, data.len()) };
unreachable!();
}
#[test]
fn test_strncasecmp_null_s2() {
expect_panic();
let data = [0u8; 10];
unsafe { strncasecmp(data.as_ptr() as *const c_char, null(), data.len()) };
unreachable!();
}
#[test]
fn test_strncasecmp_eq() {
let data = [1u8; 10];
let ret = unsafe {
strncasecmp(
data.as_ptr() as *const c_char,
data.as_ptr() as *const c_char,
data.len(),
)
};
assert_eq!(ret, 0);
}
#[test]
fn test_strncasecmp_zero_length_both() {
let data = [0u8; 10];
let ret = unsafe {
strncasecmp(
data.as_ptr() as *const c_char,
data.as_ptr() as *const c_char,
data.len(),
)
};
assert_eq!(ret, 0);
}
#[test]
fn test_strncasecmp_zero_length_s1() {
let data1 = [0u8; 10];
let data2 = [1u8; 10];
let ret = unsafe {
strncasecmp(
data1.as_ptr() as *const c_char,
data2.as_ptr() as *const c_char,
data1.len(),
)
};
assert!(ret < 0);
}
#[test]
fn test_strncasecmp_zero_length_s2() {
let data1 = [1u8; 10];
let data2 = [0u8; 10];
let ret = unsafe {
strncasecmp(
data1.as_ptr() as *const c_char,
data2.as_ptr() as *const c_char,
data1.len(),
)
};
assert!(ret > 0);
}
#[test]
fn test_strncasecmp_eq_string() {
let data1 = c"abcdefghij";
let data2 = c"abcdefghij";
let ret = unsafe {
strncasecmp(
data1.as_ptr() as *const c_char,
data2.as_ptr() as *const c_char,
data1.count_bytes(),
)
};
assert_eq!(ret, 0);
}
#[test]
fn test_strncasecmp_s1_shorter() {
let data1 = c"abcdefghi";
let data2 = c"abcdefghij";
let ret = unsafe {
strncasecmp(
data1.as_ptr() as *const c_char,
data2.as_ptr() as *const c_char,
data2.count_bytes(),
)
};
assert!(ret < 0);
}
#[test]
fn test_strncasecmp_s1_longer() {
let data1 = c"abcdefghij";
let data2 = c"abcdefghi";
let ret = unsafe {
strncasecmp(
data1.as_ptr() as *const c_char,
data2.as_ptr() as *const c_char,
data1.count_bytes(),
)
};
assert!(ret > 0);
}
#[test]
fn test_strncasecmp_s1_less_than() {
let data1 = c"abcdefghii";
let data2 = c"abcdefghij";
let ret = unsafe {
strncasecmp(
data1.as_ptr() as *const c_char,
data2.as_ptr() as *const c_char,
data1.count_bytes(),
)
};
assert!(ret < 0);
}
#[test]
fn test_strncasecmp_s1_greater_than() {
let data1 = c"abcdefghik";
let data2 = c"abcdefghij";
let ret = unsafe {
strncasecmp(
data1.as_ptr() as *const c_char,
data2.as_ptr() as *const c_char,
data1.count_bytes(),
)
};
assert!(ret > 0);
}
#[test]
fn test_strncasecmp_case_ignored() {
let data1 = c"abcdefghijklmnopqrstuvwxyz";
let data2 = c"ABCDEFGHIJKLMNOPQRSTUVWXYZ";
let ret = unsafe {
strncasecmp(
data1.as_ptr() as *const c_char,
data2.as_ptr() as *const c_char,
data1.count_bytes(),
)
};
assert_eq!(ret, 0);
}
#[test]
fn test_strncasecmp_differ_after_length() {
let data1 = c"abcdefghijXYZ";
let data2 = c"abcdefghijUVW";
let ret = unsafe {
strncasecmp(
data1.as_ptr() as *const c_char,
data2.as_ptr() as *const c_char,
data1.count_bytes() - 3,
)
};
assert_eq!(ret, 0);
}
}