Sha256: c07319cd47464cf1a718ae8375a0ae71318949950478bafcfb309efdf33f7bc6

Contents?: true

Size: 1.08 KB

Versions: 4

Compression:

Stored size: 1.08 KB

Contents

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>"));
}

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
wasmtime-29.0.0 ./ext/cargo-vendor/magnus-0.7.1/tests/debug_exception.rs
wasmtime-28.0.0 ./ext/cargo-vendor/magnus-0.7.1/tests/debug_exception.rs
wasmtime-27.0.0 ./ext/cargo-vendor/magnus-0.7.1/tests/debug_exception.rs
wasmtime-26.0.0 ./ext/cargo-vendor/magnus-0.7.1/tests/debug_exception.rs