Page MenuHomePhabricator

Make the default behavior of getApplicationTransactionCommentObject() "return null" instead of "throw"
ClosedPublic

Authored by epriestley on Feb 7 2019, 3:43 AM.
Tags
None
Referenced Files
F15454227: D20121.diff
Sat, Mar 29, 5:07 PM
F15428824: D20121.id48036.diff
Sun, Mar 23, 10:36 PM
F15423184: D20121.id48036.diff
Sat, Mar 22, 1:44 PM
F15405296: D20121.id.diff
Tue, Mar 18, 11:02 AM
F15390114: D20121.diff
Sat, Mar 15, 5:55 AM
Unknown Object (File)
Feb 24 2025, 2:30 AM
Unknown Object (File)
Feb 9 2025, 7:07 AM
Unknown Object (File)
Feb 9 2025, 7:07 AM
Subscribers

Details

Summary

Depends on D20115. See https://discourse.phabricator-community.org/t/transaction-search-endpoint-does-not-work-on-differential-diffs/2369/.

Currently, getApplicationTransactionCommentObject() throws by default. Subclasses must override it to return null to indicate that they don't support comments.

This is silly, and leads to a bunch of code that does a try / catch around it, and at least some code (here, transaction.search) which doesn't try / catch and gets the wrong behavior as a result.

Just make it return null by default, meaning "no support for comments". Then remove the try / catch stuff and all the return null implementations.

Test Plan
  • Grepped for getApplicationTransactionCommentObject(), fixed each callsite / definition.
  • Called transaction.search on a diff with transactions (i.e., not a sourced-from-commit diff).

Diff Detail

Repository
rP Phabricator
Branch
hook4
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 21876
Build 29861: Run Core Tests
Build 29860: arc lint + arc unit

Event Timeline

src/applications/transactions/storage/PhabricatorApplicationTransaction.php
79

This is the culprit responsible for this mess.

This revision is now accepted and ready to land.Feb 7 2019, 8:47 PM
This revision was automatically updated to reflect the committed changes.