Rietveld Code Review Tool
Help | Bug tracker | Discussion group | Source code | Sign in
(2)

Issue 6500072: Unite uniter state files; charm upgrades

Can't Edit
Can't Publish+Mail
Start Review
Created:
12 years, 7 months ago by fwereade
Modified:
12 years, 7 months ago
Reviewers:
mp+122662
Visibility:
Public.

Description

Unite uniter state files; charm upgrades The most notable common feature of the two preceding rejections was that their mechanisms for smoothly managing the switch from deployment to hook- running were clunky and inelegant. This prompted me to switch over to a single uniter state file, which is written atomically, and can compactly express everything the uniter needs to persist (excluding relation state). The immediate effects of this change were to move significant chunks of code from the hook and charm packages directly into uniter/state.go; it also naturally induced minor fixes across uniter.go and modes.go (to stay compatible). Doing this made it clear that the original hook state storage strategy was flawed: saving even a membership list for a 100k-scale relation is a bad idea even when we're only persisting it at relation hook time, but it's just plain awful if we might have to save it repeatedly. So: we no longer save hook.Info.Members, and we depend on the Relationer to induce the appropriate changes to relation state. This was pleasing; it required only a single else branch in Relationer.PrepareHook. In turn, it allowed me to write a charm.Deployer which uses charm bundles and URLs to deploy to (slightly enhanced) GitDirs, and enabled a reasonably straightforward rewrite of Uniter.changeCharm (now deploy), which subsumes a small but significant chunk of charm.Manager. The Uniter modes also underwent related changes; most notably, ModeInit is now almost vestigial, but I expect to add to it very soon, so I would prefer to keep it around. ModeContinue has been rewritten but still works the same; ModeStarted and ModeHookError now upgrade charms, while ModeUpgrading and ModeConflicted have been added to implement this behaviour. I'm really pretty happy with this as it stands, and hope the above reduces the WTF-is-he-doing mental load a little; the only thing I'm sure *won't* make it through review is the not-doing-anything-right-now Op, which I called "Abide" after some time with a thesaurus, but I'm pretty sure is wrong. https://code.launchpad.net/~fwereade/juju-core/uniter-operation-state/+merge/122662 (do not edit description out of merge proposal)

Patch Set 1 #

Patch Set 2 : Unite uniter state files; charm upgrades #

Unified diffs Side-by-side diffs Delta from patch set Stats (+1553 lines, -652 lines) Patch
A [revision details] View 1 chunk +2 lines, -0 lines 0 comments Download
M worker/uniter/charm/charm.go View 2 chunks +162 lines, -132 lines 0 comments Download
M worker/uniter/charm/charm_test.go View 2 chunks +183 lines, -99 lines 0 comments Download
M worker/uniter/charm/git.go View 5 chunks +98 lines, -15 lines 0 comments Download
M worker/uniter/charm/git_test.go View 3 chunks +122 lines, -38 lines 0 comments Download
M worker/uniter/hook/hook.go View 4 chunks +29 lines, -149 lines 0 comments Download
D worker/uniter/hook/hook_test.go View 1 chunk +0 lines, -62 lines 0 comments Download
M worker/uniter/modes.go View 7 chunks +183 lines, -72 lines 0 comments Download
M worker/uniter/relationer.go View 2 chunks +5 lines, -1 line 0 comments Download
A worker/uniter/state.go View 1 chunk +151 lines, -0 lines 0 comments Download
A worker/uniter/state_test.go View 1 chunk +171 lines, -0 lines 0 comments Download
M worker/uniter/uniter.go View 8 chunks +79 lines, -50 lines 0 comments Download
M worker/uniter/uniter_test.go View 18 chunks +368 lines, -34 lines 0 comments Download

Messages

Total messages: 1
fwereade
12 years, 7 months ago (2012-09-04 12:25:28 UTC) #1
Please take a look.
Sign in to reply to this message.

Powered by Google App Engine
RSS Feeds Recent Issues | This issue
This is Rietveld f62528b