Browse Source

Account for make_app()

pull/2294/head
Hendrik Makait 8 years ago
parent
commit
ce88135c3b
  1. 12
      flask/cli.py
  2. 7
      tests/test_cli.py

12
flask/cli.py

@ -47,17 +47,19 @@ def find_best_app(module):
if len(matches) == 1: if len(matches) == 1:
return matches[0] return matches[0]
# Search for app factory callable. # Search for app factory callables.
app_factory = getattr(module, 'create_app', None) for attr_name in 'create_app', 'make_app':
app_factory = getattr(module, attr_name, None)
if app_factory is not None and callable(app_factory): if app_factory is not None and callable(app_factory):
try: try:
app = app_factory() app = app_factory()
if app is not None and isinstance(app, Flask): if app is not None and isinstance(app, Flask):
return app return app
except TypeError: except TypeError:
raise NoAppException('Auto-detected a create_app() function in ' raise NoAppException('Auto-detected "%s()" in module "%s", '
'module "%s", but could not call it without ' 'but could not call it without '
'specifying arguments.' % module.__name__) 'specifying arguments.'
% (attr_name, module.__name__))
raise NoAppException('Failed to find application in module "%s". Are ' raise NoAppException('Failed to find application in module "%s". Are '
'you sure it contains a Flask application? Maybe ' 'you sure it contains a Flask application? Maybe '

7
tests/test_cli.py

@ -58,6 +58,13 @@ def test_find_best_app(test_apps):
assert isinstance(find_best_app(Module), Flask) assert isinstance(find_best_app(Module), Flask)
assert find_best_app(Module).name == 'appname' assert find_best_app(Module).name == 'appname'
class Module:
@staticmethod
def make_app():
return Flask('appname')
assert isinstance(find_best_app(Module), Flask)
assert find_best_app(Module).name == 'appname'
class Module: class Module:
myapp = Flask('appname1') myapp = Flask('appname1')
@staticmethod @staticmethod

Loading…
Cancel
Save