Page MenuHomePhabricator

Partially modularize AlmanacService transactions
ClosedPublic

Authored by epriestley on Apr 9 2018, 9:10 PM.
Tags
None
Referenced Files
F14752506: D19317.id.diff
Tue, Jan 21, 12:58 PM
F14751179: D19317.id46259.diff
Tue, Jan 21, 12:08 PM
F14746796: D19317.diff
Tue, Jan 21, 9:53 AM
Unknown Object (File)
Fri, Jan 17, 9:06 PM
Unknown Object (File)
Sun, Jan 12, 2:32 PM
Unknown Object (File)
Tue, Jan 7, 1:10 PM
Unknown Object (File)
Fri, Jan 3, 9:04 PM
Unknown Object (File)
Mon, Dec 23, 8:41 AM
Subscribers
None

Details

Summary

Ref T13120. Ref T12414. See PHI145. See PHI473. This partially modernizes AlmanacService transactions by moving them to ModularTransactions.

This isn't complete because the "update property" and "remove property" transactions aren't modularized. They still work, since the parent Editor implements them, but they no longer render properly on the timeline since the Transaction object no longer has rendering logic for them.

Tentatively, I'm going to try to convert the rest of the Almanac objects and then modularize those transactions. (Currently, all of Binding, Device, Namespace and Service support properties, although they can only actually be edited on Service, Device and Binding.)

If that turns out to be really tricky for some reason I can just copy/paste the timeline rendering for now, but I think it won't be too hard.

Test Plan
  • Created and edited Services.
  • Tried to create a service with: a bad name, no name, a name which put it in a namespace I can't edit (got errors in all cases).
  • Edited and removed properties. The edits worked, the timeline just renders a generic story now ('X edited this object (transaction type "almanac:property:update").').

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable