-
Notifications
You must be signed in to change notification settings - Fork 388
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
feat(gnovm): add gno test parallel package testing #3431
base: master
Are you sure you want to change the base?
Conversation
Signed-off-by: gfanton <8671905+gfanton@users.noreply.github.com>
Signed-off-by: gfanton <8671905+gfanton@users.noreply.github.com>
Signed-off-by: gfanton <8671905+gfanton@users.noreply.github.com>
🛠 PR Checks SummaryAll Automated Checks passed. ✅ Manual Checks (for Reviewers):
Read More🤖 This bot helps streamline PR reviews by verifying automated checks and providing guidance for contributors and reviewers. ✅ Automated Checks (for Contributors):🟢 Maintainers must be able to edit this pull request (more info) ☑️ Contributor Actions:
☑️ Reviewer Actions:
📚 Resources:Debug
|
Signed-off-by: gfanton <8671905+gfanton@users.noreply.github.com>
Signed-off-by: gfanton <8671905+gfanton@users.noreply.github.com>
37424f8
to
707182e
Compare
Codecov ReportAttention: Patch coverage is
📢 Thoughts on this report? Let us know! |
Signed-off-by: gfanton <8671905+gfanton@users.noreply.github.com>
gnovm/cmd/gno/test.go
Outdated
&c.parallel, | ||
"parallel", | ||
1, | ||
"number of package to run concurrently (default(1): sequentially); 0 = GOMAXPROCESS", |
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.
It could be great to run tests in parallel within the same package as well. A recent change I made was to ensure each test is independent; if there is a global variable, it is always set up again. This is probably easy to implement.
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've tried to run them separately; it doesn't seem to work. Also, quoting @thehowl comment, it should require deeper changes
from gnovm/pkg/test/test.go
:
// TODO(morgan): we could theoretically use wrapping on the baseStore
// and gno store to achieve per-test isolation. However, that requires
// some deeper changes, as ideally we'd:
// - Run the MemPackage independently (so it can also be run as a
// consequence of an import)
// - Run the test files before this for loop (but persist it to store;
// RunFiles doesn't do that currently)
// - Wrap here.
Signed-off-by: gfanton <8671905+gfanton@users.noreply.github.com>
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.
Some preliminary comments
@@ -52,7 +52,7 @@ jobs: | |||
echo "LOG_LEVEL=debug" >> $GITHUB_ENV | |||
echo "LOG_PATH_DIR=$LOG_PATH_DIR" >> $GITHUB_ENV | |||
- run: go install -v ./gnovm/cmd/gno | |||
- run: go run ./gnovm/cmd/gno test -v -print-runtime-metrics -print-events ./examples/... | |||
- run: go run ./gnovm/cmd/gno test -parallel=0 -v -print-runtime-metrics -print-events ./examples/... |
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.
why specify this?
t.Fatal(err) | ||
} | ||
} | ||
// func TestStdlibs(t *testing.T) { |
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.
If we don't have this, then the tests in the standard libraries doesn't count as coverage, and I think it should
maxWorkers := runtime.GOMAXPROCS(0) | ||
if cfg.parallel > 0 { | ||
maxWorkers = cfg.parallel | ||
} |
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.
} | |
} | |
maxWorkers = min(maxWorkers, subPkgs) |
if hasError || err != nil { | ||
if err != nil { | ||
io.ErrPrintfln("%s: test pkg: %v", pkg.Dir, err) | ||
if err := sem.Acquire(ctx, 1); err != nil { |
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.
This could be a channel where you write at the beginning ch <- struct{}{}
and do a defer func() { <- ch }
at the end.
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.
We need to make the output buffered for each test if maxWorkers > 1, so that the full output of a package is all printed together rather than being mixed with that of other tests.
This PR improves the speed of running
gnovm
tests.stdlibs
tests fromgnovm
go tests by usinggno test
directly in separate job on the CI.parallel
package test flags forgno test
.As a result, this PR reduces the test time of the gnovm test suite to below
5m
.