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

Issue Jenkins-36718 - Fix DM_DEFAULT_ENCODING scanned by spotbugs #9784

Open
wants to merge 11 commits into
base: master
Choose a base branch
from

Conversation

programbeginnerTW
Copy link
Contributor

@programbeginnerTW programbeginnerTW commented Sep 25, 2024

See JENKINS-36718.

Testing done

  • Clean compiled
  • Manually tested Jenkins core as well as spotbugs to ensure no DM_DEFAULT_ENCODING remains.
  • Specify using UTF-8 encoding to prevent relative problems.
  • Run all SpotBugs check to proof the warnings were tackled.

Proposed changelog entries

  • Fixed encoding issues in consoleNote.java, WindowsServiceLifecycle.java, and Textfile.java by specifying UTF-8 encoding instead of system default.

Proposed upgrade guidelines

N/A

Submitter checklist

Preview Give feedback

Before the changes are marked as ready-for-merge:

Maintainer checklist

Preview Give feedback

@programbeginnerTW
Copy link
Contributor Author

@oleg-nenashev , I saw this issue on Jira and mentioned you in the article. JENKINS-36718
Could you review this, please 🥹

@programbeginnerTW programbeginnerTW marked this pull request as draft November 3, 2024 01:18
@programbeginnerTW programbeginnerTW marked this pull request as ready for review November 3, 2024 01:20
@programbeginnerTW programbeginnerTW marked this pull request as draft November 3, 2024 01:38
@programbeginnerTW programbeginnerTW marked this pull request as ready for review November 3, 2024 01:48
@oleg-nenashev oleg-nenashev self-requested a review November 3, 2024 09:45
@oleg-nenashev
Copy link
Member

@programbeginnerTW thank for the pull request. I'm yet to return to the Jenkins core maintenance after a long sabbatical. I will try to take a look when I have a bit of a time, but there are also many other core maintainers around so you shouldn't depend on my response

Generally, I need to refresh my memory what will the agreements on default encoding. Using anything except system default is a potential breaking change. Maybe this it is safer to just use default

1 similar comment
@oleg-nenashev
Copy link
Member

@programbeginnerTW thank for the pull request. I'm yet to return to the Jenkins core maintenance after a long sabbatical. I will try to take a look when I have a bit of a time, but there are also many other core maintainers around so you shouldn't depend on my response

Generally, I need to refresh my memory what will the agreements on default encoding. Using anything except system default is a potential breaking change. Maybe this it is safer to just use default

Copy link

@A1exKH A1exKH left a comment

Choose a reason for hiding this comment

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

@programbeginnerTW, could you resolve warning for this PR, please?

@@ -194,7 +194,7 @@ public void encodeTo(OutputStream out) throws IOException {
* encoding is ASCII compatible.
*/
public void encodeTo(Writer out) throws IOException {
out.write(encodeToBytes().toString());
out.write(new String(encodeToBytes().toByteArray(), StandardCharsets.UTF_8));
Copy link

Choose a reason for hiding this comment

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

@programbeginnerTW Could you please check this warning message, please?

Check warning on line 197 in core/src/main/java/hudson/console/ConsoleNote.java

Copy link
Contributor Author

Choose a reason for hiding this comment

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

@A1exKH Thanks for the reply,

Seems the coverage shrunk in this modification, the previous scan was 2, and now 1 has missed.
Should I simply add a new test for it? Or should I revise and review if there's anything I can do?

Copy link

@A1exKH A1exKH left a comment

Choose a reason for hiding this comment

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

@programbeginnerTW
Copy link
Contributor Author

Thanks a lot! @A1exKH
Perhaps I can consider this PR finished?

Copy link
Contributor

@zbynek zbynek left a comment

Choose a reason for hiding this comment

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

Since the warnings are fixed they should no longer be excluded via https://github.com/jenkinsci/jenkins/blob/master/core/src/spotbugs/excludesFilter.xml#L185

@@ -224,7 +224,8 @@ private ByteArrayOutputStream encodeToBytes() throws IOException {
* Works like {@link #encodeTo(Writer)} but obtain the result as a string.
*/
public String encode() throws IOException {
return encodeToBytes().toString();
return new String(encodeToBytes().toByteArray(), StandardCharsets.UTF_8);
Copy link
Contributor

Choose a reason for hiding this comment

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

Why not just return encodeToBytes().toString(StandardCharsets.UTF_8)? Should run slightly faster. Same suggestion applies to the other changes in this PR.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

You're correct, sir. Changes were made according to your suggestion! Thank you!

@krisstern krisstern requested a review from timja January 14, 2025 12:56
@programbeginnerTW
Copy link
Contributor Author

programbeginnerTW commented Jan 23, 2025

Hey @timja, if you’re free, could you take a look at this PR and let me know what you think? I really appreciate your feedback!

@timja timja requested a review from a team January 23, 2025 09:16
@timja
Copy link
Member

timja commented Jan 23, 2025

Hey @timja, if you’re free, could you take a look at this PR and let me know what you think? I really appreciate your feedback!

Hi could you provide more clarity on how you've tested it?

Manually tested Jenkins core as well as spotbugs to ensure no DM_DEFAULT_ENCODING remains.

This is not clear enough.

I think this is ok, especially since https://openjdk.org/jeps/400, but the ConsoleNote change worries me a bit.

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.

6 participants