Как исправить ошибку «flask db.create_all ()»? - PullRequest
0 голосов
/ 11 апреля 2019

У меня есть колба init с функцией создания приложения.Я создаю тестовый файл для моих юнитов.В классе unitest добавьте функцию setUp, где я создаю новое приложение фляги и добавляю контекст, вставляю в него контекст.Затем я создаю тестовую базу данных с помощью функции create_all () и, где я запускаю тестовый файл, у меня появляется следующая ошибка:

in _execute_for_all_tables op(bind=self.get_engine(app, bind), **extra) 

TypeError: create_all () получил неожиданный аргумент ключевого слова 'формы' у меня нет 'файлы форм или переменные на моделях или где-либо еще.

Перед этой ошибкой поместите в flask_sqlalchemy / init .py MetaData (bind = None), может быть, это какая-то помощь.


from flask import Flask
from config import Config
from blocker_application.database import db
from flask_migrate import Migrate
from flask_login import LoginManager
from flask_moment import Moment

migrate = Migrate()
login = LoginManager()
login.login_view = 'user.login'
moment = Moment()


def create_app(config_class=Config):
    app = Flask(__name__)
    app.config.from_object(config_class)

    db.init_app(app)
    migrate.init_app(app, db)
    login.init_app(app)
    moment.init_app(app)

    from blocker_application.main.routes import bp_main
    from blocker_application.errors.handlers import bp_error
    from blocker_application.reports.routes import bp_reports
    from blocker_application.user.routes import bp_user
    from blocker_application.applications.routes import bp_applications
    app.register_blueprint(bp_main)
    app.register_blueprint(bp_error)
    app.register_blueprint(bp_reports, url_prefix='/reports')
    app.register_blueprint(bp_user, url_prefix='/user')
    app.register_blueprint(bp_applications, url_prefix='/applications')


    return app

from blocker_application import models
________________________________________________________________________

/config.py

import os

basedir = os.path.abspath(os.path.dirname(__file__))


class Config:
    SECRET_KEY = os.environ.get('SECRET_KEY') or 'not realy finish secret key configuration'
    SQLALCHEMY_DATABASE_URI = 'mysql://some_database'
    SQLALCHEMY_TRACK_MODIFICATIONS = False

class TestConfig(Config):
    TESTING = True
    SQLALCHEMY_BINDS = {'test': 'mysql://some_database_test'}
______________________________________________________________________

/tests.py

import unittest
from blocker_application import create_app, db
from blocker_application import models
from config import TestConfig


class UserModelCase(unittest.TestCase):
    def setUp(self):
        self.app = create_app(TestConfig)
        self.app_context = self.app.app_context()
        self.app_context.push()
        db.create_all(bind='test')

    def tearDown(self):
        db.session.remove()
        db.drop_all(bind='test')
        self.app_context.pop()

    def test_password(self):
        u = models.User(username='Mark')
        u.set_password('Mark')
        self.assertTrue(u.check_password('Mark'))
        self.assertFalse(u.check_password('Tony'))

if __name__ == '__main__':
    unittest.main(verbosity=2)

1 Ответ

0 голосов
/ 12 апреля 2019

Я нашел решение.Unittest работает нормально, после воссоздания виртуальной среды.

...