-
-
Notifications
You must be signed in to change notification settings - Fork 23
Detect if configlet is at the latest version #113
Comments
I am for either form of the 1st option. |
As I see it, you need all those behaviors: every time a command is run, you want to check internal state, which may be a config file, and determines when the last version check was made. If it exceeds some threshold, it goes over the wire for a small request to get the current version. (This should behave well if the network is unavailable or laggy, meaning it runs concurrently with the actual command being executed and fail silently if at all.) Finally, if a newer version is available, it should prompt the user to run the |
I’m a fan of all three options, with some slight modifications. For the upgrade process #112, I think we could leverage the cli pkg in exercism/cli which is responsible for checking if a binary is out of date and upgrading to the latest version. At a minimum users of configlet should be encouraged to use the same version used on Travis. Would anyone be opposed to showing the version with the build date as metadata at command run (e.g When it comes to going over the wire, we could add a flag to disable that check for those users who update regularly. Thoughts? The config file is a nice idea, but where would we store the file? Should configlet have a config directory to store this type of info? |
It will need some sort of auto-check for current version. If a user is unaware that configlet is updated they may not think to run the update command. I'm often surprised at how many track maintainers don't even use it, let alone monitor its release status. Over the wire every invocation is not great, and we would probably want to disable it entirely for travis linting? A config file for one thing may be overkill, perhaps we can just store the last checked time in a tmp dir file or something? |
That's the idea. The current version is easily accessible within configlet so it would be just printing in a way that it is not disruptive to the normal output.
I hoping that if a user sees that the build date in the version string is, lets say, older than x months or even a year old they would be inclined to check for a new release. Is that a stretch?
So in thinking about this a little more, if we added the date of the last build as build metadata to the version we would be able to use that information to determine if configlet should check for a new available release. Removing the need for a tmp dir/file entirely.
Travis always pulls down the latest version of configlet so there wouldn't be a need to run the check. |
All good ideas here. Esp. the metadata one. Would strive to avoid files if it can be avoided. I really don't think users will think to check for a new release. Just not part of their workflow. |
The discussion in exercism/docs#110 raised some issues regarding improvements to Configlet in the context of UUIDs that get submitted, but which are incorrect.
Since older versions of Configlet were using a UUID library that generated invalid UUIDs, one thing we can do to help improve the situation is ensure that Configlet is up to date.
The approaches I can think of are:
The text was updated successfully, but these errors were encountered: