
* 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>
183 lines
4.6 KiB
Rust
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);
|
|
}
|
|
}
|