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

Test coverage support #1

Open
caseyduquettesc opened this issue Jul 28, 2022 · 4 comments
Open

Test coverage support #1

caseyduquettesc opened this issue Jul 28, 2022 · 4 comments

Comments

@caseyduquettesc
Copy link
Owner

caseyduquettesc commented Jul 28, 2022

Via slack:

In this case, I got pytest-style tests working using https://github.com/caseyduquettesc/rules_python_pytest. It works, and I can even set up a github actions module to list the test results; all happy. So of course I'm greedy and want to use it for coverage too 🙂 I know the "approved" answer for Python coverage (the "modified version of coverage.py") but passing the "--cov" and "--cov-report=xml" gives me the nice test output Coverage XML written to file coverage.xml.
...of course that file is nowhere to be found; bazel-out obligingly has an appropriate test.xml (because of the argument --junit-xml=$$XML_OUTPUT_FILE to the pytest rule). And the file probably is being generated but somehow not being exported, and I'm new enough to bazel to not quite understand what's happening (or not).
Where should I start looking?

Related issues:
bazelbuild/rules_python#43
bazelbuild/bazel#10660

@caseyduquettesc
Copy link
Owner Author

Code coverage didn't even occur to me when writing rules_pytest. Seems like something that should be doable in theory. I've used pytest-cov before. Should be able to hook that up to pytest and get the report for bazel.

@basilnsage
Copy link

I'm interested in taking a stab at this. Any thoughts what a nice change to the rule signature might be? I'm not sure if

  • exposing a new boolean parameter cover and using default pytest-cov arguments
    or
  • exposing pytest-cov arguments to the caller
    or something else... is better.

@caseyduquettesc
Copy link
Owner Author

caseyduquettesc commented Aug 3, 2022

I need to read up on how bazel exposes it's running coverage before offering up an opinion. I think the thing we need to keep in mind is that this is going to be generating coverage reports for individual targets and we need bazel to merge them. The mechanism, I don't have an understanding of yet.

Purely from a user interface standpoint, I would expect bazel coverage //:py_test to generate the coverage data for target :py_test. This means turning coverage on or off implicitly for the user and not through an attribute on the rule.

I don't have a great answer to how to customize the coverage options off the top of my head.

bazelbuild/bazel#10660 (comment) seems like a really good starting point, though a little outdated.

According to pytest-dev/pytest-cov#536, coverage.py gained lcov support (https://coverage.readthedocs.io/en/6.4.2/cmd.html#cmd-lcov), so coverage-lconv shouldn't be necessary.

Current documentation for enabling test coverage, though looks hacky to me - https://bazel.build/docs/coverage#python

@WSUFan
Copy link

WSUFan commented Jan 10, 2025

one way is to write a genrule to copy this

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

3 participants