-
Notifications
You must be signed in to change notification settings - Fork 40
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
versions: calculate record's active versions #274
base: master
Are you sure you want to change the base?
versions: calculate record's active versions #274
Conversation
anikachurilova
commented
Nov 9, 2023
- closes https://github.com/zenodo/rdm-project/issues/515
fbba67f
to
9542bb8
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we add a test for versions_count
?
def versions_count(self): | ||
"""Get number of record's active versions""" | ||
records = list( | ||
self.get_record_versions(parent_id=self.parent.id, include_deleted=False) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could we reuse get_records_by_parent
with with_deleted=False, ids_only=True
?
This would fix the tests which are failing due to the import from invenio_rdm_records
which we cannot do in invenio-drafts-resources
.
Not sure what is the difference between is_deleted
and deletion_status
in the model.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
After checking, I can confirm that we need to use the deletion_status
and not is_deleted=False
as is_deleted
is checking for empty json (see here)
You are right tho, that we can not import invenio_rdm_records
... I could hardcode the value "P"
of the RecordDeletionStatusEnum.PUBLISHED
..
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
After checking, we should explore a different implementation.
I would add the property count
inside the versions
system field, and calculate the number of versions there.
The query should exclude both records mark as deleted (RecordDeletionStatusEnum.PUBLISHED.value
) and the soft deleted (is_deleted=True
).
However, there are a couple of issues:
RecordDeletionStatusEnum.PUBLISHED.value
is in rdm-records and cannot be imported here. Does it make sent to move some of that code here? Or inrecords-resources
?- the query should be performant, maybe cached, to avoid multiple calculations and performance hits. However, it is not straightforward to understand when invalidating the cache.