Skip to content

Commit 7e49c1b

Browse files
Respond to PR comments. Cleanup documentation.
1 parent 804579c commit 7e49c1b

File tree

1 file changed

+17
-13
lines changed

1 file changed

+17
-13
lines changed

src/doc/rustc/src/instrument-coverage.md

+17-13
Original file line numberDiff line numberDiff line change
@@ -97,23 +97,16 @@ $ echo "{some: 'thing'}" | target/debug/examples/formatjson5 -
9797
}
9898
```
9999

100-
After running this program, a new file, `default_%m_%p.profraw`, should be in the current working directory. This file takes advantage ofLLVM's support for rewriting special pattern strings to ensure `.profraw` files generated are unique. The following special pattern strings are rewritten as:
101-
102-
- `%p` - The process ID.
103-
- `%h` - The hostname of the machine running the program.
104-
- `%t` - The value of the TMPDIR environment variable.
105-
- `%Nm` - the instrumented binary’s signature: The runtime creates a pool of N raw profiles, used for on-line profile merging. The runtime takes care of selecting a raw profile from the pool, locking it, and updating it before the program exits. `N` must be between `1` and `9`, and defaults to `1` if omitted (with simply `%m`).
106-
- `%c` - Does not add anything to the filename, but enables a mode (on some platforms, including Darwin) in which profile counter updates are continuously synced to a file. This means that if the instrumented program crashes, or is killed by a signal, perfect coverage information can still be recovered.
100+
After running this program, a new file named like `default_11699812450447639123_0_20944` should be in the current working directory.
101+
A new, unique file name will be generated each time the program is run to avoid overwriting previous data.
107102

108103
```shell
109104
$ echo "{some: 'thing'}" | target/debug/examples/formatjson5 -
110105
...
111-
$ ls default_11699812450447639123_0_20944.profraw
106+
$ ls default_*.profraw
112107
default_11699812450447639123_0_20944.profraw
113108
```
114109

115-
In the example above, the value `11699812450447639123_0` in the generated filename is the instrumented binary's signature, which replaced the `%m` pattern and the value `20944` is the process ID of the binary being executed.
116-
117110
You can also set a specific file name or path for the generated `.profraw` files by using the environment variable `LLVM_PROFILE_FILE`:
118111

119112
```shell
@@ -124,6 +117,17 @@ $ ls formatjson5.profraw
124117
formatjson5.profraw
125118
```
126119

120+
If `LLVM_PROFILE_FILE` contains a path to a non-existent directory, the missing directory structure will be created. Additionally, the following special pattern strings are rewritten:
121+
122+
- `%p` - The process ID.
123+
- `%h` - The hostname of the machine running the program.
124+
- `%t` - The value of the TMPDIR environment variable.
125+
- `%Nm` - the instrumented binary’s signature: The runtime creates a pool of N raw profiles, used for on-line profile merging. The runtime takes care of selecting a raw profile from the pool, locking it, and updating it before the program exits. `N` must be between `1` and `9`, and defaults to `1` if omitted (with simply `%m`).
126+
- `%c` - Does not add anything to the filename, but enables a mode (on some platforms, including Darwin) in which profile counter updates are continuously synced to a file. This means that if the instrumented program crashes, or is killed by a signal, perfect coverage information can still be recovered.
127+
128+
In the first example above, the value `11699812450447639123_0` in the generated filename is the instrumented binary's signature,
129+
which replaced the `%m` pattern and the value `20944` is the process ID of the binary being executed.
130+
127131
## Installing LLVM coverage tools
128132

129133
LLVM's supplies two tools—`llvm-profdata` and `llvm-cov`—that process coverage data and generate reports. There are several ways to find and/or install these tools, but note that the coverage mapping data generated by the Rust compiler requires LLVM version 12 or higher, and processing the *raw* data may require exactly the LLVM version used by the compiler. (`llvm-cov --version` typically shows the tool's LLVM version number, and `rustc --verbose --version` shows the version of LLVM used by the Rust compiler.)
@@ -190,9 +194,7 @@ A typical use case for coverage analysis is test coverage. Rust's source-based c
190194

191195
The following example (using the [`json5format`] crate, for demonstration purposes) show how to generate and analyze coverage results for all tests in a crate.
192196

193-
Since `cargo test` both builds and runs the tests, we set the additional `RUSTFLAGS`, to add the `-C instrument-coverage` flag. If setting `LLVM_PROFILE_FILE` to specify a custom filename for the raw profiling data generated during the test runs,
194-
apply `%m` in the filename pattern since there may be more than one test binary. This generates unique names for each test binary which is not done by default when setting the `LLVM_PROFILE_FILE` environment variable.
195-
(Otherwise, each executed test binary would overwrite the coverage results from the previous binary.) If not setting `LLVM_PROFILE_FILE`, the `%m` and `%p` filename patterns are added by default.
197+
Since `cargo test` both builds and runs the tests, we set the additional `RUSTFLAGS`, to add the `-C instrument-coverage` flag.
196198

197199
```shell
198200
$ RUSTFLAGS="-C instrument-coverage" \
@@ -240,6 +242,8 @@ $ llvm-cov show \
240242
--Xdemangler=rustfilt | less -R
241243
```
242244

245+
> **Note**: If overriding the default `profraw` file name via the `LLVM_PROFILE_FILE` environment variable, it's highly recommended to use the `%m` and `%p` special pattern strings to generate unique file names in the case of more than a single test binary being executed.
246+
243247
> **Note**: The command line option `--ignore-filename-regex=/.cargo/registry`, which excludes the sources for dependencies from the coverage results.\_
244248
245249
### Tips for listing the binaries automatically

0 commit comments

Comments
 (0)