Page MenuHomeSoftware Heritage

storage: Open content_get_range storage endpoint
ClosedPublic

Authored by ardumont on Nov 12 2018, 11:41 AM.

Details

Summary

This allows to retrieve contents from within a range.
The endpoint is paginated.

Tests are using the hypothesis module and reuse the initial work on
D646.

Depends on D646

Test Plan

tox

Diff Detail

Repository
rDSTO Storage manager
Branch
add-content-get-range
Lint
No Linters Available
Unit
No Unit Test Coverage
Build Status
Buildable 2325
Build 2822: tox-on-jenkinsJenkins
Build 2821: arc lint + arc unit

Event Timeline

ardumont created this revision.

Use the right origin commit.

Fix:

  • spurious print statements
  • wrong docstring conventions

Again use the right original commit!

Build has FAILED

stacked diff, you cannot build it successfully.

vlorentz added a subscriber: vlorentz.
vlorentz added inline comments.
swh/storage/storage.py
262 ↗(On Diff #2017)

Why +1?

swh/storage/tests/test_storage.py
1912

Nitpick: get_sha1s = sorted(c['sha1'] for c in contents)

1928

I don't think this properly tests contents. What if contents[0] is an empty dict?

1961

Same comment as above

This revision now requires changes to proceed.Nov 14 2018, 2:29 PM
ardumont added inline comments.
swh/storage/storage.py
262 ↗(On Diff #2017)

To retrieve the next content_id when checking for the boundary limit.

swh/storage/tests/test_storage.py
1928

As explained in prior diff D646#inline-3344, cannot happen here.

ardumont added inline comments.
swh/storage/tests/test_storage.py
1912

right.

Adapt according to review

  • storage: Open content_get_range endpoint
  • tests: Use sorted

(and rebase interactively)

Add missing commits from the prior rebase instructions (T.T)

  • tests: Move property_based marker to toplevel test class
  • tests: Add docstring to test to detail what's tested
This revision is now accepted and ready to land.Nov 14 2018, 3:22 PM
This revision was automatically updated to reflect the committed changes.