やあ、
tastypieを13.3からheadに更新すると、Webアプリを実行しようとすると次のエラーがスローされます。
Request Method: GET
Request URL: http://192.168.0.104:8888/accounts/login/?next=/dashboard/
Django Version: 1.8.8
Python Version: 2.7.12
Installed Applications:
('longerusernameandemail',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'tastypie',
'myapp',
'widget_tweaks',
'corsheaders')
Installed Middleware:
('corsheaders.middleware.CorsMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware')
Traceback:
File "/home/user/anaconda2/lib/python2.7/site-packages/django/core/handlers/base.py" in get_response
119. resolver_match = resolver.resolve(request.path_info)
File "/home/user/anaconda2/lib/python2.7/site-packages/django/core/urlresolvers.py" in resolve
365. for pattern in self.url_patterns:
File "/home/user/anaconda2/lib/python2.7/site-packages/django/core/urlresolvers.py" in url_patterns
401. patterns = getattr(self.urlconf_module, "urlpatterns", self.urlconf_module)
File "/home/user/anaconda2/lib/python2.7/site-packages/django/core/urlresolvers.py" in urlconf_module
395. self._urlconf_module = import_module(self.urlconf_name)
File "/home/user/anaconda2/lib/python2.7/importlib/__init__.py" in import_module
37. __import__(name)
File "/home/user/webserver/myapp/urls.py" in <module>
7. from myapp.api import UserResource
File "/home/user/webserver/myapp/api.py" in <module>
303. class MyResource(ModelResource):
File "/home/user/anaconda2/lib/python2.7/site-packages/tastypie/resources.py" in __new__
1797. if meta and meta.object_class:
Exception Type: AttributeError at /accounts/login/
Exception Value: class Meta has no attribute 'object_class'
バージョン13.3(commit a71dd6e85e18ec38e978e904c0c7a91dee11043d)に戻すと、正常に動作します。
何が間違っているのでしょうか?
ありがとう
リソースを投稿していただけますか?
urls.pyで、 tastypie.api.Api
をインポートしてから、リソースを1つずつインポートします。 最初のリソースを読み込もうとするとすぐに失敗するようです。 たとえば、これはリソースの1つですが、これをコメントアウトしても、次のリソースでクラッシュします。
class MyResource(ModelResource):
class Meta:
queryset = MyModel.objects.all()
fields = ['my_field']
allowed_methods = ['get']
resource_name = 'my_resource'
authentication = BasicAuthentication()
include_resource_uri = False
回帰テストを追加しましたが、エラーを再現できませんでした:3e1f5527b698c7121d4c5434d073b08d364d31f2
あなたが提供できる他の情報はありますか? コードサンプルは実際のコードにどの程度近いですか?
これを調べてくれたSeanに感謝します。 サンプルコードは非常によく似ており、基本的に名前を変更しただけです。 私は自分の側でもう一度チェックし、関連していて欠落している可能性のある要素があるかどうかを確認しようとします。
最後に、詳細がありましたら、お気軽にコメントしてください。
@SeanHayes :抽象ベースリソースを使用していたため、これと同じ問題が発生しました。 これが複製です:
class BaseResource(ModelResource):
class Meta:
authentication = DefaultAuthentication()
class FooResource(BaseResource):
class Meta(BaseResource.Meta):
resource_name = 'foo'
queryset = Foo.objects.all()
class BarResource(BaseResource):
class Meta(BaseResource.Meta):
resource_name = 'bar'
queryset = Bar.objects.all()
BaseResourceにはクエリセットがないため、これは、hashemianによって行class BaseResource(ModelResource):
に貼り付けられた同じスタックトレースで失敗します。
今のところ私の回避策は、 object_class = None
をBaseResource.Meta
に追加することです。そうすれば、すべてが機能します。
実際の修正は、resources.py行1797をif meta and getattr(meta, 'object_class'):
に変更することだと思います
...または、querysetが設定されていないときにModelResourceサブクラスがエラーをスローすることが望ましい動作である場合、そのエラーはより明示的になる可能性があります。 BaseResourceが失敗することはないと思いますが、それ以来、ここでやろうとしていることをどのように行うかがわかりません。
ありがとう!
最も参考になるコメント
@SeanHayes :抽象ベースリソースを使用していたため、これと同じ問題が発生しました。 これが複製です:
BaseResourceにはクエリセットがないため、これは、hashemianによって行
class BaseResource(ModelResource):
に貼り付けられた同じスタックトレースで失敗します。今のところ私の回避策は、
object_class = None
をBaseResource.Meta
に追加することです。そうすれば、すべてが機能します。実際の修正は、resources.py行1797を
if meta and getattr(meta, 'object_class'):
に変更することだと思います...または、querysetが設定されていないときにModelResourceサブクラスがエラーをスローすることが望ましい動作である場合、そのエラーはより明示的になる可能性があります。 BaseResourceが失敗することはないと思いますが、それ以来、ここでやろうとしていることをどのように行うかがわかりません。
ありがとう!