我有一个奇怪的应用启动错误,并想知道是否有人可能知道如何调试/解决它。
我正在使用python 3运行Flask应用程序。我通过运行python manage.py runserver
来启动它,并生成下面的堆栈跟踪:
Traceback (most recent call last):
File "/projectbase/manage.py", line 19, in <module>
create_tables()
File "/projectbase/myproject/__init__.py", line 15, in create_tables
from myproject.models.util import Weekday, weekday_type
File "<frozen importlib._bootstrap>", line 2237, in _find_and_load
File "<frozen importlib._bootstrap>", line 2226, in _find_and_load_unlocked
File "<frozen importlib._bootstrap>", line 1200, in _load_unlocked
File "<frozen importlib._bootstrap>", line 742, in __exit__
File "<frozen importlib._bootstrap>", line 742, in <genexpr>
TypeError: an integer is required (got type NoneType)
问题是,当我在调试器中运行它并设置断点时,问题就会消失。但如果我在没有调试的情况下运行它,则存在问题。
有关进一步的参考,manage.py代码/文件调用的create_tables()
函数如下所示:
from myproject.app import app
from myproject.app import db
def create_tables():
from myproject.models.util import Weekday, weekday_type
from myproject.models.activity import Activity, activities_tags, Occurrence, Tag
db.create_all()
问题的进一步Weekday
和weekday_type
代码如下:
from myproject.app import db
from myproject.models.enum import DeclEnum
class Weekday(DeclEnum):
Sunday = 'Sunday', {'offset': 0}
Monday = 'Monday', {'offset': 1}
Tuesday = 'Tuesday', {'offset': 2}
Wednesday = 'Wednesday', {'offset': 3}
Thursday = 'Thursday', {'offset': 4}
Friday = 'Friday', {'offset': 5}
Saturday = 'Saturday', {'offset': 6}
weekday_type = Weekday.db_type(metadata=db.metadata)
weekday_type.register_with_psycopg(db.engine)
我使用的DeclEnum
类型基本上只是从gist复制而来。
我对代码所做的唯一调整是让DeclEnum
更加灵活,因此它可以使用值词典而不仅仅是value
和description
。除此之外,我什么都没改变。
有什么想法在这里发生了什么?由于调试它的行为修复事情,我不知道如何解决问题的根源。
提前致谢。
答案 0 :(得分:0)
该错误具有误导性。
查看我在原始问题中链接的gist
方法register_with_psycopg()
仅在首次在数据库中创建枚举类型时才有效。我在创建类型之前调用了该方法。通过在应用启动期间更改事物的顺序,错误就消失了。