summaryrefslogtreecommitdiff
path: root/docs/quick_tour
diff options
context:
space:
mode:
authorSteve Piercy <web@stevepiercy.com>2021-01-09 07:55:02 -0800
committerSteve Piercy <web@stevepiercy.com>2021-01-09 07:55:02 -0800
commitab8b801d5ac13feac86219ad8860f0426140d0de (patch)
tree3409ceacef059302183a1c7fc0efbed62e61a00f /docs/quick_tour
parent8143e8679b5025a648272ec17942307c243c59b5 (diff)
downloadpyramid-ab8b801d5ac13feac86219ad8860f0426140d0de.tar.gz
pyramid-ab8b801d5ac13feac86219ad8860f0426140d0de.tar.bz2
pyramid-ab8b801d5ac13feac86219ad8860f0426140d0de.zip
Update Quick Tutorial and Quick Tour cookiecutter steps
Diffstat (limited to 'docs/quick_tour')
-rw-r--r--docs/quick_tour/package/tests/conftest.py76
-rw-r--r--docs/quick_tour/package/tests/test_functional.py7
-rw-r--r--docs/quick_tour/package/tests/test_it.py39
-rw-r--r--docs/quick_tour/package/tests/test_views.py13
4 files changed, 96 insertions, 39 deletions
diff --git a/docs/quick_tour/package/tests/conftest.py b/docs/quick_tour/package/tests/conftest.py
new file mode 100644
index 000000000..adc1e0f3f
--- /dev/null
+++ b/docs/quick_tour/package/tests/conftest.py
@@ -0,0 +1,76 @@
+import os
+from pyramid.paster import get_appsettings
+from pyramid.scripting import prepare
+from pyramid.testing import DummyRequest, testConfig
+import pytest
+import webtest
+
+from hello_world import main
+
+
+def pytest_addoption(parser):
+ parser.addoption('--ini', action='store', metavar='INI_FILE')
+
+@pytest.fixture(scope='session')
+def ini_file(request):
+ # potentially grab this path from a pytest option
+ return os.path.abspath(request.config.option.ini or 'testing.ini')
+
+@pytest.fixture(scope='session')
+def app_settings(ini_file):
+ return get_appsettings(ini_file)
+
+@pytest.fixture(scope='session')
+def app(app_settings):
+ return main({}, **app_settings)
+
+@pytest.fixture
+def testapp(app):
+ testapp = webtest.TestApp(app, extra_environ={
+ 'HTTP_HOST': 'example.com',
+ })
+
+ return testapp
+
+@pytest.fixture
+def app_request(app):
+ """
+ A real request.
+
+ This request is almost identical to a real request but it has some
+ drawbacks in tests as it's harder to mock data and is heavier.
+
+ """
+ with prepare(registry=app.registry) as env:
+ request = env['request']
+ request.host = 'example.com'
+ yield request
+
+@pytest.fixture
+def dummy_request():
+ """
+ A lightweight dummy request.
+
+ This request is ultra-lightweight and should be used only when the request
+ itself is not a large focus in the call-stack. It is much easier to mock
+ and control side-effects using this object, however:
+
+ - It does not have request extensions applied.
+ - Threadlocals are not properly pushed.
+
+ """
+ request = DummyRequest()
+ request.host = 'example.com'
+
+ return request
+
+@pytest.fixture
+def dummy_config(dummy_request):
+ """
+ A dummy :class:`pyramid.config.Configurator` object. This allows for
+ mock configuration, including configuration for ``dummy_request``, as well
+ as pushing the appropriate threadlocals.
+
+ """
+ with testConfig(request=dummy_request) as config:
+ yield config
diff --git a/docs/quick_tour/package/tests/test_functional.py b/docs/quick_tour/package/tests/test_functional.py
new file mode 100644
index 000000000..bac5d63f4
--- /dev/null
+++ b/docs/quick_tour/package/tests/test_functional.py
@@ -0,0 +1,7 @@
+def test_root(testapp):
+ res = testapp.get('/', status=200)
+ assert b'Pyramid' in res.body
+
+def test_notfound(testapp):
+ res = testapp.get('/badurl', status=404)
+ assert res.status_code == 404
diff --git a/docs/quick_tour/package/tests/test_it.py b/docs/quick_tour/package/tests/test_it.py
deleted file mode 100644
index 90c6302fe..000000000
--- a/docs/quick_tour/package/tests/test_it.py
+++ /dev/null
@@ -1,39 +0,0 @@
-import unittest
-
-from pyramid import testing
-
-
-class ViewTests(unittest.TestCase):
- def setUp(self):
- self.config = testing.setUp()
-
- def tearDown(self):
- testing.tearDown()
-
- def test_my_view(self):
- from hello_world.views.default import my_view
- request = testing.DummyRequest()
- info = my_view(request)
- self.assertEqual(info['project'], 'hello_world')
-
- def test_notfound_view(self):
- from hello_world.views.notfound import notfound_view
- request = testing.DummyRequest()
- info = notfound_view(request)
- self.assertEqual(info, {})
-
-
-class FunctionalTests(unittest.TestCase):
- def setUp(self):
- from hello_world import main
- app = main({})
- from webtest import TestApp
- self.testapp = TestApp(app)
-
- def test_root(self):
- res = self.testapp.get('/', status=200)
- self.assertTrue(b'Pyramid' in res.body)
-
- def test_notfound(self):
- res = self.testapp.get('/badurl', status=404)
- self.assertTrue(res.status_code == 404)
diff --git a/docs/quick_tour/package/tests/test_views.py b/docs/quick_tour/package/tests/test_views.py
new file mode 100644
index 000000000..0b019fe82
--- /dev/null
+++ b/docs/quick_tour/package/tests/test_views.py
@@ -0,0 +1,13 @@
+from hello_world.views.default import my_view
+from hello_world.views.notfound import notfound_view
+
+
+def test_my_view(app_request):
+ info = my_view(app_request)
+ assert app_request.response.status_int == 200
+ assert info['project'] == 'hello_world'
+
+def test_notfound_view(app_request):
+ info = notfound_view(app_request)
+ assert app_request.response.status_int == 404
+ assert info == {}