What is the default for FACELETS_REFRESH_PERIOD?

sleske picture sleske · Oct 23, 2012 · Viewed 8k times · Source

In a JSF application, the parameter javax.faces.FACELETS_REFRESH_PERIOD can be used to enable/disable automatic reloading of XHTML files.

I am currently researching the right configuration for production deployments, and accidentally found out that we currently run with FACELETS_REFRESH_PERIOD=1 even in production, which is obviously not a good idea.

This lead to the question: What is the default value for this parameter?

Ideally, I'd like to just omit FACELETS_REFRESH_PERIOD from our production config for simplicity's sake, and hoped it would use a "safe" default value of -1. However, this does not seem to be the case, because without the parameter, refreshing seems to be enabled (with both Mojarra and MyFaces).

I checked the JSF spec, and while it describes the parameter, it does not give a default. Is this a deliberate omission in the spec?

Answer

BalusC picture BalusC · Oct 23, 2012

The default is implementation dependent.

Given that you're using Mojarra, you can find the default in the com.sun.faces.config.WebConfiguration class:

768         FaceletsDefaultRefreshPeriod(
769               "javax.faces.FACELETS_REFRESH_PERIOD",
770               "2"
771         )

(line numbers are from Mojarra 2.0.0)

The default is thus 2. I can't find this in any Mojarra documentation. It might be worth to post an issue report to Mojarra guys to better document it.

MyFaces has according its documentation also a default value of 2.


Update: From Mojarra 2.2.11, the default value is set to -1 if project stage is Production. See also issue 3788.