<p>Hi,<br>
Inline response follows:<br>
On Apr 20, 2011 6:24 AM, &quot;Daniel Kastl&quot; &lt;<a href="mailto:daniel@georepublic.de">daniel@georepublic.de</a>&gt; wrote:<br>
&gt; I had actually made a ticket for unit tests some time ago: <br>
Thanks to let me know that I&#39;m heading in the right direction.</p>
<p>&gt; Have you looked at how PostGIS is doing it? There is some chance that pgRouting and PostGIS will merge (someday), so then it would be good to have something that fits already.<br>
Well, it didn&#39;t occur to me previously. I am hoping that looking at PostGIS&#39;s tests will solve most problems. I got busy with college stuff recently and hope to go through it in a couple of days. </p>
<p>&gt; One important point is in my opinion to have some suitable network graph for testing. <br>
&gt; Something that can cover all test cases and can eventually give some visual.<br>
Ah, I added that simple test data and the simple test case more as a hello world of unittests and hence will replace with some large, real data soon.</p>
<p>Thanks &amp; regards,<br>
J Kishore Kumar.</p>
<p>&gt; 2011/4/20 Kishore Kumar &lt;<a href="mailto:justjkk@gmail.com">justjkk@gmail.com</a>&gt;<br>
&gt;&gt;<br>
&gt;&gt; Hi,<br>
&gt;&gt;<br>
&gt;&gt; I was exploring on ways to improve the pgrouting codebase and make it suited for easier development. It struck me that writing unittests for all the pgrouting functions will help with both documentation as well as reduce the overhead of manual testing. Initially I tried using google&#39;s c++ testing framework[1] to test the c and c++ functions but encountered problems because the c functions were using postgresql library and decoupling psql interactions from the core algorithm seemed too much of a rewrite for testing.<br>

&gt;&gt;<br>
&gt;&gt; Hence, I resolved to implementing black box testing of individual SQL functions. Since this can be done independent of the language constraints, I explored opportunities with using python. I found python&#39;s unittest framework to be both light and flexible for the purpose. The initial attempts can be found in my python_unittests branch[2].<br>

&gt;&gt;<br>
&gt;&gt; The problem I&#39;m facing is to run the tests between &#39;make&#39; and &#39;make install&#39; stages. Currently, the tests are run against the installed version of pgrouting found at $libdir so that testing can be done only after installing.<br>

&gt;&gt;<br>
&gt;&gt; Will be glad to hear any problems with the current choice of tools or if the testing approach needs to be changed.<br>
&gt;&gt;<br>
&gt;&gt; -- <br>
&gt;&gt; Regards,<br>
&gt;&gt; J Kishore Kumar.<br>
&gt;&gt;<br>
&gt;&gt; [1] - <a href="http://code.google.com/p/googletest/">http://code.google.com/p/googletest/</a><br>
&gt;&gt; [2] - <a href="https://github.com/justjkk/pgrouting/commits/python_unittests">https://github.com/justjkk/pgrouting/commits/python_unittests</a><br>
&gt;&gt;<br>
&gt;&gt;<br>
&gt;&gt; _______________________________________________<br>
&gt;&gt; pgrouting-dev mailing list<br>
&gt;&gt; <a href="mailto:pgrouting-dev@lists.osgeo.org">pgrouting-dev@lists.osgeo.org</a><br>
&gt;&gt; <a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-dev">http://lists.osgeo.org/mailman/listinfo/pgrouting-dev</a><br>
&gt;&gt;<br>
&gt;<br>
&gt;<br>
&gt;<br>
&gt; -- <br>
&gt; Georepublic UG &amp; Georepublic Japan<br>
&gt; eMail: <a href="mailto:daniel.kastl@georepublic.de">daniel.kastl@georepublic.de</a><br>
&gt; Web: <a href="http://georepublic.de">http://georepublic.de</a><br>
&gt;<br>
&gt; _______________________________________________<br>
&gt; pgrouting-dev mailing list<br>
&gt; <a href="mailto:pgrouting-dev@lists.osgeo.org">pgrouting-dev@lists.osgeo.org</a><br>
&gt; <a href="http://lists.osgeo.org/mailman/listinfo/pgrouting-dev">http://lists.osgeo.org/mailman/listinfo/pgrouting-dev</a><br>
&gt;<br>
</p>