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

Unknown source debugging attached java process #1469

Open
BroadLux opened this issue Apr 22, 2024 · 2 comments
Open

Unknown source debugging attached java process #1469

BroadLux opened this issue Apr 22, 2024 · 2 comments

Comments

@BroadLux
Copy link

When attaching to a Java process built with a custom bazel-based build system, the Java debugger can't resolved source even though the file is open, reporting "Unknown source".

Environment
  • Operating System: Windows 11 Enterprise locally, Linux remotely.
  • JDK version: Adoptium Temurin-17 (tried 21 as well)
  • Visual Studio Code version: 1.85.2
  • Java extension version: v0.57.0
  • Java Debugger extension version: v0.26.0 (extension pack)
  • Language support for Java by Red Hat: v1.29.0
Steps To Reproduce
  1. Start Visual Studio Code and connect to the SSH host.
  2. In Terminal, build (using proprietary bazel-based build system).
  3. In Terminal, change to the directory where the result JARs are produced.
  4. Open the source file with the main function (Pos001.java, in this case).
  5. Create a java attach-to-process debugger config. No special settings, just type, name, request, processId set as:
    "type": "java", "name": "Java attach to process", "projectName": "acquiretokenbyuserid", "request": "attach", "processId":"${command:PickJavaProcess}",
  6. Run main in the target class using typical attach to process parameters as shown below. It is waiting for a keystroke.
    java -agentlib:jdwp=transport=dt_socket,server=y,address=5005 -verbose -cp "./*" packagename1.packagename2.Pos001
  7. In Visual Studio, attach to the process and set a breakpoint just after where the code is waiting for the keystroke.
  8. In the Terminal window where the process was run, press enter.

Logs: LanguageServerLogFile.txt
I can't provide source or project, sorry.

Current Result

Call stack reports Unknown source and the current source line is not highlighted. The call stack does correctly report the filename and line number of where the program is, so you can manually scroll through. Stepping through and further breakpoints work normally, just with this limitation.

Expected Result

Debugger should highlight the current line and recognize the open file in the editor as the correct source. Or at least, it should behave as Real Visual Studio, asking me "should I use this file?" or allowing me to browse for it.

Additional Informations
  1. Language Support for Java window reports several instances of the following:
    [Error - 6:19:42 PM] Apr 21, 2024, 6:19:42 PM _/lotus-qe/core-pfs/src/test/java/sts/acquiretokenbyuserid [in rpsmain2_f021ed] does not exist _/lotus-qe/core-pfs/src/test/java/sts/acquiretokenbyuserid [in rpsmain2_f021ed] does not exist Java Model Exception: Error in Java Model (code 969): _/lotus-qe/core-pfs/src/test/java/sts/acquiretokenbyuserid [in rpsmain2_f021ed] does not exist at org.eclipse.jdt.internal.core.JavaElement.newNotPresentException(JavaElement.java:562) at org.eclipse.jdt.internal.core.PackageFragmentRoot.getUnderlyingResource(PackageFragmentRoot.java:764) at org.eclipse.jdt.internal.core.PackageFragment.getUnderlyingResource(PackageFragment.java:430) at org.eclipse.jdt.internal.core.Openable.getUnderlyingResource(Openable.java:328) at org.eclipse.jdt.internal.core.CompilationUnit.getUnderlyingResource(CompilationUnit.java:975) at org.eclipse.jdt.ls.core.internal.handlers.BaseDiagnosticsHandler.collectNonJavaProblems(BaseDiagnosticsHandler.java:149) at org.eclipse.jdt.ls.core.internal.handlers.BaseDiagnosticsHandler.endReporting(BaseDiagnosticsHandler.java:135) at org.eclipse.jdt.internal.core.ReconcileWorkingCopyOperation.reportProblems(ReconcileWorkingCopyOperation.java:141) at org.eclipse.jdt.internal.core.ReconcileWorkingCopyOperation.executeOperation(ReconcileWorkingCopyOperation.java:110) at org.eclipse.jdt.internal.core.JavaModelOperation.run(JavaModelOperation.java:740) at org.eclipse.jdt.internal.core.JavaModelOperation.runOperation(JavaModelOperation.java:805) at org.eclipse.jdt.internal.core.CompilationUnit.reconcile(CompilationUnit.java:1311) at org.eclipse.jdt.ls.core.internal.handlers.BaseDocumentLifeCycleHandler.publishDiagnostics(BaseDocumentLifeCycleHandler.java:332) at org.eclipse.jdt.ls.core.internal.handlers.BaseDocumentLifeCycleHandler.publishDiagnostics(BaseDocumentLifeCycleHandler.java:295) at org.eclipse.jdt.ls.core.internal.handlers.BaseDocumentLifeCycleHandler$PublishDiagnosticJob.run(BaseDocumentLifeCycleHandler.java:777) at org.eclipse.core.internal.jobs.Worker.run(Worker.java:63)
  2. There's no maven or gradle files in this project, it uses a custom bazel-based build.
  3. Disabled Maven and Gradle project import, but this seems to make no difference. Debugger appears built to require these.
  4. Set sourcePaths in debugger config, no help.
  5. If it matters, JDK is configured via java.jdt.ls.java.home in settings.json on remote host.
@testforstephen
Copy link
Contributor

The debugger leverages the RedHat Java language server to recoginize the Java project and get the source mapping, which doesn't provide the native support for bazel build tool. You may have a try on this bazel language support extension. https://marketplace.visualstudio.com/items?itemName=sfdc.bazel-vscode-java

@BroadLux
Copy link
Author

BroadLux commented May 7, 2024

Is there any way to inform the Red Hat engine of where the source files are directly?

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

No branches or pull requests

2 participants