package org.displaytag.jsptests; import org.apache.log4j.Level; import org.apache.log4j.Logger; import org.displaytag.properties.MediaTypeEnum; import org.displaytag.tags.TableTag; import org.displaytag.tags.TableTagParameters; import org.displaytag.test.DisplaytagCase; import org.displaytag.util.ParamEncoder; import org.junit.Assert; import org.junit.Test; import com.meterware.httpunit.GetMethodWebRequest; import com.meterware.httpunit.HttpInternalErrorException; import com.meterware.httpunit.WebRequest; import com.meterware.httpunit.WebResponse; /** * Tests the ResponseOverrideFilter. * @author Fabrizio Giustina * @version $Revision$ ($Author$) */ public class FilterTest extends DisplaytagCase { /** * @see org.displaytag.test.DisplaytagCase#getJspName() */ public String getJspName() { return "filter.jsp"; } /** * @see org.displaytag.test.DisplaytagCase#doTest(java.lang.String) */ @Test public void doTest() throws Exception { ParamEncoder encoder = new ParamEncoder("table"); String mediaParameter = encoder.encodeParameterName(TableTagParameters.PARAMETER_EXPORTTYPE); WebRequest request = new GetMethodWebRequest(getJspUrl(getJspName())); request.setParameter(mediaParameter, Integer.toString(MediaTypeEnum.XML.getCode())); // save previous level, since we are expeting an excetion I don't want to fill logs Level previousLevel = Logger.getLogger(TableTag.class).getLevel(); try { // disable log Logger.getLogger(TableTag.class).setLevel(Level.OFF); // check if page need a filter (unfiltered request) runner.getResponse(request); Assert.fail("Request works also without a filter. Can't test it properly."); } catch (HttpInternalErrorException e) { // it's ok } // reset log Logger.getLogger(TableTag.class).setLevel(previousLevel); request = new GetMethodWebRequest(getJspUrl(getJspName())); request.setParameter(mediaParameter, Integer.toString(MediaTypeEnum.XML.getCode())); // this enable the filter! request.setParameter(TableTagParameters.PARAMETER_EXPORTING, "1"); WebResponse response = runner.getResponse(request); Assert.assertEquals("Expected a different content type.", "text/xml", response.getContentType()); } }