2020-07-25 22:39:00 +01:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
|
|
|
<title>Handbook Troggle - Unit Tests</title>
|
|
|
|
<link rel="stylesheet" type="text/css" href="../../css/main2.css" />
|
|
|
|
</head>
|
|
|
|
<body><style>body { background: #fff url(/images/style/bg-system.png) repeat-x 0 0 }</style>
|
|
|
|
<h2 id="tophead">CUCC Expedition Handbook</h2>
|
|
|
|
<h1>Handbook Troggle - Unit Tests</h1>
|
|
|
|
|
|
|
|
<h2>Troggle Unit Tests</h2>
|
|
|
|
<p>We have a small suite of tests which are run manually by troggle programmers like this:
|
2021-02-05 01:11:12 +00:00
|
|
|
<pre><code> troggle$ python manage.py test -v 1</code></pre>
|
2020-07-25 22:39:00 +01:00
|
|
|
The test code is all in <a href="http://expo.survex.com/repositories/troggle/.git/tree/core/TESTS/tests.py"><var>troggle/core/TESTS/tests.py</var></a>.
|
|
|
|
<p>The test 'test_page_expofile' checks that a particular PDF is being served correctly by the web server
|
|
|
|
and that the resulting page is the correct length of 2,299,270 bytes:
|
|
|
|
|
|
|
|
<pre><code>
|
|
|
|
def test_page_expofile(self):
|
|
|
|
# Flat file tests.
|
|
|
|
response = self.client.get('/expofiles/documents/surveying/tunnel-loefflerCP35-only.pdf')
|
|
|
|
self.assertEqual(response.status_code, 200)
|
|
|
|
self.assertEqual(len(response.content), 2299270)
|
|
|
|
</code></pre>
|
|
|
|
|
|
|
|
<p>This test suite is part of <a href="https://docs.djangoproject.com/en/1.11/topics/testing/">the
|
|
|
|
django test system</a> which is a very thin layer on top of the standard python library module
|
|
|
|
<a href="https://docs.python.org/3/library/unittest.html#module-unittest">unittest</a>. One of the things this layer does
|
|
|
|
is to ensure that all the settings are imported correctly, and it sets up a very fast in-memory sqlite database purely for tests.
|
|
|
|
No tests are run with the real expo database.
|
|
|
|
<p>The tests can be run at a more verbose level by setting the <var>-v 3</var> flag.
|
|
|
|
|
2021-04-21 20:41:01 +01:00
|
|
|
<p>As yet we have no test database set up, so the in-memory database is entirely empty. However we have 'fixtures' in
|
|
|
|
<var>troggle/core/fixtures/ </var>
|
|
|
|
which are JSON files containing dummy data which is used in the more complex tests.
|
|
|
|
|
|
|
|
<p>If you want to write some tests and are having trouble finding something which is untested, have a look at the list of
|
|
|
|
url paths in the routing system in <var>troggle/urls.py</var>
|
|
|
|
and look for types of url which do not appear in the test suite checks.
|
2020-07-25 22:39:00 +01:00
|
|
|
|
|
|
|
<hr />
|
|
|
|
Go on to: <a href="trogarch.html">Troggle architecture</a><br />
|
|
|
|
Return to: <a href="trogintro.html">Troggle intro</a><br />
|
2020-07-27 01:42:09 +01:00
|
|
|
Troggle index:
|
|
|
|
<a href="trogindex.html">Index of all troggle documents</a><br /><hr />
|
2020-07-25 22:39:00 +01:00
|
|
|
</body>
|
|
|
|
</html>
|