X-Git-Url: https://gerrit.opnfv.org/gerrit/gitweb?a=blobdiff_plain;f=api%2Fserver.py;h=1d42feffb0f09ba335c8b70d316a924e537bf5a9;hb=d27e5aa9fd79f80638f4a5616d4341758300c831;hp=fac821b00f8a8cf4b6f1dd20becf2acca060dd55;hpb=8d702f720aeb9566adb258e886c12a348bedc84b;p=yardstick.git diff --git a/api/server.py b/api/server.py index fac821b00..1d42feffb 100644 --- a/api/server.py +++ b/api/server.py @@ -6,14 +6,20 @@ # which accompanies this distribution, and is available at # http://www.apache.org/licenses/LICENSE-2.0 ############################################################################## +from __future__ import absolute_import + +import inspect import logging +from six.moves import filter +from flasgger import Swagger from flask import Flask from flask_restful import Api -from flasgger import Swagger -from api.database import init_db +from api.database import Base from api.database import db_session +from api.database import engine +from api.database import models from api.urls import urlpatterns from yardstick import _init_logging @@ -21,8 +27,6 @@ logger = logging.getLogger(__name__) app = Flask(__name__) -init_db() - Swagger(app) api = Api(app) @@ -33,11 +37,32 @@ def shutdown_session(exception=None): db_session.remove() -reduce(lambda a, b: a.add_resource(b.resource, b.url, - endpoint=b.endpoint) or a, urlpatterns, api) +for u in urlpatterns: + api.add_resource(u.resource, u.url, endpoint=u.endpoint) + + +def init_db(): + def func(a): + try: + if issubclass(a[1], Base): + return True + except TypeError: + pass + return False + + subclses = filter(func, inspect.getmembers(models, inspect.isclass)) + logger.debug('Import models: %s', [a[1] for a in subclses]) + Base.metadata.create_all(bind=engine) + + +def app_wrapper(*args, **kwargs): + init_db() + return app(*args, **kwargs) + if __name__ == '__main__': _init_logging() logger.setLevel(logging.DEBUG) logger.info('Starting server') + init_db() app.run(host='0.0.0.0')