dylint_testing

[docs.rs documentation]

This crate provides convenient access to the [compiletest_rs] package for testing [Dylint] libraries.

Specifically, this crate provides the following three functions. Note: If your test has dependencies, you must use ui_test_example or ui_test_examples. See the [questionmarkin_expression] example in this repository.

For most situations, you can add the following to your library's lib.rs file:

```rust,ignore

[test]

fn ui() { dylinttesting::uitest( env!("CARGOPKGNAME"), &std::path::Path::new(env!("CARGOMANIFESTDIR")).join("ui"), ); } ```

And include one or more .rs and .stderr files in a ui directory alongside your library's src directory. See the [examples] in this repository.

Test builder

In addition to the above three functions, dylint_testing::ui:Test is a test "builder." Currently, the main advantage of using Test over the above functions is that Test allows flags to be passed to rustc. For an example of its use, see [nonthreadsafecallin_test] in this repository.

Test has three constructors, which correspond to the above three functions as follows:

In each case, the constructor's arguments are exactly those of the corresponding function.

A Test instance has the following methods:

Updating .stderr files

If the standard error that results from running your .rs file differs from the contents of your .stderr file, compiletest_rs will produce a report like the following:

```rust,ignore diff of stderr:

error: calling std::env::set_var in a test could affect the outcome of other tests --> $DIR/main.rs:8:5 | LL | std::env::set_var("KEY", "VALUE"); | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ | = note: -D non-thread-safe-call-in-test implied by -D warnings

-error: aborting due to previous error +error: calling std::env::set_var in a test could affect the outcome of other tests + --> $DIR/main.rs:23:9 + | +LL | std::env::set_var("KEY", "VALUE"); + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +error: aborting due to 2 previous errors

The actual stderr differed from the expected stderr. Actual stderr saved to ... ```

The meaning of each line is as follows:

Note: In the actual standard error, a blank line usually follows the error: aborting due to N previous errors line. So a correct .stderr file will typically contain one blank line at the end.

In general, it is not too hard to update a .stderr file by hand. However, the compiletest_rs report should contain a line of the form Actual stderr saved to PATH. Copying PATH to your .stderr file should update it completely.

Additional documentation on compiletest_rs can be found in [its repository].