Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

memory leak when merging reports #1639

Open
flavio opened this issue Oct 23, 2024 · 2 comments
Open

memory leak when merging reports #1639

flavio opened this issue Oct 23, 2024 · 2 comments
Assignees

Comments

@flavio
Copy link

flavio commented Oct 23, 2024

Describe the bug

We're using tarpaulin to collect coverage of end-to-end test of kwctl, a Rust cli tool.

The tests are running fine and produce many profraw files. I've seen we are generating 138(!!!) files, maybe we're doing something stupid?!

It looks like there's a memory leak when these files are aggregated. The "Merging coverage reports" step takes a long time and, while running, the memory usage increases significantly.
On my system I've witnessed tarpaulin consume up to 28 GB of memory.

When running inside of a GitHub Action, tarpaulin is killed because it's consuming too much memory.

To Reproduce

We're using tarpaulin 0.31.2, with Rust 1.82.0, on x86_64 Linux.

The issue can be reproduced in this way:

  1. Checkout kwctl code
  2. Ensure docker daemon is running. This is needed to start the registry image locally.
  3. Run make coverage-e2e-tests or just cargo tarpaulin --verbose --skip-clean --engine=llvm --all-features --implicit-test-threads --test e2e --out xml --out html --output-dir coverage/e2e-tests

You can also run these command by prepending GNU Time to have a rough idea about the amount of memory being used:

/usr/bin/time -v make coverage-e2e-tests

Expected behavior

The usage of memory should not be so high.

@xd009642
Copy link
Owner

So each executable ran will generate a prof raw, so how rust's test stuff decides to split things into binaries and any spawned processes built as part of the tests will generate one.

As for the memory usage, unfortunately rust flags are applied to every crate in your dependency tree and all of them will be instrumented for coverage information as a result. This can result in an enormous amount of bloat with a full dependencies instrumented with counters that are often just 0 if it's library functionality you never use...

Still there is likely some room for me to minimise this some more... Out of curiosity have you tried with cargo-llvm-cov and seen if it hits similarly high memory usage?

@flavio
Copy link
Author

flavio commented Oct 23, 2024

Still there is likely some room for me to minimise this some more... Out of curiosity have you tried with cargo-llvm-cov and seen if it hits similarly high memory usage?

I've tried cargo-llvm-cov, it's memory consumption is significantly lower:

    Finished report saved to /home/flavio/hacking/kubernetes/kubewarden/kwctl/target/llvm-cov/html
	Command being timed: "cargo llvm-cov --html"
	User time (seconds): 1710.16
	System time (seconds): 34.59
	Percent of CPU this job got: 590%
	Elapsed (wall clock) time (h:mm:ss or m:ss): 4:55.32
	Average shared text size (kbytes): 0
	Average unshared data size (kbytes): 0
	Average stack size (kbytes): 0
	Average total size (kbytes): 0
	Maximum resident set size (kbytes): 3972312
	Average resident set size (kbytes): 0
	Major (requiring I/O) page faults: 995
	Minor (reclaiming a frame) page faults: 5570003
	Voluntary context switches: 86879
	Involuntary context switches: 423985
	Swaps: 0
	File system inputs: 136
	File system outputs: 12062096
	Socket messages sent: 0
	Socket messages received: 0
	Signals delivered: 0
	Page size (bytes): 4096
	Exit status: 0

flavio added a commit to flavio/kwctl that referenced this issue Oct 23, 2024
Switch to cargo-llvm-cov to collect code coverage results. This is
required because tarpaulin is consuming too much memory, leading to our
GHA being killed.

See xd009642/tarpaulin#1639 for more details.

Signed-off-by: Flavio Castelli <fcastelli@suse.com>
flavio added a commit to flavio/kwctl that referenced this issue Oct 23, 2024
Switch to cargo-llvm-cov to collect code coverage results. This is
required because tarpaulin is consuming too much memory, leading to our
GHA being killed.

See xd009642/tarpaulin#1639 for more details.

Signed-off-by: Flavio Castelli <fcastelli@suse.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants