Rollup merge of #95528 - RalfJung:miri-is-too-slow, r=scottmcm

skip slow int_log tests in Miri

Iterating over i16::MAX many things takes a long time in Miri, let's not do that.
I added https://github.com/rust-lang/miri/pull/2044 on the Miri side to still give us some test coverage.
This commit is contained in:
Matthias Krüger 2022-04-01 12:07:03 +02:00 committed by GitHub
commit c37aeb0299
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -22,12 +22,15 @@ fn checked_log() {
assert_eq!(0i8.checked_log(4), None); assert_eq!(0i8.checked_log(4), None);
assert_eq!(0i16.checked_log(4), None); assert_eq!(0i16.checked_log(4), None);
#[cfg(not(miri))] // Miri is too slow
for i in i16::MIN..=0 { for i in i16::MIN..=0 {
assert_eq!(i.checked_log(4), None); assert_eq!(i.checked_log(4), None);
} }
#[cfg(not(miri))] // Miri is too slow
for i in 1..=i16::MAX { for i in 1..=i16::MAX {
assert_eq!(i.checked_log(13), Some((i as f32).log(13.0) as u32)); assert_eq!(i.checked_log(13), Some((i as f32).log(13.0) as u32));
} }
#[cfg(not(miri))] // Miri is too slow
for i in 1..=u16::MAX { for i in 1..=u16::MAX {
assert_eq!(i.checked_log(13), Some((i as f32).log(13.0) as u32)); assert_eq!(i.checked_log(13), Some((i as f32).log(13.0) as u32));
} }
@ -48,6 +51,7 @@ fn checked_log2() {
for i in 1..=u8::MAX { for i in 1..=u8::MAX {
assert_eq!(i.checked_log2(), Some((i as f32).log2() as u32)); assert_eq!(i.checked_log2(), Some((i as f32).log2() as u32));
} }
#[cfg(not(miri))] // Miri is too slow
for i in 1..=u16::MAX { for i in 1..=u16::MAX {
// Guard against Android's imprecise f32::log2 implementation. // Guard against Android's imprecise f32::log2 implementation.
if i != 8192 && i != 32768 { if i != 8192 && i != 32768 {
@ -60,9 +64,11 @@ fn checked_log2() {
for i in 1..=i8::MAX { for i in 1..=i8::MAX {
assert_eq!(i.checked_log2(), Some((i as f32).log2() as u32)); assert_eq!(i.checked_log2(), Some((i as f32).log2() as u32));
} }
#[cfg(not(miri))] // Miri is too slow
for i in i16::MIN..=0 { for i in i16::MIN..=0 {
assert_eq!(i.checked_log2(), None); assert_eq!(i.checked_log2(), None);
} }
#[cfg(not(miri))] // Miri is too slow
for i in 1..=i16::MAX { for i in 1..=i16::MAX {
// Guard against Android's imprecise f32::log2 implementation. // Guard against Android's imprecise f32::log2 implementation.
if i != 8192 { if i != 8192 {
@ -87,15 +93,19 @@ fn checked_log10() {
assert_eq!(0i8.checked_log10(), None); assert_eq!(0i8.checked_log10(), None);
assert_eq!(0i16.checked_log10(), None); assert_eq!(0i16.checked_log10(), None);
#[cfg(not(miri))] // Miri is too slow
for i in i16::MIN..=0 { for i in i16::MIN..=0 {
assert_eq!(i.checked_log10(), None); assert_eq!(i.checked_log10(), None);
} }
#[cfg(not(miri))] // Miri is too slow
for i in 1..=i16::MAX { for i in 1..=i16::MAX {
assert_eq!(i.checked_log10(), Some((i as f32).log10() as u32)); assert_eq!(i.checked_log10(), Some((i as f32).log10() as u32));
} }
#[cfg(not(miri))] // Miri is too slow
for i in 1..=u16::MAX { for i in 1..=u16::MAX {
assert_eq!(i.checked_log10(), Some((i as f32).log10() as u32)); assert_eq!(i.checked_log10(), Some((i as f32).log10() as u32));
} }
#[cfg(not(miri))] // Miri is too slow
for i in 1..=100_000u32 { for i in 1..=100_000u32 {
assert_eq!(i.checked_log10(), Some((i as f32).log10() as u32)); assert_eq!(i.checked_log10(), Some((i as f32).log10() as u32));
} }