<html>
<head>
<title>File Source for InputFilterTest.php</title>
<link rel="stylesheet" type="text/css" href="../media/style.css">
</head>
<body>
<table border="0" cellspacing="0" cellpadding="0" height="48" width="100%">
<tr>
<td class="header_top">PHPonTraxTest</td>
</tr>
<tr><td class="header_line"><img src="../media/empty.png" width="1" height="1" border="0" alt="" /></td></tr>
<tr>
<td class="header_menu">
[ <a href="../classtrees_PHPonTraxTest.html" class="menu">class tree: PHPonTraxTest</a> ]
[ <a href="../elementindex_PHPonTraxTest.html" class="menu">index: PHPonTraxTest</a> ]
[ <a href="../elementindex.html" class="menu">all elements</a> ]
</td>
</tr>
<tr><td class="header_line"><img src="../media/empty.png" width="1" height="1" border="0" alt="" /></td></tr>
</table>
<table width="100%" border="0" cellpadding="0" cellspacing="0">
<tr valign="top">
<td width="200" class="menu">
<div id="todolist">
<p><a href="../todolist.html">Todo List</a></p>
</div>
<b>Packages:</b><br />
<a href="../li_PHPonTrax.html">PHPonTrax</a><br />
<a href="../li_PHPonTraxTest.html">PHPonTraxTest</a><br />
<br /><br />
</td>
<td>
<table cellpadding="10" cellspacing="0" width="100%" border="0"><tr><td valign="top">
<h1 align="center">Source for file InputFilterTest.php</h1>
<p>Documentation is available at <a href="../PHPonTraxTest/_test_InputFilterTest_php.html">InputFilterTest.php</a></p>
<div class="php">
<div class="listing"><pre><ol><li><a name="a1"></a><span class="src-php"><?php</span></li>
<li><a name="a2"></a><span class="src-doc">/**</span></li>
<li><a name="a3"></a><span class="src-doc"> * File for the InputFilterTest class</span></li>
<li><a name="a4"></a><span class="src-doc"> *</span></li>
<li><a name="a5"></a><span class="src-doc"> * (PHP 5)</span></li>
<li><a name="a6"></a><span class="src-doc"> *</span></li>
<li><a name="a7"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@package</span><span class="src-doc"> PHPonTraxTest</span></li>
<li><a name="a8"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@license</span><span class="src-doc"> http://opensource.org/licenses/gpl-license.php GNU Public License</span></li>
<li><a name="a9"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@copyright</span><span class="src-doc"> (c) Walter O. Haas 2006</span></li>
<li><a name="a10"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@version</span><span class="src-doc"> $Id: InputFilterTest.php 192 2006-03-27 22:02:53Z haas $</span></li>
<li><a name="a11"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@author</span><span class="src-doc"> Walt Haas <hide@address.com></span></li>
<li><a name="a12"></a><span class="src-doc"> */</span></li>
<li><a name="a13"></a> </li>
<li><a name="a14"></a>echo <span class="src-str">"testing InputFilter\n"</span><span class="src-sym">;</span></li>
<li><a name="a15"></a><span class="src-inc">require_once </span><span class="src-str">'testenv.php'</span><span class="src-sym">;</span></li>
<li><a name="a16"></a> </li>
<li><a name="a17"></a><span class="src-comm">// Call InputFilterTest::main() if this source file is executed directly.</span></li>
<li><a name="a18"></a><span class="src-key">if </span><span class="src-sym">(</span><span class="src-sym">!</span><a href="http://www.php.net/defined">defined</a><span class="src-sym">(</span><span class="src-str">"PHPUnit2_MAIN_METHOD"</span><span class="src-sym">)) </span><span class="src-sym">{</span></li>
<li><a name="a19"></a> <a href="http://www.php.net/define">define</a><span class="src-sym">(</span><span class="src-str">"PHPUnit2_MAIN_METHOD"</span><span class="src-sym">, </span><span class="src-str">"InputFilterTest::main"</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a20"></a><span class="src-sym">}</span></li>
<li><a name="a21"></a> </li>
<li><a name="a22"></a><span class="src-inc">require_once </span><span class="src-str">"PHPUnit2/Framework/TestCase.php"</span><span class="src-sym">;</span></li>
<li><a name="a23"></a><span class="src-inc">require_once </span><span class="src-str">"PHPUnit2/Framework/TestSuite.php"</span><span class="src-sym">;</span></li>
<li><a name="a24"></a> </li>
<li><a name="a25"></a><span class="src-comm">// You may remove the following line when all tests have been implemented.</span></li>
<li><a name="a26"></a><span class="src-inc">require_once </span><span class="src-str">"PHPUnit2/Framework/IncompleteTestError.php"</span><span class="src-sym">;</span></li>
<li><a name="a27"></a> </li>
<li><a name="a28"></a><span class="src-inc">require_once </span><span class="src-str">"input_filter.php"</span><span class="src-sym">;</span></li>
<li><a name="a29"></a> </li>
<li><a name="a30"></a><span class="src-doc">/**</span></li>
<li><a name="a31"></a><span class="src-doc"> * Test class for InputFilter.</span></li>
<li><a name="a32"></a><span class="src-doc"> * Generated by PHPUnit2_Util_Skeleton on 2006-02-28 at 11:52:31.</span></li>
<li><a name="a33"></a><span class="src-doc"> */</span></li>
<li><a name="a34"></a><span class="src-key">class </span><a href="../PHPonTraxTest/InputFilterTest.html">InputFilterTest</a> <span class="src-key">extends </span><span class="src-id">PHPUnit2_Framework_TestCase </span><span class="src-sym">{</span></li>
<li><a name="a35"></a> </li>
<li><a name="a36"></a> <span class="src-doc">/**</span></li>
<li><a name="a37"></a><span class="src-doc"> * Runs the test methods of this class.</span></li>
<li><a name="a38"></a><span class="src-doc"> *</span></li>
<li><a name="a39"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@access</span><span class="src-doc"> public</span></li>
<li><a name="a40"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@static</span></li>
<li><a name="a41"></a><span class="src-doc"> */</span></li>
<li><a name="a42"></a> <span class="src-key">public </span><span class="src-key">static </span><span class="src-key">function </span><a href="../PHPonTraxTest/InputFilterTest.html#methodmain">main</a><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-sym">{</span></li>
<li><a name="a43"></a> <span class="src-inc">require_once </span><span class="src-str">"PHPUnit2/TextUI/TestRunner.php"</span><span class="src-sym">;</span></li>
<li><a name="a44"></a> </li>
<li><a name="a45"></a> <span class="src-var">$suite </span>= <span class="src-key">new </span><span class="src-id">PHPUnit2_Framework_TestSuite</span><span class="src-sym">(</span><span class="src-str">"InputFilterTest"</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a46"></a> <span class="src-var">$result </span>= <span class="src-id">PHPUnit2_TextUI_TestRunner</span><span class="src-sym">::</span><span class="src-id">run</span><span class="src-sym">(</span><span class="src-var">$suite</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a47"></a> <span class="src-sym">}</span></li>
<li><a name="a48"></a> </li>
<li><a name="a49"></a> <span class="src-doc">/**</span></li>
<li><a name="a50"></a><span class="src-doc"> * Sets up the fixture, for example, open a network connection.</span></li>
<li><a name="a51"></a><span class="src-doc"> * This method is called before a test is executed.</span></li>
<li><a name="a52"></a><span class="src-doc"> *</span></li>
<li><a name="a53"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@access</span><span class="src-doc"> protected</span></li>
<li><a name="a54"></a><span class="src-doc"> */</span></li>
<li><a name="a55"></a> <span class="src-key">protected </span><span class="src-key">function </span><a href="../PHPonTraxTest/InputFilterTest.html#methodsetUp">setUp</a><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-sym">{</span></li>
<li><a name="a56"></a> <span class="src-sym">}</span></li>
<li><a name="a57"></a> </li>
<li><a name="a58"></a> <span class="src-doc">/**</span></li>
<li><a name="a59"></a><span class="src-doc"> * Tears down the fixture, for example, close a network connection.</span></li>
<li><a name="a60"></a><span class="src-doc"> * This method is called after a test is executed.</span></li>
<li><a name="a61"></a><span class="src-doc"> *</span></li>
<li><a name="a62"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@access</span><span class="src-doc"> protected</span></li>
<li><a name="a63"></a><span class="src-doc"> */</span></li>
<li><a name="a64"></a> <span class="src-key">protected </span><span class="src-key">function </span><a href="../PHPonTraxTest/InputFilterTest.html#methodtearDown">tearDown</a><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-sym">{</span></li>
<li><a name="a65"></a> <span class="src-sym">}</span></li>
<li><a name="a66"></a> </li>
<li><a name="a67"></a> <span class="src-doc">/**</span></li>
<li><a name="a68"></a><span class="src-doc"> * Test the process() method</span></li>
<li><a name="a69"></a><span class="src-doc"> */</span></li>
<li><a name="a70"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../PHPonTraxTest/InputFilterTest.html#methodtestProcess">testProcess</a><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-sym">{</span></li>
<li><a name="a71"></a> <span class="src-comm">// Trivial case, nothing to clean</span></li>
<li><a name="a72"></a> <span class="src-sym">@</span><span class="src-key">new </span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a73"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'foo'</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-str">'foo'</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a74"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'foo'</span><span class="src-sym">,</span><span class="src-str">'bar'</span><span class="src-sym">))</span><span class="src-sym">,</span></li>
<li><a name="a75"></a> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'foo'</span><span class="src-sym">,</span><span class="src-str">'bar'</span><span class="src-sym">))</span><span class="src-sym">;</span></li>
<li><a name="a76"></a> <span class="src-comm">// Default constructor removes all tags</span></li>
<li><a name="a77"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'<ok>foobar</ok>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a78"></a> <span class="src-str">'foobar'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a79"></a> <span class="src-comm">// Allow all but blacklisted tags and attributes</span></li>
<li><a name="a80"></a> <span class="src-sym">@</span><span class="src-key">new </span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a81"></a> <span class="src-comm">// Irregular tag names are always filtered out</span></li>
<li><a name="a82"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'foo<#$>bar</#$>mumble'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a83"></a> <span class="src-str">'foobarmumble'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a84"></a> <span class="src-comm">// $xssAuto=1 filters blacklisted tags and attributes</span></li>
<li><a name="a85"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'<body>foobar</body>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a86"></a> <span class="src-str">'foobar'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a87"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'<ok action="yes">foobar</ok>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a88"></a> <span class="src-str">'<ok>foobar</ok>'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a89"></a> <span class="src-comm">// With $xssAuto off, blacklisted tags and attributes are allowed</span></li>
<li><a name="a90"></a> <span class="src-sym">@</span><span class="src-key">new </span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a91"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'<body>foobar</body>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a92"></a> <span class="src-str">'<body>foobar</body>'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a93"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'<ok action="yes">foobar</ok>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a94"></a> <span class="src-str">'<ok action="yes">foobar</ok>'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a95"></a> <span class="src-comm">// tagMethod=1 permits all but listed tags</span></li>
<li><a name="a96"></a> <span class="src-sym">@</span><span class="src-key">new </span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'foo'</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a97"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span></li>
<li><a name="a98"></a> <span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'<foo>mumble</foo><bar>grumble</bar>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a99"></a> <span class="src-str">'mumble<bar>grumble</bar>'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a100"></a> <span class="src-comm">// tagMethod=0 permits only listed tags</span></li>
<li><a name="a101"></a> <span class="src-sym">@</span><span class="src-key">new </span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'foo'</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a102"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span></li>
<li><a name="a103"></a> <span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'<foo>mumble</foo><bar>grumble</bar>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a104"></a> <span class="src-str">'<foo>mumble</foo>grumble'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a105"></a> <span class="src-comm">// attrMethod=1 permits all but listed attributes</span></li>
<li><a name="a106"></a> <span class="src-sym">@</span><span class="src-key">new </span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'dangerous'</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a107"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span></li>
<li><a name="a108"></a> <span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'<foo safe="1" dangerous="1">mumble</foo>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a109"></a> <span class="src-str">'<foo safe="1">mumble</foo>'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a110"></a> <span class="src-comm">// attrMethod=0 permits only listed tags</span></li>
<li><a name="a111"></a> <span class="src-sym">@</span><span class="src-key">new </span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'dangerous'</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-num">1</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a112"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span></li>
<li><a name="a113"></a> <span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span><span class="src-str">'<foo safe="1" dangerous="1">mumble</foo>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a114"></a> <span class="src-str">'<foo dangerous="1">mumble</foo>'</span><span class="src-sym">)</span><span class="src-sym">; </span></li>
<li><a name="a115"></a> <span class="src-comm">// accept only know safe tags</span></li>
<li><a name="a116"></a> <span class="src-sym">@</span><span class="src-key">new </span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'div'</span><span class="src-sym">,</span><span class="src-str">'span'</span><span class="src-sym">,</span><span class="src-str">'strong'</span><span class="src-sym">,</span><span class="src-str">'em'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a117"></a> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'id'</span><span class="src-sym">,</span><span class="src-str">'class'</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">,</span><span class="src-num">0</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a118"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span></li>
<li><a name="a119"></a> <span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess">process</a><span class="src-sym">(</span></li>
<li><a name="a120"></a> <span class="src-str">'<body class="full">mumble<span class="error" color="red">'</span></li>
<li><a name="a121"></a> .<span class="src-str">'grumble</span>burfl</body>'</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a122"></a> <span class="src-str">'mumble<span class="error">grumble</span>burfl'</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a123"></a> <span class="src-sym">}</span></li>
<li><a name="a124"></a> </li>
<li><a name="a125"></a> <span class="src-doc">/**</span></li>
<li><a name="a126"></a><span class="src-doc"> * Test process_all() method</span></li>
<li><a name="a127"></a><span class="src-doc"> */</span></li>
<li><a name="a128"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../PHPonTraxTest/InputFilterTest.html#methodtestProcess_all">testProcess_all</a><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-sym">{</span></li>
<li><a name="a129"></a> <span class="src-var">$_GET </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'<tag1>foo</tag1>'</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a130"></a> <span class="src-var">$_POST </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'<tag2>bar</tag2>'</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a131"></a> <span class="src-var">$_REQUEST </span>= <span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'<tag3>mumble</tag3>'</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a132"></a> </li>
<li><a name="a133"></a> <span class="src-comm">// Default is to remove all tags</span></li>
<li><a name="a134"></a> <span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodprocess_all">process_all</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a135"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-var">$_GET</span><span class="src-sym">,</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'foo'</span><span class="src-sym">))</span><span class="src-sym">;</span></li>
<li><a name="a136"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-var">$_POST</span><span class="src-sym">,</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'bar'</span><span class="src-sym">))</span><span class="src-sym">;</span></li>
<li><a name="a137"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-var">$_REQUEST</span><span class="src-sym">,</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'mumble'</span><span class="src-sym">))</span><span class="src-sym">;</span></li>
<li><a name="a138"></a> <span class="src-sym">}</span></li>
<li><a name="a139"></a> </li>
<li><a name="a140"></a> <span class="src-doc">/**</span></li>
<li><a name="a141"></a><span class="src-doc"> * Test saveSQL()</span></li>
<li><a name="a142"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@todo</span><span class="src-doc"> Figure out problem w/ mysql_real_escape_string()</span></li>
<li><a name="a143"></a><span class="src-doc"> * </span><span class="src-doc-coretag">@todo</span><span class="src-doc"> Figure out how to test with magic quotes either on or off</span></li>
<li><a name="a144"></a><span class="src-doc"> */</span></li>
<li><a name="a145"></a> <span class="src-key">public </span><span class="src-key">function </span><a href="../PHPonTraxTest/InputFilterTest.html#methodtestSafeSQL">testSafeSQL</a><span class="src-sym">(</span><span class="src-sym">) </span><span class="src-sym">{</span></li>
<li><a name="a146"></a> <span class="src-var">$rs </span>= <a href="http://www.php.net/mysql_connect">mysql_connect</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a147"></a> <span class="src-key">if </span><span class="src-sym">(</span><span class="src-var">$rs </span>== <span class="src-id">false</span><span class="src-sym">) </span><span class="src-sym">{</span></li>
<li><a name="a148"></a> <span class="src-id">PHPUnit2_Framework_Assert</span><span class="src-sym">::</span><span class="src-id">fail</span><span class="src-sym">(</span><span class="src-str">"InputFilterTest:"</span></li>
<li><a name="a149"></a> .<span class="src-str">" unable to open a connction to MySQL"</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a150"></a> <span class="src-sym">}</span></li>
<li><a name="a151"></a> <span class="src-comm">// Trivial case, nothing to clean</span></li>
<li><a name="a152"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodsafeSQL">safeSQL</a><span class="src-sym">(</span><span class="src-str">'foo'</span><span class="src-sym">,</span><span class="src-var">$rs</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-str">'foo'</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a153"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodsafeSQL">safeSQL</a><span class="src-sym">(</span><span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'foo'</span><span class="src-sym">,</span><span class="src-str">'bar'</span><span class="src-sym">)</span><span class="src-sym">,</span><span class="src-var">$rs</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a154"></a> <span class="src-key">array</span><span class="src-sym">(</span><span class="src-str">'foo'</span><span class="src-sym">,</span><span class="src-str">'bar'</span><span class="src-sym">))</span><span class="src-sym">;</span></li>
<li><a name="a155"></a> <span class="src-key">if </span><span class="src-sym">(</span><a href="http://www.php.net/get_magic_quotes_gpc">get_magic_quotes_gpc</a><span class="src-sym">(</span><span class="src-sym">)) </span><span class="src-sym">{</span></li>
<li><a name="a156"></a> <span class="src-comm">// verify stripping of magic quotes</span></li>
<li><a name="a157"></a> <span class="src-comm">// FIXME: figure out how to test this case</span></li>
<li><a name="a158"></a> <span class="src-var">$this</span><span class="src-sym">-></span><span class="src-id">assertEquals</span><span class="src-sym">(</span></li>
<li><a name="a159"></a> <span class="src-id"><a href="../PHPonTrax/InputFilter.html">InputFilter</a></span><span class="src-sym">::</span><a href="../PHPonTrax/InputFilter.html#methodsafeSQL">safeSQL</a><span class="src-sym">(</span><span class="src-str">'a\\\'b\\"c\\\\d\\\x00e\\\nf\\\rg\\\x1a'</span><span class="src-sym">,</span><span class="src-var">$rs</span><span class="src-sym">)</span><span class="src-sym">,</span></li>
<li><a name="a160"></a> <span class="src-str">'a\\\'b\\"c\\\\d\\\x00e\\\nf\\\rg\\\x1a'</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a161"></a> <span class="src-sym">}</span></li>
<li><a name="a162"></a> <span class="src-key">else </span><span class="src-sym">{</span></li>
<li><a name="a163"></a> <span class="src-comm">// verify magic quotes aren't there</span></li>
<li><a name="a164"></a> <span class="src-var">$pattern </span>= <span class="src-str">"a'b\"c\\d\x00e\nf\rg\x1ah"</span><span class="src-sym">;</span></li>
<li><a name="a165"></a> <span class="src-var">$non_zero_pattern </span>= <span class="src-str">"a'b\"c\\de\nf\rg\x1ah"</span><span class="src-sym">;</span></li>
<li><a name="a166"></a> <span class="src-var">$quoted_pattern </span>= <span class="src-str">"a\\'b\\\"c\\\\de\\\nf\\\rg\\\x1ah"</span><span class="src-sym">;</span></li>
<li><a name="a167"></a> <span class="src-var">$quoted_non_zero_pattern </span>= <span class="src-str">"a\\'b\\\"c\\\\de\\\nf\\\rg\\\x1ah"</span><span class="src-sym">;</span></li>
<li><a name="a168"></a><span class="src-comm">// echo "\nIf this fails it means mysql_real_escape_string() is broken: ";</span></li>
<li><a name="a169"></a><span class="src-comm">// $this->assertEquals(mysql_real_escape_string($non_zero_pattern),</span></li>
<li><a name="a170"></a><span class="src-comm">// $quoted_non_zero_pattern);</span></li>
<li><a name="a171"></a><span class="src-comm">// echo "\nIf this fails it means mysql_real_escape_string() is broken: ";</span></li>
<li><a name="a172"></a><span class="src-comm">// $this->assertEquals(mysql_real_escape_string($pattern),</span></li>
<li><a name="a173"></a><span class="src-comm">// $quoted_pattern);</span></li>
<li><a name="a174"></a><span class="src-comm">// $this->assertEquals(</span></li>
<li><a name="a175"></a><span class="src-comm">// InputFilter::safeSQL($pattern,$rs),$quoted_pattern);</span></li>
<li><a name="a176"></a> <span class="src-sym">}</span></li>
<li><a name="a177"></a> <span class="src-comm">// Remove the following line when you complete this test.</span></li>
<li><a name="a178"></a> throw <span class="src-key">new </span><span class="src-id">PHPUnit2_Framework_IncompleteTestError</span><span class="src-sym">;</span></li>
<li><a name="a179"></a> <span class="src-sym">}</span></li>
<li><a name="a180"></a><span class="src-sym">}</span></li>
<li><a name="a181"></a> </li>
<li><a name="a182"></a><span class="src-comm">// Call InputFilterTest::main() if this source file is executed directly.</span></li>
<li><a name="a183"></a><span class="src-key">if </span><span class="src-sym">(</span><span class="src-id"><a href="../PHPonTraxTest/_test_FormOptionsHelperTest_php.html#definePHPUnit2_MAIN_METHOD">PHPUnit2_MAIN_METHOD</a> </span>== <span class="src-str">"InputFilterTest::main"</span><span class="src-sym">) </span><span class="src-sym">{</span></li>
<li><a name="a184"></a> <span class="src-id"><a href="../PHPonTraxTest/InputFilterTest.html">InputFilterTest</a></span><span class="src-sym">::</span><a href="../PHPonTraxTest/InputFilterTest.html#methodmain">main</a><span class="src-sym">(</span><span class="src-sym">)</span><span class="src-sym">;</span></li>
<li><a name="a185"></a><span class="src-sym">}</span></li>
<li><a name="a186"></a> </li>
<li><a name="a187"></a><span class="src-comm">// -- set Emacs parameters --</span></li>
<li><a name="a188"></a><span class="src-comm">// Local variables:</span></li>
<li><a name="a189"></a><span class="src-comm">// tab-width: 4</span></li>
<li><a name="a190"></a><span class="src-comm">// c-basic-offset: 4</span></li>
<li><a name="a191"></a><span class="src-comm">// c-hanging-comment-ender-p: nil</span></li>
<li><a name="a192"></a><span class="src-comm">// indent-tabs-mode: nil</span></li>
<li><a name="a193"></a><span class="src-comm">// End:</span></li>
<li><a name="a194"></a><span class="src-php">?></span></li>
</ol></pre></div>
</div>
<div class="credit">
<hr />
Documentation generated on Thu, 04 May 2006 19:47:47 -0600 by <a href="http://www.phpdoc.org">phpDocumentor 1.3.0RC4</a>
</div>
</td></tr></table>
</td>
</tr>
</table>
</body>
</html>