Child: [3abb2e] (diff)

Download this file

__init__.py    63 lines (47 with data), 1.9 kB

 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
# -*- coding: utf-8 -*-
"""Unit and functional test suite for pyforge."""
from os import path, environ
import sys
from tg import config
from paste.deploy import loadapp
from paste.script.appinstall import SetupCommand
from routes import url_for
from webtest import TestApp
from nose.tools import eq_
from pyforge import model
__all__ = ['setup_db', 'teardown_db', 'TestController', 'url_for']
def setup_db():
"""Method used to build a database"""
pass
def teardown_db():
"""Method used to destroy a database"""
pass
class TestController(object):
"""
Base functional test case for the controllers.
The pyforge application instance (``self.app``) set up in this test
case (and descendants) has authentication disabled, so that developers can
test the protected areas independently of the :mod:`repoze.who` plugins
used initially. This way, authentication can be tested once and separately.
Check pyforge.tests.functional.test_authentication for the repoze.who
integration tests.
This is the officially supported way to test protected areas with
repoze.who-testutil (http://code.gustavonarea.net/repoze.who-testutil/).
"""
application_under_test = 'main'
test_config = environ.get('SANDBOX') and 'sandbox-test.ini' or 'test.ini'
def setUp(self):
"""Method called by nose before running each test"""
# Loading the application:
conf_dir = config.here = path.abspath(
path.dirname(__file__) + '/../..')
wsgiapp = loadapp('config:%s#%s' % (self.test_config, self.application_under_test),
relative_to=conf_dir)
self.app = TestApp(wsgiapp)
# Setting it up:
test_file = path.join(conf_dir, self.test_config)
cmd = SetupCommand('setup-app')
cmd.run([test_file])
def tearDown(self):
"""Method called by nose after running each test"""
pass