1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215
|
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<link rel="STYLESHEET" href="modpython.css" type='text/css'>
<link rel="first" href="modpython.html" title='Mod_python Manual'>
<link rel='contents' href='contents.html' title="Contents">
<link rel='index' href='genindex.html' title='Index'>
<link rel='last' href='about.html' title='About this document...'>
<link rel='help' href='about.html' title='About this document...'>
<LINK REL="next" href="inst-trouble.html">
<LINK REL="prev" href="inst-installing.html">
<LINK REL="parent" href="installation.html">
<LINK REL="next" href="inst-trouble.html">
<meta name='aesop' content='information'>
<META NAME="description" CONTENT="Testing">
<META NAME="keywords" CONTENT="modpython">
<META NAME="resource-type" CONTENT="document">
<META NAME="distribution" CONTENT="global">
<title>2.4 Testing</title>
</head>
<body>
<DIV CLASS="navigation">
<table align="center" width="100%" cellpadding="0" cellspacing="2">
<tr>
<td><a rel="prev" title="2.3.2 Configuring Apache"
href="inst-apacheconfig.html"><img src='previous.gif'
border='0' height='32' alt='Previous Page' width='32'></A></td>
<td><a rel="parent" title="2. Installation"
href="installation.html"><img src='up.gif'
border='0' height='32' alt='Up One Level' width='32'></A></td>
<td><a rel="next" title="2.5 Troubleshooting"
href="inst-trouble.html"><img src='next.gif'
border='0' height='32' alt='Next Page' width='32'></A></td>
<td align="center" width="100%">Mod_python Manual</td>
<td><a rel="contents" title="Table of Contents"
href="contents.html"><img src='contents.gif'
border='0' height='32' alt='Contents' width='32'></A></td>
<td><img src='blank.gif'
border='0' height='32' alt='' width='32'></td>
<td><a rel="index" title="Index"
href="genindex.html"><img src='index.gif'
border='0' height='32' alt='Index' width='32'></A></td>
</tr></table>
<b class="navlabel">Previous:</b>
<a class="sectref" rel="prev" href="inst-apacheconfig.html">2.3.2 Configuring Apache</A>
<b class="navlabel">Up:</b>
<a class="sectref" rel="parent" href="installation.html">2. Installation</A>
<b class="navlabel">Next:</b>
<a class="sectref" rel="next" href="inst-trouble.html">2.5 Troubleshooting</A>
<br><hr>
</DIV>
<!--End of Navigation Panel-->
<H1><A NAME="SECTION004400000000000000000"> </A>
<BR>
2.4 Testing
</H1>
<P>
<b>Warning :</b> These instructions are meant to be followed if you are
using mod_python 3.x or later. If you are using mod_python 2.7.x (namely,
if you are using Apache 1.3.x), please refer to the proper documentation.
<P>
<OL>
<LI>Make some directory that would be visible on your web site, for
example, htdocs/test.
<P>
</LI>
<LI>Add the following Apache directives, which can appear in either the
main server configuration file, or <span class="file">.htaccess</span>. If you are
going to be using the <span class="file">.htaccess</span> file, you will not need the
<code><Directory></code> tag below (the directory then becomes the one in
which the <span class="file">.htaccess</span> file is located), and you will need to
make sure the <code>AllowOverride</code> directive applicable to this
directory has at least <code>FileInfo</code> specified. (The default is
<code>None</code>, which will not work.)
<P>
<div class="verbatim"><pre>
<Directory /some/directory/htdocs/test>
AddHandler mod_python .py
PythonHandler mptest
PythonDebug On
</Directory>
</pre></div>
<P>
(Substitute <span class="file">/some/directory</span> above for something applicable to
your system, usually your Apache ServerRoot)
<P>
</LI>
<LI>This redirects all requests for URLs ending in <span class="file">.py</span> to the mod_python
handler. mod_python receives those requests and looks for an appropriate
PythonHandler to handle them. Here, there is a single PythonHandler
directive defining mptest as the python handler to use. We'll see next
how this python handler is defined.
<P>
</LI>
<LI>At this time, if you made changes to the main configuration file, you
will need to restart Apache in order for the changes to take effect.
<P>
</LI>
<LI>Edit <span class="file">mptest.py</span> file in the <span class="file">htdocs/test</span> directory so
that is has the following lines (be careful when cutting and pasting
from your browser, you may end up with incorrect indentation and a
syntax error):
<P>
<div class="verbatim"><pre>
from mod_python import apache
def handler(req):
req.content_type = 'text/plain'
req.write("Hello World!")
return apache.OK
</pre></div>
<P>
</LI>
<LI>Point your browser to the URL referring to the <span class="file">mptest.py</span>;
you should see "<tt class="samp">Hello World!</tt>". If you didn't - refer to the
troubleshooting section next.
<P>
</LI>
<LI>Note that according to the configuration written above, you can
also point your browser to any URL ending in .py in the test directory.
You can for example point your browser to <span class="file">/test/foobar.py</span>
and it will be handled by <span class="file">mptest.py</span>. That's because you
explicitely set the handler to always be <span class="file">mptest</span>, whatever the
requested file was. If you want to have many handler files named
<span class="file">handler1.py</span>, <span class="file">handler2.py</span>
and so on, and have them accessible on <span class="file">/test/handler1.py</span>,
<span class="file">/test/handler2.py</span>, etc., then you have to use a higher level
handler system such as the mod_python publisher (see <A href="tut-pub.html#tut-pub">3.1</A>),
mpservlets or Vampire. Those are just special mod_python handler
that know how to map requests to a dynamically loaded handler.
<P>
</LI>
<LI>If everything worked well, move on to Chapter <A href="tutorial.html#tutorial">3</A>,
<em class="citetitle"><a
href="tutorial.html"
title="Tutorial"
>Tutorial</a></em>.
<P>
</LI>
</OL>
<P>
<div class="seealso">
<p class="heading"><b>See Also:</b></p>
<dl compact class="seeurl">
<dt><a href="http://home.comcast.net/ d.popowich/mpservlets"
class="url">http://home.comcast.net/ d.popowich/mpservlets</a>
<dd>mpservlets
</dl>
<dl compact class="seeurl">
<dt><a href="http://www.dscpl.com.au/projects/vampire"
class="url">http://www.dscpl.com.au/projects/vampire</a>
<dd>Vampire
</dl>
</div>
<P>
<DIV CLASS="navigation">
<p><hr>
<table align="center" width="100%" cellpadding="0" cellspacing="2">
<tr>
<td><a rel="prev" title="2.3.2 Configuring Apache"
rel="prev" title="2.3.2 Configuring Apache"
href="inst-apacheconfig.html"><img src='previous.gif'
border='0' height='32' alt='Previous Page' width='32'></A></td>
<td><a rel="parent" title="2. Installation"
rel="parent" title="2. Installation"
href="installation.html"><img src='up.gif'
border='0' height='32' alt='Up One Level' width='32'></A></td>
<td><a rel="next" title="2.5 Troubleshooting"
rel="next" title="2.5 Troubleshooting"
href="inst-trouble.html"><img src='next.gif'
border='0' height='32' alt='Next Page' width='32'></A></td>
<td align="center" width="100%">Mod_python Manual</td>
<td><a rel="contents" title="Table of Contents"
rel="contents" title="Table of Contents"
href="contents.html"><img src='contents.gif'
border='0' height='32' alt='Contents' width='32'></A></td>
<td><img src='blank.gif'
border='0' height='32' alt='' width='32'></td>
<td><a rel="index" title="Index"
rel="index" title="Index"
href="genindex.html"><img src='index.gif'
border='0' height='32' alt='Index' width='32'></A></td>
</tr></table>
<b class="navlabel">Previous:</b>
<a class="sectref" rel="prev" href="inst-apacheconfig.html">2.3.2 Configuring Apache</A>
<b class="navlabel">Up:</b>
<a class="sectref" rel="parent" href="installation.html">2. Installation</A>
<b class="navlabel">Next:</b>
<a class="sectref" rel="next" href="inst-trouble.html">2.5 Troubleshooting</A>
<hr>
<span class="release-info">Release 3.2.10, documentation updated on July 19, 2006.</span>
</DIV>
<!--End of Navigation Panel-->
</BODY>
</HTML>
|