fix(countdown-banner): cache result of is_enabled() check
#4422
+17
−5
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
All Submissions:
Changes proposed in this Pull Request:
Plugs a performance hole by memoizing the result of
Metering_Countdown::is_enabled()to avoid redundant checks that can cause extra calculations and site slowdowns.#2243 proposes some additional improvements that are worth making for content gating logic, but this PR should hotfix a known performance issue for live sites already using metered content gates.
Closes NPPM-2543.
How to test the changes in this Pull Request:
release, add anerror_log( 'post is not metered or restricted' );after line 138 and visit a post that's NOT affected by content gating rules. Observe that your test error log is logged many times for the single page request, demonstrating that this method is running a lot more often than needed.Other information: