ChocoButler is a small app that works with Chocolatey, periodically checking for outdated packages, and allowing them to be upgraded.
ChocoButler sits in the system tray (i.e. notification area) of Windows. Its icon changes colour and an alert pops-up when upgrades are available. See screenshots for examples.
Rather than running upgrades on a fixed schedule, ChocoButler alerts you when updates are available and allows you to start the upgrades at a time convenient for you. (If you just want regular, scheduled updates without user interaction there are better ways to achieve this, though you can do that too with ChocoButler if you really want to).
The easiest way to install ChocoButler is via Chocolatey. The package in Chocolatey is named chocobutler
. Use the Chocolatey GUI and search for "chocobutler" or install via the command line with choco install chocobutler
.
The Chocolatey package adds a shortcut to the startup folder so ChocoButler starts-up automatically with Windows, and also adds an entry to the Start Menu.
To suppress the Start-Up or Start-Menu additions, install via the command line with the following params:
choco install chocobutler --params "'/NoStartUp'"
choco install chocobutler --params "'/NoStartMenu'"
choco install chocobutler --params "'/NoStartMenu /NoStartUp'"
For manual installation, download the files, unzip to a folder, double-click the chocobutler.bat
file.
Alternatively clone the github repo and run the chocobutler.bat
file.
Note that ChocoButler is "portable" and does not require any actual installation. Just place the files in a folder, and double-click the chocobutler.bat
file. If you don't like the software, exit ChocoButler from the menu, and then delete the folder. ChocoButler makes no changes to your system (unless you use it to install updates of course). If you edit your settings via the "Advanced" menu in ChocoButler then a settings file will be created.
If you want to see ChocoButler's logging messages, either run within Powershell (by running chocobutler.ps1
), or run the chocobutler_visible.bat
file instead. This .bat file runs ChocoButler with a visible console window, rather than hiding the window.
When installed via Chocolatey, a shortcut is added to your startup folder, so that ChocoButler runs when Windows starts-up (this can be suppressed as described above in Install via Chocolatey).
To set up start-up manually, copy a shortcut of the chocobutler.bat
file to your startup folder as follows:
- Open start-up folder: Press
Win+R
(to open run dialog), and typeshell:startup
- Right-click on the
chocobutler.bat
file and copy, then "Paste shortcut" in the startup folder
ChocoButler will first check for outdated packages 1 minute after you start ChocoButler (and every N hours thereafter). This delay prevents your PC getting hammered at start-up. If you're keen to check sooner, right-click on the brown ChocoButler icon in the system tray and click "Check for outdated packages now" (or change the immediate_first_check
setting).
Normally the brown ChocoButler icon is shown in the system tray. If packages are available for upgrade, the icon will turn red. When outdated packages are found, a popup will display also.
To install available upgrades, right-click on the system tray icon and select "Install upgrades...". This will install outdated package updates without prompting for confirmations. This effectively runs choco upgrade <packages> --yes
under the covers.
By right-clicking the ChocoButler icon you can see when the last update or check occurred. You can also start the Chocolatey GUI (if installed) via the icon, and exit ChocoButler too.
See screenshots for examples.
On detecting outdated packages, an alert pop-up is shown, and the ChocoButler icon in the system tray (notification area) turns red:
You may need to expand the system tray (notification area) with the up-arrow to see the icon. Hovering the mouse over the (red) icon displays the number (and names) of outdated packages:
Right-clicking the icon shows a menu, including the option to "Install upgrades...":
A confirmation box, showing packages to be upgraded, is shown before installation:
A pop-up displays when upgrades are complete:
When no outdated packages are available for upgrade (e.g. post-install) the icon returns to the regular icon. Hovering over the icon displays "No outdated packages":
Default settings (as detailed below) will be in place unless/until the user selects Edit ChocoButler Settings file
via the Advanced
. At that point a settings.json
file will be created (in %APPDATA%
).
Edit this file to configure ChocoButler. The following settings are available:
By default ChocoButler checks for outdated packages every 12 hours. To change this, edit the settings.json
file and change the check_delay_hours
value.
Suppress alert pop-ups by setting silent
to true
. Alerts will still be shown for warnings and errors, even with this setting turned on.
Normally ChocoButler will check in the background for outdated packages every few hours. However if exit_if_no_outdated
is set to true
, ChocoButler will exit after an outdated-check find no packages are available for upgrade.
You may want to pair this with the immediate_first_check
setting.
By default, ChocoButler waits 1 minute before doing its first outdated-check; this helps prevent hammering the PC on startup. Set immediate_first_check
to true
to have the first check start immediately.
By default, ChocoButler will alert you to available updates, and you then start the installation process (from the system tray icon) at a convenient time. This way you don't upgrade Zoom in the middle of a video meeting, say. However if you want the upgrade installation to occur automatically, and as soon as outdated packages are available, you can change the auto_install
setting to true
.
Even with auto_install
turned on, you'll probably still need to click OK in a dialog to allow choco to make changes, and these requests could pop up at any time (and so could be annoying).
To avoid this, you could run the whole Powershell script as Admin, then you won't get prompted, but this is probably not a great idea from a security point of view. Overall ChocoButler was not built for fully automated updates, so this will likely be clunky.
Generally the test_mode
setting should be left as false
. See Testing & Development below for more details.
You must restart ChocoButler for settings changes to take effect.
Often, when Chocolatey updates itself, the choco
command will start issuing errors/warnings like this:
Access to the path 'C:\ProgramData\chocolatey\choco.exe.old' is denied.
These warning messages prevent the output of choco
from being parsed correctly.
The problem occurs when Chocolatey is trying to delete an old .exe file from a previous version, but is unable to do so. This can generally be fixed by running choco
as admin.
ChocoButler will check for this problem periodically, and if encountered gives the option to "repair". The repair option simply runs choco
as admin to allow it to fix itself.
There is a built in test mode to help when testing and developing the app. You can enable the test mode by setting "test_mode": true
in the settings.json
file.
The test_mode leads to four changes in behaviour:
- The first check for outdated-packages occurs as soon as the script starts (not one minute after as is the normal behaviour)
- If no outdated packages are found, the GoogleChrome package is added to the outdated list for testing
- No changes are made during the installation of upgrades, it just does a dry-run (i.e. the
--noop
switch is passed tochoco upgrade
) - On exit,
Exit
is called rather thanStop-Process
. This is less likely to kill your IDE. YMMV.
The above changes allow you to quickly test the main check->upgrade workflow, without having to wait for an actual outdated package to appear.