bugfix for binary and, modulo, binary ops tests
This commit is contained in:
52
src/tests.rs
52
src/tests.rs
@@ -688,4 +688,56 @@ fn test_right_shift_equals() {
|
||||
} else {
|
||||
assert!(false);
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_modulo_equals() {
|
||||
let mut engine = Engine::new();
|
||||
|
||||
if let Ok(result) = engine.eval::<i64>("let x = 10; x %= 4; x") {
|
||||
assert_eq!(result, 2);
|
||||
} else {
|
||||
assert!(false);
|
||||
}
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn test_binary_ops() {
|
||||
let mut engine = Engine::new();
|
||||
|
||||
if let Ok(result) = engine.eval::<i64>("10 % 4") {
|
||||
assert_eq!(result, 2);
|
||||
} else {
|
||||
assert!(false);
|
||||
}
|
||||
|
||||
if let Ok(result) = engine.eval::<i64>("10 << 4") {
|
||||
assert_eq!(result, 160);
|
||||
} else {
|
||||
assert!(false);
|
||||
}
|
||||
|
||||
if let Ok(result) = engine.eval::<i64>("10 >> 4") {
|
||||
assert_eq!(result, 0);
|
||||
} else {
|
||||
assert!(false);
|
||||
}
|
||||
|
||||
if let Ok(result) = engine.eval::<i64>("10 & 4") {
|
||||
assert_eq!(result, 0);
|
||||
} else {
|
||||
assert!(false);
|
||||
}
|
||||
|
||||
if let Ok(result) = engine.eval::<i64>("10 | 4") {
|
||||
assert_eq!(result, 14);
|
||||
} else {
|
||||
assert!(false);
|
||||
}
|
||||
|
||||
if let Ok(result) = engine.eval::<i64>("10 ^ 4") {
|
||||
assert_eq!(result, 14);
|
||||
} else {
|
||||
assert!(false);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user