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
Unknown Object (File)
Thu, Apr 25, 6:17 AM
Unknown Object (File)
Wed, Apr 24, 11:47 PM
Unknown Object (File)
Thu, Apr 18, 11:50 PM
Unknown Object (File)
Fri, Apr 5, 1:19 PM
Unknown Object (File)
Mon, Apr 1, 9:01 AM
Unknown Object (File)
Mar 23 2024, 1:52 AM
Unknown Object (File)
Mar 21 2024, 11:03 AM
Unknown Object (File)
Mar 8 2024, 9:24 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.