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

Allow "subtest at cursor" to work with table-driven test setup #1602

Open
schandra157 opened this issue Jul 2, 2021 · 19 comments
Open

Allow "subtest at cursor" to work with table-driven test setup #1602

schandra157 opened this issue Jul 2, 2021 · 19 comments
Labels
FeatureRequest Go Companion Issues relating to the Go Companion extension go-test issues related to go test support (test output, test explorer, ...) gopls gopls related issues

Comments

@schandra157
Copy link

schandra157 commented Jul 2, 2021

Related issues

Issue Work to be done
#2445 Statically detect simple table-driven tests
This issue Support "run at cursor" for entries in a table
#1734 Let the user manually enter a test or subtest name to execute

Is your feature request related to a problem? Please describe.

In the case of Table driven Test model in GO programming, Currently, it's possible to run/debug test at the Function level. It would be great if its possible to be executed at the individual test level

Describe the solution you'd like
Have an option to Run and Debug at each individual Test level, which would be great to debug the individual test in case of issue and would be very handy feature

Additional context

The below Screen shot describes the problem
Screenshot 2021-07-02 at 2 23 31 PM

@gopherbot gopherbot added this to the Untriaged milestone Jul 2, 2021
@schandra157 schandra157 changed the title Able to Run/debug individual test-case isn table driven test model in Go Test files Able to Run/debug individual test-case isnt possible in table driven test model in Go Test files Jul 2, 2021
@findleyr
Copy link
Member

findleyr commented Jul 7, 2021

Hi, this feature is available:
https://github.com/golang/vscode-go/blob/master/docs/commands.md#go-subtest-at-cursor

Does that meet your needs?

@findleyr findleyr added the WaitingForInfo Issue is not actionable because of missing required information, which needs to be provided. label Jul 7, 2021
@suzmue
Copy link
Contributor

suzmue commented Jul 7, 2021

Unfortunately, "Go: subtest at cursor" is pretty limited at the moment and does not work with table driven tests. Where would you expect the code lens to appear? In the definition of tests? On t.Run (with some way to specify which subtest)?

It would be reasonable for Go: subtest at cursor to request a subtest name via an input box if it cannot find a simple test name.

Issue #1579 is tracking updates to testing support for this extension, which may add some support for easier subtest running.

@schandra157
Copy link
Author

Hi, this feature is available:
https://github.com/golang/vscode-go/blob/master/docs/commands.md#go-subtest-at-cursor

Does that meet your needs?

Yes, it will be helping us a lot.

@schandra157
Copy link
Author

Unfortunately, "Go: subtest at cursor" is pretty limited at the moment and does not work with table driven tests. Where would you expect the code lens to appear? In the definition of tests? On t.Run (with some way to specify which subtest)?

It would be reasonable for Go: subtest at cursor to request a subtest name via an input box if it cannot find a simple test name.

Issue #1579 is tracking updates to testing support for this extension, which may add some support for easier subtest running.

Glad to see some Ideas around this, My opinion is to have code lens appear at definition of the test

@findleyr
Copy link
Member

findleyr commented Jul 8, 2021

We couldn't do this in generality (for example if the test cases were outside the function scope), but it wouldn't be hard for gopls to provide code lenses for the common patterns of a slice of test cases in the function scope, or ranging over a literal.

We could add this feature as part of our migration to use gopls for generating test code lens.

@schandra157
Copy link
Author

okay

@hyangah hyangah changed the title Able to Run/debug individual test-case isnt possible in table driven test model in Go Test files Allow "subtest at cursor" to work with table-driven test setup Jul 13, 2021
@hyangah hyangah added FeatureRequest and removed WaitingForInfo Issue is not actionable because of missing required information, which needs to be provided. labels Jul 13, 2021
@hyangah hyangah modified the milestones: Untriaged, Backlog Jul 13, 2021
@hyangah
Copy link
Contributor

hyangah commented Jul 13, 2021

I guess users will still want to enter or select the subtest name after clicking a codelens. Currently, I don't think LSP's codelens+command allows that level of UX control yet. So the extension will need a middleware hack or the actual codelens implementation (based on info from gopls) if we want to implement it soon.

@gopherbot
Copy link
Collaborator

Change https://golang.org/cl/333309 mentions this issue: src/goTest.ts: prompt for subtest name if there is no subtest at cursor

@firelizzard18
Copy link
Contributor

@schandra157 Once VSCode's testing API is finalized and #1579 is merged, you will be able to see specific subtests, though there are some limitations. Discovering subtests statically is problematic, so at the moment, I add subtests while running a test, any time I see a go test event with a test name that indicates a subtest, such as TestFoo/Bar. Since the set of defined subtests can change without notice (from the extension's perspective), I wipe out the subtests of a test whenever it is run, or whenever VSCode reports the test function was edited.

So the test explorer will list subtests. But every feasible method I can think of for discovering where a subtest was defined has edge cases that wouldn't work. And the only method I can think of that would always work would involve executing the code, which is not really something we can feasibly do at the moment. go test does not tell you where a test or a subtest was defined, and that's the only 'execute the code' method I consider feasible. I opened golang/go#47101 to discuss adding a core package such as go/test that might facilitate this kind of thing.

