Page MenuHomePhabricator

Fully fix a bad rule object aliasing issue custom remarkup rules
ClosedPublic

Authored by epriestley on Mar 28 2016, 5:24 PM.
Tags
None
Referenced Files
F14414011: D15535.diff
Tue, Dec 24, 2:58 PM
Unknown Object (File)
Fri, Dec 20, 5:46 PM
Unknown Object (File)
Fri, Dec 13, 7:28 PM
Unknown Object (File)
Fri, Dec 13, 7:10 PM
Unknown Object (File)
Thu, Dec 12, 7:11 AM
Unknown Object (File)
Wed, Nov 27, 12:54 PM
Unknown Object (File)
Nov 23 2024, 6:42 AM
Unknown Object (File)
Nov 19 2024, 12:52 AM

Details

Summary

Fixes T10234. This is a more thorough fix.

Root issue is that some time around D13589, we started hitting an object cache for loadCustomInlineRules(), but didn't adjust the code to account for that.

So if a page created multiple similar engines, we'd return the same $rule object for multiple engines, call setEngine() on it with different engines, and then possibly try to render using an already-expired engine the second time through.

Instead, create a separate $rule object for each separate $engine.

Test Plan

Repro is something like this:

  • Create a custominlinerule which uses an engine.
  • Purge the remarkup cache.
  • Load a page which uses the rule in two engines (e.g., in a revision description, and also in an inline comment).
  • Before change: second one could fatal. After change: clean load.

Diff Detail

Repository
rP Phabricator
Branch
remarkupx
Lint
Lint Passed
Unit
Tests Passed
Build Status
Buildable 11316
Build 14075: Run Core Tests
Build 14074: arc lint + arc unit

Event Timeline

epriestley retitled this revision from to Fully fix a bad rule object aliasing issue custom remarkup rules.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: chad.
thoughtpolice added a reviewer: thoughtpolice.
thoughtpolice added subscribers: eadler, thoughtpolice.

I've confirmed this fixed our instance of T10234 on phabricator.haskell.org

(/cc @eadler, who may want to note this for Wikimedia?)

I've confirmed this fixed our instance of T10234 on phabricator.haskell.org

(/cc @eadler, who may want to note this for Wikimedia?)

I deal with FreeBSD, my employers, and a few other small instances, but appreciate the CC nonetheless.

chad edited edge metadata.

¯\_(ツ)_/¯

This revision is now accepted and ready to land.Mar 28 2016, 6:20 PM
This revision was automatically updated to reflect the committed changes.