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

Update DGP migration opt-in flags and messages #3736

Merged
merged 16 commits into from
Aug 20, 2024

Conversation

adam-enko
Copy link
Member

@adam-enko adam-enko commented Aug 8, 2024

Continued from #3695 (comment)

  • Create BuildService so that classic/V2 messages are only logged once per project
  • Add test for classic/v2/suppress message properties.
  • Update test utils to make it easier to modify the gradle.properties in a test project.

tl;dr:

  • V1 triggers a warning message.
  • org.jetbrains.dokka.experimental.gradlePlugin.enableV2=true to opt-in for V2.
  • org.jetbrains.dokka.experimental.gradlePlugin.enableV2.noWarn=true to suppress the message.

KT-70655

@adam-enko adam-enko added the runner: Gradle plugin An issue/PR related to Dokka's Gradle plugin label Aug 8, 2024
@adam-enko adam-enko self-assigned this Aug 8, 2024
Base automatically changed from adam/merge-dokkatoo to master August 13, 2024 09:57
- Re-write the Dokka Gradle Plugin v1 & v2 messages.
- Update the opt-in flag for v2.
- Create a BuildService, so the messages are only logged once per project.
@adam-enko adam-enko force-pushed the adam/feat/OSIP-355/update-dokkatoo-optin-flags branch from 47824c0 to 608937b Compare August 13, 2024 14:52
@adam-enko adam-enko marked this pull request as ready for review August 13, 2024 14:59
@adam-enko adam-enko changed the title Update DGP migration messages Update DGP migration opt-in flags and messages Aug 13, 2024
Copy link
Collaborator

@whyoleg whyoleg left a comment

Choose a reason for hiding this comment

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

LGTM

I want to add more opt-in flags in the future, and the pattern of '$prop.quiet=true' is easier to read, understand, and more robust.
E.g. 'dokka.enableK2.quiet=true' is nicer to read than 'dokka.suppressK2Message=true'.
- Re-register the BuildService if it fails. Mark the first successfully registered BuildService as 'primary'. Only 'primary' BuildServices will log user-facing messages.
- Update MigrationMessagesTest to test BuildService classloader issues.
- Rename flag properties for consistency.
- Add `.nowarn` and `.noWarn` variants, because I really don't want to be constantly nagged by spellcheck.
- use `lazy(SYNCHRONIZED) {}` to better control logging, only log when necessary, and to avoid potential parallel issues.
Avoid using `Properties()` because it needlessly escapes values, doesn't order values, and adds a timestamp.
Copy link
Contributor

@Tapchicoma Tapchicoma left a comment

Choose a reason for hiding this comment

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

LGTM!

@adam-enko adam-enko merged commit 67c2c9e into master Aug 20, 2024
13 checks passed
@adam-enko adam-enko deleted the adam/feat/OSIP-355/update-dokkatoo-optin-flags branch August 20, 2024 11:45
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
runner: Gradle plugin An issue/PR related to Dokka's Gradle plugin
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants