-
Notifications
You must be signed in to change notification settings - Fork 5
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
Allow bridged providers to opt-in to sharding #1217
base: master
Are you sure you want to change the base?
Changes from 2 commits
89a0422
4f9db6c
c99ce21
6c50dd5
635117e
a0b5d12
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
|
@@ -258,7 +258,7 @@ bin/$(PROVIDER): .make/schema | |||||
|
||||||
test: export PATH := $(WORKING_DIR)/bin:$(PATH) | ||||||
test: | ||||||
cd examples && go test -v -tags=all -parallel $(TESTPARALLELISM) -timeout 2h | ||||||
cd #{{ .Config.E2ETestDirectory }}# && go test -v -tags=all -parallel $(TESTPARALLELISM) -timeout 2h | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Alternative design - proxy all test runs through your sharded test runner which could then apply the sharding in a single step, if needed:
Suggested change
The exact same change could be applied to the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
I've been thinking of See my comment here about integration tests in By default we can expect "slow" tests to live in one directory, but this doesn't have to be a requirement as long as the provider can eventually customize targets. With a root-level |
||||||
.PHONY: test | ||||||
|
||||||
test_provider: | ||||||
|
@@ -379,6 +379,15 @@ provider_dist-darwin-arm64: bin/$(PROVIDER)-v$(VERSION_GENERIC)-darwin-arm64.tar | |||||
provider_dist-windows-amd64: bin/$(PROVIDER)-v$(VERSION_GENERIC)-windows-amd64.tar.gz | ||||||
provider_dist: provider_dist-linux-amd64 provider_dist-linux-arm64 provider_dist-darwin-amd64 provider_dist-darwin-arm64 provider_dist-windows-amd64 | ||||||
.PHONY: provider_dist-linux-amd64 provider_dist-linux-arm64 provider_dist-darwin-amd64 provider_dist-darwin-arm64 provider_dist-windows-amd64 provider_dist | ||||||
|
||||||
#{{ if .Config.Shards -}}# | ||||||
# shard computes tests to run and modifies the CI runner's environment. | ||||||
shard: | ||||||
Comment on lines
+425
to
+426
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We can't use $(GITHUB_ENV) to modify the environment as that won't be runnable locally. I really think we want to leverage the single target that's integrated via the existing test target which might be a little more fiddly to write but makes it easier for the caller to repro exactly what CI did. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Totally agree with everything you're saying but would prefer to make those optimizations in a followup. It's nice that we manage the Makefile for these bridged providers because we're not locked in to anything here. It is possible to repro things locally by looking up the shard information
and you can generate that information yourself if you really want to ( So you can in theory run |
||||||
@(cd #{{ .Config.E2ETestDirectory }}# && go run github.com/blampe/shard@latest --total $(SHARD_TOTAL) --index $(SHARD_INDEX) --output env) >> "$(GITHUB_ENV)" | ||||||
blampe marked this conversation as resolved.
Show resolved
Hide resolved
|
||||||
|
||||||
# test_shard runs the tests specified by a regex contained in $SHARD_TESTS for paths $SHARD_PATHS. | ||||||
test_shard: | ||||||
cd #{{ .Config.E2ETestDirectory }}# && \ | ||||||
go test -tags=all -v -count=1 -coverprofile="coverage.txt" -coverpkg=./... -timeout 3h -parallel ${TESTPARALLELISM} -run "$(SHARD_TESTS)" $(SHARD_PATHS) | ||||||
#{{- end }}# | ||||||
# Permit providers to extend the Makefile with provider-specific Make includes. | ||||||
include $(wildcard .mk/*.mk) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we can make this less repetitive in the generated code by doing the touch and install outside the loop and leveraging the phony grouping targets.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Additionally, we could allow the "Download SDK" action to accept multiple languages (e.g. comma separated or something) to make the call sight cleaner and more understandable.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Totally forgot about
install_sdks
, good call!