move to Pylons 0.9.7 and related packages
This commit is contained in:
parent
787f6050d4
commit
30b74165c6
28 changed files with 199 additions and 173 deletions
|
|
@ -1,41 +1,36 @@
|
|||
"""Pylons application test package
|
||||
|
||||
When the test runner finds and executes tests within this directory,
|
||||
this file will be loaded to setup the test environment.
|
||||
This package assumes the Pylons environment is already loaded, such as
|
||||
when this script is imported from the `nosetests --with-pylons=test.ini`
|
||||
command.
|
||||
|
||||
It registers the root directory of the project in sys.path and
|
||||
pkg_resources, in case the project hasn't been installed with
|
||||
setuptools. It also initializes the application via websetup (paster
|
||||
setup-app) with the project's test.ini configuration file.
|
||||
This module initializes the application via ``websetup`` (`paster
|
||||
setup-app`) and provides the base testing objects.
|
||||
"""
|
||||
import os
|
||||
import sys
|
||||
from unittest import TestCase
|
||||
|
||||
import pkg_resources
|
||||
import paste.fixture
|
||||
import paste.script.appinstall
|
||||
from paste.deploy import loadapp
|
||||
from routes import url_for
|
||||
from paste.script.appinstall import SetupCommand
|
||||
from pylons import config, url
|
||||
from routes.util import URLGenerator
|
||||
from webtest import TestApp
|
||||
|
||||
__all__ = ['url_for', 'TestController']
|
||||
import pylons.test
|
||||
|
||||
here_dir = os.path.dirname(os.path.abspath(__file__))
|
||||
conf_dir = os.path.dirname(os.path.dirname(here_dir))
|
||||
__all__ = ['environ', 'url', 'TestController']
|
||||
|
||||
sys.path.insert(0, conf_dir)
|
||||
pkg_resources.working_set.add_entry(conf_dir)
|
||||
pkg_resources.require('Paste')
|
||||
pkg_resources.require('PasteScript')
|
||||
|
||||
test_file = os.path.join(conf_dir, 'test.ini')
|
||||
cmd = paste.script.appinstall.SetupCommand('setup-app')
|
||||
cmd.run([test_file])
|
||||
# Invoke websetup with the current config file
|
||||
SetupCommand('setup-app').run([config['__file__']])
|
||||
|
||||
environ = {}
|
||||
|
||||
class TestController(TestCase):
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
wsgiapp = loadapp('config:test.ini', relative_to=conf_dir)
|
||||
self.app = paste.fixture.TestApp(wsgiapp)
|
||||
if pylons.test.pylonsapp:
|
||||
wsgiapp = pylons.test.pylonsapp
|
||||
else:
|
||||
wsgiapp = loadapp('config:%s' % config['__file__'])
|
||||
self.app = TestApp(wsgiapp)
|
||||
url._push_object(URLGenerator(config['routes.map'], environ))
|
||||
TestCase.__init__(self, *args, **kwargs)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue