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
F13291821: D15535.id37451.diff
Wed, Jun 5, 12:54 AM
F13279009: D15535.id.diff
Sat, Jun 1, 9:14 AM
F13279008: D15535.id37458.diff
Sat, Jun 1, 9:13 AM
F13274502: D15535.diff
Fri, May 31, 3:47 AM
F13261721: D15535.diff
Mon, May 27, 1:22 AM
F13246566: D15535.id37458.diff
Thu, May 23, 11:31 AM
F13246111: D15535.id37451.diff
Thu, May 23, 7:49 AM
F13229508: D15535.id.diff
Mon, May 20, 4:53 PM

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
Lint
Lint Not Applicable
Unit
Tests Not Applicable

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.