3

我在我设置的 django-reversion 系统的一些代码上遇到了一些问题。

我有一个ObjectClass继承自非抽象模型的 django 模型_concept很长的故事,现在非常不变。在代码的其余上下文中有意义。

在课堂上,_concept我将强制ForeignKey字段workgroup转到另一个模型。

我已经ObjectClass像这样注册了Django reversion:

reversion.unregister(ObjectClass)
reversion.register(ObjectClass,follow=['_concept_ptr'])

所有旧版本都保存并可以使用 'django-reversion-compare' 进行比较。不幸的是,当我点击任何旧版本查看历史版本时,我得到了错误:

RevertError at /module.py
Could not revert revision, due to database integrity errors.

在对 django-reversion 代码进行了一些挖掘之后,我做了一些摆弄,发现错误正在出现:

RelatedObjectDoesNotExist at /module.py
_concept has no workgroup.

现在我检查了数据库中存储的版本,发现了一些东西:

  1. 任何给定reversion.models.version的 _concept 历史在该serialized_data领域都有一个工作组(这是预期的)。
  2. 任何给定reversion.models.version的 a历史ObjectClass 都没有该字段中的任何父信息serialized_data(这是预期的)。
  3. 任何给定reversion.models.version的 an历史ObjectClass 都没有任何 a_concept_ptr在该serialized_data字段中(这是期望的)。

我怀疑django-reversion以下划线开头的字段可能存在问题,但是我还有其他以下划线开头的字段。

所以我在这里不知所措。有没有办法让这个模型设置像这样工作?


编辑:

经过更多检查后,似乎异常来自 Haystack 调用,这提醒我由于某种原因忽略了工作组has no workgroup的事实。reversion

我检查了数据库,这是为一个项目序列化的内容(为便于阅读而添加了换行符):

In [28]: myobj.serialized_data
Out[28]: u'[{"fields": {
               "definition": "<p>A code for sex.</p>\\r\\n",
               "_is_locked": false, 
               "workgroup": 3, 
               "created": "2015-12-27T07:45:10.409Z", 
               "modified": "2015-12-27T08:38:26.989Z", 
               "readyToReview": false, 
               "_is_public": false, 
               "name": "Sex Code"
             }, 
             "model": "aristotle_mdr._concept", "pk": 30}]'

编辑2:

禁用 haystack 索引器后,现在一切正常,问题是当 django-reversion 尝试保存项目以检查一致性时调用 Haystack 信号 - 然后 django 调用 haystackpost_save信号尝试使用不完整的数据更新索引。

仍然没有解决方案。我在我的 haystack 处理程序中需要的是一种确定我是否在修订事务中的方法,或者一种防止还原让这些信号触发的方法。后者可能是一个更好的长期目标,因为我怀疑仅仅通过查看修订它正在更新 Haystack 索引。

4

1 回答 1

2

所以你得出了一个结论prevent reversion from letting those signals fire

https://docs.djangoproject.com/en/dev/topics/signals/#disconnecting-signals

django-reversion 本身使用 Signal.connect 并自行断开连接。
https://github.com/etianen/django-reversion/blob/b2f5f3362054b2b72a95bee1ed0dfe2dd2301cda/src/reversion/revisions.py

我看你有几个选择。

  1. 找个好地方做disconnect/connect(我猜你需要覆盖reversion,但我不太了解)
  2. (覆盖反转)排除注册某些信号,例如 haystack。
  3. (override haystack, reversion) 在被保存对象上设置一个标志,并检查 haystack 信号中的标志以立即返回。
于 2016-01-04T13:53:53.073 回答