1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
|
use magnus::error::ErrorType;
#[test]
fn it_includes_backtrace_in_debug() {
let ruby = unsafe { magnus::embed::init() };
let err = ruby
.eval::<magnus::Value>(
r#"
def foo
raise "bang"
end
def bar
foo
end
def baz
bar
end
def qux
baz
end
qux
"#,
)
.unwrap_err();
let ex = match err.error_type() {
ErrorType::Exception(e) => e,
_ => panic!(),
};
let message = format!("{:#?}", ex);
assert!(message.contains("RuntimeError: bang"));
assert!(message.contains("eval:3:in"));
assert!(message.contains("foo"));
assert!(message.contains("eval:7:in"));
assert!(message.contains("bar"));
assert!(message.contains("eval:11:in"));
assert!(message.contains("baz"));
assert!(message.contains("eval:15:in"));
assert!(message.contains("qux"));
assert!(message.contains("eval:18:in"));
assert!(message.contains("<main>"));
}
|