Skip to content

Commit

Permalink
Merge pull request #1801 from dtolnay/fixupinvariant
Browse files Browse the repository at this point in the history
Add exhaustive test of FixupContext leading/trailing invariant
  • Loading branch information
dtolnay authored Dec 26, 2024
2 parents 4947eb4 + 90c730d commit 3a8d163
Showing 1 changed file with 31 additions and 0 deletions.
31 changes: 31 additions & 0 deletions src/fixup.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ use crate::classify;
use crate::expr::Expr;
use crate::precedence::Precedence;

#[cfg_attr(test, derive(PartialEq, Debug))]
pub(crate) struct FixupContext {
// Print expression such that it can be parsed back as a statement
// consisting of the original expression.
Expand Down Expand Up @@ -343,3 +344,33 @@ impl Clone for FixupContext {
*self
}
}

#[cfg(feature = "full")]
#[test]
fn test_leftmost_rightmost_invariant() {
const BITS: usize = 8;

for bits in 0u16..1 << BITS {
let mut i = 0;
let mut bit = || {
let mask = 1 << i;
i += 1;
(bits & mask) != 0
};
let fixup = FixupContext {
stmt: bit(),
leftmost_subexpression_in_stmt: bit(),
match_arm: bit(),
leftmost_subexpression_in_match_arm: bit(),
parenthesize_exterior_struct_lit: bit(),
next_operator_can_begin_expr: bit(),
next_operator_can_continue_expr: bit(),
next_operator_can_begin_generics: bit(),
};
assert_eq!(i, BITS);
assert_eq!(
fixup.leftmost_subexpression().rightmost_subexpression(),
fixup.rightmost_subexpression().leftmost_subexpression(),
);
}
}

0 comments on commit 3a8d163

Please sign in to comment.