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

Use integration tests to generate coverage #1516

Closed
yurishkuro opened this issue May 5, 2019 · 7 comments · Fixed by #4964
Closed

Use integration tests to generate coverage #1516

yurishkuro opened this issue May 5, 2019 · 7 comments · Fixed by #4964
Labels
good first issue Good for beginners help wanted Features that maintainers are willing to accept but do not have cycles to implement

Comments

@yurishkuro
Copy link
Member

yurishkuro commented May 5, 2019

The plugin/storage/integration tests are using STORAGE env var to decide which tests to run. It makes sense for tests that require external storage, but badger/grpc-plugin are currently not running at all.

I propose the following changes:

  • always run Badger tests
  • always run grpc-plugin tests, but look for env variable pointing to the plugin binary path (to address [this comment](address https://github.com/jaegertracing/jaeger/pull/1461/files#r280031679))
  • use -coverpkg directive to generate test coverage for the actual packages, and merge it with overall coverage (codecov.io allows submitting multiple reports from CI job)
@yurishkuro yurishkuro added good first issue Good for beginners help wanted Features that maintainers are willing to accept but do not have cycles to implement labels May 5, 2019
@Beachyesh
Copy link

I see that this issue has been added as a good first issue, I'm new to contributing, how may I help? Please let me know, thanks!

@yurishkuro
Copy link
Member Author

Help is appreciated. What kind of assistance are you looking for?

@yurishkuro
Copy link
Member Author

Perhaps an even better way would be to change the tests from using integration build tag to have specific tag for each storage type, so that we don't even run irrelevant tests.

@rbroggi
Copy link
Contributor

rbroggi commented Oct 27, 2021

Dear @yurishkuro , I'm a first-timer here in Jaeger and as much as I work a bit with it and went through some documentation I'm not yet familiar with the code. This change sounds pretty straightforward. Some questions I had while trying to understand your suggested change:

  1. Concerning your last comment around integration build tag - I see no build tag in any of the tests under the path plugin/storage/integration/. Are you suggesting to introduce different build tag for each of the tests under plugin/storage/integration/badgerstore_test.go and adapt the commands in the Makefile?

e.g.:

in plugin/storage/integration/badgerstore_test.go

// Copyright...
//go:build storage-integration-badge
// +build storage-integration-badge

...

and in Makefile

.PHONY: badger-storage-integration-test
badger-storage-integration-test:
		bash -c "set -e; set -o pipefail; $(GOTEST) -tags=storage-integration-badge $(STORAGE_PKGS) | $(COLORIZE)"

??

  1. When you say that

badger/grpc-plugin are currently not running at all

you mean in the context of CI? github actions? In github actions I could see that there is a workflow (ci-memory-badger.yml) that runs the make target:

make mem-and-badger-storage-integration-test
.PHONY: mem-and-badger-storage-integration-test
mem-and-badger-storage-integration-test: badger-storage-integration-test grpc-plugin-storage-integration-test

.PHONY: badger-storage-integration-test
badger-storage-integration-test:
	STORAGE=badger $(MAKE) storage-integration-test

.PHONY: grpc-plugin-storage-integration-test
grpc-plugin-storage-integration-test:
	(cd examples/memstore-plugin/ && go build .)
	STORAGE=grpc-plugin $(MAKE) storage-integration-test

I was willing to contribute to Jaeger in the scope of the hacktoberfest and beyond, maybe we are too close to meet the deadline for hacktober fast but I'm willing to help the project anyways :)

@rbroggi
Copy link
Contributor

rbroggi commented Oct 27, 2021

OK I just realize that you addressed many of the issues in the PR2474.

Is there something else to be done? maybe the -coverpkg?

I see you are using go tool cover in the Makefile to handle the coverability. I guess we need to update the part of CONTRIBUTING.md mentioning ./scripts/cover.sh file (which does no longer exist).

@yurishkuro
Copy link
Member Author

@rbroggi Yes your understanding about the build tags proposal is accurate. Right now we don't use build tags and instead control storage integrations via ENV var, which is weird since the all run all the time.

My PR #2474 didn't fix it, just added the other tests (which are fairly light weight) to also run all the time, to at least have them always executed one way or another.

@rbroggi
Copy link
Contributor

rbroggi commented Oct 27, 2021

Dear @yurishkuro , I will try to work on that tomorrow (I'm currently based in France so time to go to bed :) ). Thank you for the update and clarifications

rbroggi added a commit to rbroggi/jaeger that referenced this issue Oct 28, 2021
* introduction of build tags [grpc_plugin_storage_integration, badger_storage_integration] for better control over badgerstore_test.go and grpc_test.go  which being fairly light-weight can be run along with the main make target `test`
rbroggi added a commit to rbroggi/jaeger that referenced this issue Oct 28, 2021
* introduction of build tags [grpc_plugin_storage_integration, badger_storage_integration] for better control over badgerstore_test.go and grpc_test.go  which being fairly light-weight can be run along with the main make target `test`

Signed-off-by: rbroggi <[email protected]>
rbroggi added a commit to rbroggi/jaeger that referenced this issue Oct 29, 2021
* introduction of build tags [grpc_plugin_storage_integration, badger_storage_integration] for better control over badgerstore_test.go and grpc_test.go  which being fairly light-weight can be run along with the main make target `test`

Signed-off-by: rbroggi <[email protected]>
yurishkuro added a commit that referenced this issue Oct 30, 2021
- introduce build tags grpc_storage_integration, badger_storage_integration, and memory_storage_integration for better control over badgerstore_test.go and grpc_test.go
- run memory storage test as part of make-test, and run badger/grpc in a separate CI workflow

Part of Use integration tests to generate coverage #1516

Signed-off-by: rbroggi <[email protected]>

Signed-off-by: Yuri Shkuro <[email protected]>

Co-authored-by: Yuri Shkuro <[email protected]>
yurishkuro added a commit that referenced this issue Nov 25, 2023
…4964)

## Which problem is this PR solving?
- Some of our code is not testable unless we run integration tests, e.g.
places that require db connection
- But we don't collect coverage from integration tests
- Resolves #1516
- Resolves #4965

## Description of the changes
- Add coverage generation to storage tests and upload to codecov
- Remove several `.nocover` since their packages are now included in
coverage via integration tests anyway. Add corresponding `empty_test.go`
to avoid linter error.
- Remove `println` from badger & sampling storage integration
- Change COLORIZE macro to include `| ...` so that it can be overwritten
to nothing for faster std output. When output is piped, even to `| cat
-`, the buffering prevents incremental test output, so one cannot easily
observe test progress

## How was this change tested?
- CI is green
- [Comment below by
codecov](#4964 (comment))
shows 11 reports (inside expander, Flags table)
- The global code coverage dropped -0.82%, which is not surprising since
some previously excluded packages are now counted, but not all the code
in them is exercised even in integration tests (e.g. kafka/auth/tls.go).
However, we can ramp it up in future PRs. One area that seems
particularly neglected is calling Close on the storage from integration
tests, which we're not doing.

---------

Signed-off-by: Yuri Shkuro <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
good first issue Good for beginners help wanted Features that maintainers are willing to accept but do not have cycles to implement
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants