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

Disable version check for external libraries #1938

Open
wants to merge 4 commits into
base: main
Choose a base branch
from

Conversation

leaanthony
Copy link
Contributor

This PR adds an internal flag to the executor to disable version checks. This is to ensure that any application that uses Task as a library doesn't error when Task checks the buildinfo.
This PR also renames close to closer in task.go as it clashes with the keyword `close.

Copy link
Member

@pd93 pd93 left a comment

Choose a reason for hiding this comment

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

Thanks for this @leaanthony.

Just a thought before this is merged. I don't think we should require users of our library to set a DisableVersionCheck flag to make Task work as package. I feel like this should be the default behaviour and our CLI entrypoint should enable it instead (basically, the reverse of this PR).

@leaanthony
Copy link
Contributor Author

I actually agree with you. This got me over the line but yeah adding the in the CLI and not init() works better

@leaanthony leaanthony changed the title Disable version check flag Disable version check for external libraries Dec 8, 2024
@leaanthony
Copy link
Contributor Author

leaanthony commented Dec 8, 2024

@pd93 - Updated the PR to run the version initialisation on cli startup. Tidied the version output if there is no sum.

if sum == "" {
sum = info.Main.Sum
}
return
}
Copy link
Member

Choose a reason for hiding this comment

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

We need to keep these empty checks as these variables are pre-populated by ldflags in some package managers. The default value also needs to be empty for the same reason.

There have been quite a few accidental changes around this function. We should probably add some comments here to explain this too.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Coming at it fresh it does seem a bit strange 😅 The reason for the change was a failing test that assumed it would be "unknown" but would return blank. What's the best approach to fix that? Set it in Init if it's not set in the buildinfo?

Copy link
Member

@pd93 pd93 Dec 9, 2024

Choose a reason for hiding this comment

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

This is because our tests treat Task as a package, not a CLI. This is a bit awkward to fix, but I think we could add a setting in the executor called EnableVersionCheck (Similar to the DisableVersionCheck you had previously). This setting would then need to be added to the CLI entrypoint and any relevant tests that need the version check functionality.

@leaanthony leaanthony force-pushed the disable-version-check-flag branch from 504a0da to 89e7b35 Compare December 17, 2024 20:09
@@ -10,7 +10,7 @@ var (
sum = ""
)

func init() {
func Init() {
Copy link
Member

Choose a reason for hiding this comment

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

Reverting this change should fix your tests

cmd/task/task.go Show resolved Hide resolved
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