-
Notifications
You must be signed in to change notification settings - Fork 29
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
feat: OpAMP Package Update functionality #616
Merged
Merged
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
cpheps
approved these changes
Aug 4, 2022
BinaryFissionGames
approved these changes
Aug 4, 2022
* add new binary to everything but windows * add to windows msi * add version flag to updater * build using combined target * fix manual build * add license header * break updater into separate module * add new module to dependabot * copy version pkg to new updater internal pkg To not have a dependency on the root module * Workaround for securego/gosec#501
* Add download and content-hash verification to updater * add a couple more tests for some edge cases * lint * gosec errors * fix defer f.close properly * fix tests on windows * more windows specific testing * fix final test failure on windows * more line-ending test fixes
…ackagesAvailable (#550) * Added OpAMP PackageStatuses functionality & basic response to PackagesAvailable * Add new data model for marshal/unmarshaling OpAMP package statuses.
* start artifact install logic * fix uninstall service step * add tests for windows service manager * remove kardiano/service dependency * check filepath with spaces * more tests, hook up to main * naming * add licenses * gosec fixes * linux gosec + some lint issues * linter * fix formatting of windows service test * actually fix formatting * guard linux/win service tests behind tag * run tests as sudo on linux * fix inverted conditional * split updater integration tests into separate target * refactor package for better encapsulation * update darwin service to load/unload for start/stop * fix installDir for windows after rename * test replaceInstallDir * add license to service_test.go * fix make target phony * add some comments * add start of readme * add a (very basic) readme * use switch instead of multiple ifs * Add comments to moveFiles * fix failing darwin test
…pdater to collector (#565)
Switched PackageStatuses yaml to a JSON file to prevent partial reads by Updater. Removed excess fields for package status. We should be able to communicate with available status and error message. If just started an install, will prevent another PackagesAvailable message from starting another install. If OpAMP client errors out at any point, sets the status to failed with an error message (if possible) in the JSON file. This will allow the updater to quickly shut down the collector and start up the rollback one (which will then send the message to BindPlane). On BindPlane connect, will check if the status is installing. If so, will check if Server version matches current version. Based on this will either set status to success or fail and write to JSON file for BindPlane to notice. It should only try to send a message immediately to BindPlane if it was a success.
* Broke package status objects into their own file Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Updated main module to reference packagestate module Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Fixed licsense check for new module Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Created interface and mocks for package state manager Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Changed PackageStateProvider to use interface of StateManager Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Fixed up linux test for package state manager Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com>
* start rollback * more wip * more tests * add licenses, more testing * split out action stuff to separate package, more testing Needed to do this due to circular deps in mocks * move service test data * fix up darwin tests * Fix linux service to fit new service interface * fix windows service (todo: tests) * add windows backup test * fix service action pointin to wrong file * Logic for Updater to monitor Collector Status (#581) * Added default file name into package state to be accessed by updater Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Added logic to monitor status of collector from updater Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Added tests and fixuped some ci-checks issues Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Ran make add-license Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Added mocks for updater state monitor Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Pre-PR fixups Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * Modified monitor state logic to be more flexible on errors Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * fix revive linting errors * fix windows gosec error * update gosec to ignore test program * refactor CopyFile to allow failure on overwrite * refactor file action to take relative dir * add interface enforcement to actions * add nosec to open func * split windows service backup function into a few functions Co-authored-by: Corbin Phelps <corbin.phelps@bluemedora.com>
* add zap logging * add log level flag * add license headers * lint fixes * remove unimplemented comment * skip NewLogger test on windows * remove ability to specify level * remove rotation * remove copyFiles receiver * remove stringer implementation * remove previous log file on logger creation * tidy go mod * re-add stringer for copy file action
* Adds ability to start Updater and monitor it for failure * Fixes new collector erroring on execution after it is copied * Added KillMode=process to the linux service file in order to orphan the updater * Added disconnection flag to avoid failure messages in graceful shutdown * Added linux service file to tarball Co-authored-by: Corbin Phelps <corbin.phelps@bluemedora.com>
Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com>
* starting on changing installDir * fix and add tests * fix gosec issues * add license * fix formatting * remove command line option from collector * remove redundant parameters, rename copyFiles functions
Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com>
* Added os specific log path Signed-off-by: Corbin Phelps <corbin.phelps@bluemedora.com> * make tests run on windows * make fmt, fix function redefinitions * reduce diff * add license Co-authored-by: Corbin Phelps <corbin.phelps@bluemedora.com>
* remove tmpdir on rollback or update success * remove temp directory in failure scenarios * comment why we use a noop logger for failure * move installer creation to where it's actually used * fix redundant calls to removeTmpDir
* pass install dir into service * pass install dir to service update action service
Also making sure that we use the backed up file permissions when rolling back a file that no longer exists in the install directory
* change service timeouts * update non-windows with new timeout * fix windows test * stop the service before rollback * fix install tests
…ctory (#601) * Have the collector clean artifacts if update fails early * fix client tests
* do Update in place for windows service * add a few comments
* refactor main; tests WIP * add tests for Updater * fix lint * add license * rename installer and rollbacker to avoid confusion w/ interface * final debug log to info log * empty commit for testing
* break CopyFile into separate functions * break overwrite flag into two functions * fix comment for CopyFileOverwrite * small tweaks * tests for file package * fix linux build * remove todo * explain why we continue even on error. * empty commit for testing
BinaryFissionGames
force-pushed
the
opamp-upgrade
branch
from
August 4, 2022 17:30
b98e813
to
dffea4e
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Proposed Change
Added ability for Bindplane to initiate a collector self update.
Checklist