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

improvement: add debug adapter for running main class to metals #6383

Merged
merged 6 commits into from
Jun 28, 2024

Conversation

kasiaMarek
Copy link
Contributor

connected to: #5928
requires scalacenter/scala-debug-adapter#704 first

@Arthurm1
Copy link
Contributor

@kasiaMarek It's great that Metals will be able to debug without the BSP server having to support it.

In MainClassDebugAdapter you setup a process to run the mainclass and pass java options of -agentlib:jdwp=transport=dt_socket,server=y,suspend=y,quiet=n which makes sense.

Why not use the BSP buildTarget/run call instead? You can specify the above jvmOptions in ScalaMainClass.

It wouldn't simplify running main classes much but then you can debug tests in the same way using buildTarget/test. Metals wouldn't need to know anything about which test framework it's using.

@kasiaMarek kasiaMarek force-pushed the debug-adapter branch 2 times, most recently from 2dfe4b4 to a641cf6 Compare May 20, 2024 10:40
@kasiaMarek
Copy link
Contributor Author

Sorry for taking so long to write back, it slipped my mind.

Why not use the BSP buildTarget/run call instead?

We can do that but as you've noticed there isn't much of a benefit to it.

you can debug tests in the same way using buildTarget/test

We need events, if we just run the test like this we'd only get the output. So it's not really an easier option. (But I feel like I only have a partial understanding of this so correct if I'm wrong.)

@Arthurm1
Copy link
Contributor

Arthurm1 commented May 21, 2024

We need events, if we just run the test like this we'd only get the output. So it's not really an easier option. (But I feel like I only have a partial understanding of this so correct if I'm wrong.)

Do you mean test events? You'd get those through BSP Test Report messages.

Does Metals currently discover/run tests itself rather than delegating to BSP?

I'd argue that it's the Build Server's responsibility to do this as it should already understand the test frameworks it supports and then Metals doesn't have to understand any test frameworks, however BSP doesn't allow test discovery at the method level (only class level) and I can't currently see how it's possible to obtain location in the Gradle BSP which is fairly key in tracing failed tests. So I'm wondering if tests in BSP can't actually deliver as good a user experience as tests in Metals can.

EDIT: I don't think there's a way to send back stacktraces of failed tests from BSP either.

@kasiaMarek
Copy link
Contributor Author

kasiaMarek commented May 24, 2024

You'd get those through BSP Test Report messages.

Oh, yes, that should in theory work. But besides the inability to run only test selection there seem to be other issues there. The biggest is that the run output gets send to onBuildLogMessage, so it's hard distinguish it from any other logs. In theory there exists OnRunPrintStdout but I don't think any of the build servers actually use that. Bloop and sbt do not send Test Reports and looking at the code both sbt and mill seem to ignore java options send for running tests (but trying to test it on mill I run into other issues). I don't know how the situation looks for gradle but it seems that having the build servers obey specification (and more if we want test selection) might be more effort than running things from metals.

Does Metals currently discover/run tests itself rather than delegating to BSP?

I think we simply always start debug server to run tests.

@Arthurm1
Copy link
Contributor

Ah - I hadn't realised that the build tools don't even send back TestReports. Probably best to just handle it all within Metals I guess.

@kasiaMarek kasiaMarek marked this pull request as ready for review May 28, 2024 08:09
@kasiaMarek kasiaMarek requested a review from tgodzik May 28, 2024 08:09
Copy link
Contributor

@tgodzik tgodzik left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great work! I added some mostly minor comments


val optClasspath =
buildTargets
.targetClasspath(id, cancelPromise)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
.targetClasspath(id, cancelPromise)
.targetJarClasspath(id, cancelPromise)

would not be good enough? Or is it due to the mill issue?

@kasiaMarek kasiaMarek force-pushed the debug-adapter branch 3 times, most recently from 8a4e818 to 6b83c95 Compare June 26, 2024 09:37
@kasiaMarek kasiaMarek requested a review from tgodzik June 26, 2024 12:53
Copy link
Contributor

@tgodzik tgodzik left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Two minor comments otherwise LGTM

_ <- compilations.compileTargets(params.getTargets().asScala.toSeq)
} yield {
val debuggee = getDebugee.getOrElse(
throw new RuntimeException(s"Can't resolve debugee")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This will most likely be thrown back to the user, so best to have some along the lines of Cannot resolve main class etc. The more information the better.

Copy link
Contributor

@tgodzik tgodzik left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM!

@kasiaMarek kasiaMarek merged commit f116e13 into scalameta:main Jun 28, 2024
24 checks passed
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

Successfully merging this pull request may close these issues.

3 participants