HomePhabricator

Try running Herald when performing inverse edge edits

Description

Try running Herald when performing inverse edge edits

Summary:
Ref T13053. When you mention one object on another (or link two objects together with an action like "Edit Parent Revisions"), we write a transaction on each side to add the "alice added subtask X" and "alice added parent task Y" items to the timeline.

This behavior now causes problems in T13053 with the "Must Encrypt" flag because it prevents the flag from being applied to the corresponding "inverse edge" mail.

This was added in rP5050389f as a quick workaround for a fatal related to Editors not having enough data to apply Herald on mentions. However, that was in 2014, and since then:

  • Herald got a significant rewrite to modularize all the rules and adapters.
  • Editing got a significant upgrade in EditEngine and most edit workflows now operate through EditEngine.
  • We generally do more editing on more pathways, everything is more modular, and we have standardized how data is loaded to a greater degree.

I suspect there's no longer a problem with just running Herald here, and can't reproduce one. If anything does crop up, it's probably easy (and desirable) to fix it.

This makes Herald fire a little more often: if someone writes a rule, mentioning or creating a relationship to old tasks will now make the rule act. Offhand, that seems fine. If it turns out to be weird, we can probably tailor Herald's behavior.

Test Plan:
I wasn't able to break anything:

  • Mentioned a task on another task (original issue).
  • Linked tasks with commits, mocks, revisions.
  • Linked revisions with commits, tasks.
  • Mentioned users, revisions, and commits.
  • Verified that mail generated by creating links (e.g., Revision > Edit Tasks) now gets the "Must Encrypt" flag properly.

Reviewers: amckinley

Reviewed By: amckinley

Maniphest Tasks: T13053

Differential Revision: https://secure.phabricator.com/D18999

Details

Provenance
epriestleyAuthored on Feb 6 2018, 12:07 PM
epriestleyPushed on Feb 6 2018, 8:19 PM
Reviewer
amckinley
Differential Revision
D18999: Try running Herald when performing inverse edge edits
Parents
rP1bf64e5cbcf4: Add Differential and Herald mail stamps and some refinements
Branches
Unknown
Tags
Unknown
Tasks
T13053: Plans: Mail Tags and Failover
Build Status
Buildable 19371
Build 26193: Run Core Tests