What we can recognize (probably)

  • t.Run("SubTest", func(*testing.T) { ... })
  • Table driven tests using obvious patterns
  • Test suites such as those defined by stretchr

What won't work

  • t.Run(fmt.Sprint(foo, bar baz), ...) - without resorting to executing code or building an interpreter, how would we know what the test name was?
  • Table driven tests using non-obvious patterns - again, without resorting to executing or interpreting code, it can be very difficult to determine subtest names etc.
  • Other non-obvious patterns - same issue.

gopherbot pushed a commit that referenced this issue Jul 16, 2021
Updates #1602

Change-Id: Ibcea9c5980c6c08257f0c6925502eb0b9fd00cdb
Reviewed-on: https://go-review.googlesource.com/c/vscode-go/+/333309
Trust: Suzy Mueller <[email protected]>
Trust: Hyang-Ah Hana Kim <[email protected]>
Reviewed-by: Hyang-Ah Hana Kim <[email protected]>
@firelizzard18 firelizzard18 mentioned this issue Jul 21, 2021
12 tasks
@pckhoi
Copy link

pckhoi commented Aug 28, 2021

How about a simpler solution such as adding command Go: Test -run that display an input box where you can specify -run flag directly? That would work for all edge cases.

@firelizzard18
Copy link
Contributor

@pckhoi It's not clear to me that such a command would provide value. The user can already run go test -run on the command line. What improvement does running that via a command provide?

@pckhoi
Copy link

pckhoi commented Aug 30, 2021

Except I never run tests on the command line anymore but mostly rely on "Go: Test Package" command. Sure I could run things on the command line but I also lose any integration with vscode, including custom settings I have defined in go.testEnvVars and go.testFlags. I have attempted to put -run flag in go.testFlags but it still proves cumbersome and prone to be committed by mistake. Adding a command that allows you to define -run flag each time will allow people to easily run sub-tests reliably while still having things integrated with vscode such as code coverage.

@firelizzard18
Copy link
Contributor

@pckhoi I suggest you open a separate feature request, including your explanation here. "Add a command that allows me to specify a custom value for the -run flag" is a different feature from "Add support for table-driven subtests to the 'subtest at cursor' command".

The can both be used for similar purposes, but they take a fundamentally different approach, and must be implemented differently. Plus, if I can find a way to detect table-driven tests, this issue will likely be closed as resolved.

@marjau
Copy link

marjau commented Nov 20, 2023

I'm coming from Goland(JetBrains). Digging a bit, I realized that we can run a specific test case into a table-driven. This seems to be related to the topic:

  1. Put the cursor inside the TestFunction
  2. In the command line, look for: "Go: Debug Subset at Cursor"
  3. Write the specific name of the test case

Ref: https://github.com/golang/vscode-go/blob/master/docs/commands.md#go-subtest-at-cursor

I hope it helps to someone.

@hyangah hyangah added the go-test issues related to go test support (test output, test explorer, ...) label Dec 5, 2023
@vec715
Copy link

vec715 commented Jul 23, 2024

any updates?

@gopherbot
Copy link
Collaborator

Change https://go.dev/cl/601015 mentions this issue: gopls/internal/cache/tests: detect simple subtests

@gopherbot
Copy link
Collaborator

Change https://go.dev/cl/548675 mentions this issue: gopls/internal: test discovery

gopherbot pushed a commit to golang/tools that referenced this issue Sep 10, 2024
Implements test discovery. Tests are discovered as part of the type
checking process, at the same time as method sets and xrefs, and cached.
Does not implement the Modules command.

Adds static detection of simple subtests. This provides a framework for
static analysis of subtests but intentionally does not support more than
the most trivial case in order to minimize the complexity of this CL.

Fixes golang/go#59445. Updates golang/go#59445, golang/vscode-go#1602,
golang/vscode-go#2445.

Change-Id: Ief497977da09a1e07831e6c5f3b7d28d6874fd9f
Reviewed-on: https://go-review.googlesource.com/c/tools/+/548675
Reviewed-by: Alan Donovan <[email protected]>
Reviewed-by: Robert Findley <[email protected]>
Auto-Submit: Robert Findley <[email protected]>
LUCI-TryBot-Result: Go LUCI <[email protected]>
@firelizzard18
Copy link
Contributor

firelizzard18 commented Oct 3, 2024

It is feasible for gopls to add static detection of simple table-driven subtests. However since #2445 already exists, I think it is better for this issue to be more specifically about: "As a user, when I have selected a table entry of a table driven test, I want Run at cursor to run the subtest for that entry". This will require a change to gopls' API: it will need to be able to report both the test function location and the table entry location.

@firelizzard18 firelizzard18 added gopls gopls related issues Go Companion Issues relating to the Go Companion extension labels Oct 3, 2024
@qdm12
Copy link

qdm12 commented Oct 4, 2024

Small note regarding the test entry location: I use map[string]struct{...} for my test cases (key=subtest name, value=test case parameters) instead of the more traditional []struct{...}, so it would be nice to support both slices and maps for "table" entries. Thanks, and hoping to see this issue resolved 🙏

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
FeatureRequest Go Companion Issues relating to the Go Companion extension go-test issues related to go test support (test output, test explorer, ...) gopls gopls related issues
Projects
Status: No status
Development

No branches or pull requests

10 participants