Skip to content

Commit 984793a

Browse files
committed
Merge pull request pandas-dev#40 from manahl/bugfix/list-versions-returns-deleted
EASY-511 return deleted state in list_versions
2 parents 965c812 + 089af7d commit 984793a

File tree

3 files changed

+29
-6
lines changed

3 files changed

+29
-6
lines changed

arctic/store/version_store.py

+6-4
Original file line numberDiff line numberDiff line change
@@ -244,14 +244,16 @@ def list_versions(self, symbol=None, snapshot=None, latest_only=False):
244244
for symbol in symbols:
245245
query['symbol'] = symbol
246246
seen_symbols = set()
247-
for version in self._versions.find(query, projection=['symbol', 'version', 'parent'], sort=[('version', -1)]):
247+
for version in self._versions.find(query, projection=['symbol', 'version', 'parent', 'metadata.deleted'], sort=[('version', -1)]):
248248
if latest_only and version['symbol'] in seen_symbols:
249249
continue
250250
seen_symbols.add(version['symbol'])
251+
meta = version.get('metadata')
251252
versions.append({'symbol': version['symbol'], 'version': version['version'],
252-
# We return offset-aware datetimes in Local Time.
253-
'date': ms_to_datetime(datetime_to_ms(version['_id'].generation_time)),
254-
'snapshots': self._find_snapshots(version.get('parent', []))})
253+
'deleted': meta.get('deleted', False) if meta else False,
254+
# We return offset-aware datetimes in Local Time.
255+
'date': ms_to_datetime(datetime_to_ms(version['_id'].generation_time)),
256+
'snapshots': self._find_snapshots(version.get('parent', []))})
255257
return versions
256258

257259
def _find_snapshots(self, parent_ids):

tests/integration/store/test_version_store.py

+20
Original file line numberDiff line numberDiff line change
@@ -303,6 +303,26 @@ def test_list_version(library):
303303
assert versions[i]['version'] == x
304304

305305

306+
def test_list_version_deleted(library):
307+
assert len(library.list_versions(symbol)) == 0
308+
library.write(symbol, ts1, prune_previous_version=False)
309+
assert len(library.list_versions(symbol)) == 1
310+
# Snapshot the library so we keep the sentinel version
311+
library.snapshot('xxx', versions={symbol: 1})
312+
library.delete(symbol)
313+
versions = library.list_versions(symbol)
314+
assert len(versions) == 2
315+
assert versions[0]['symbol'] == symbol
316+
assert versions[0]['version'] == 2
317+
assert versions[0]['snapshots'] == []
318+
assert versions[0]['deleted'] == True
319+
320+
assert versions[1]['symbol'] == symbol
321+
assert versions[1]['version'] == 1
322+
assert versions[1]['deleted'] == False
323+
assert versions[1]['snapshots'] == ['xxx']
324+
325+
306326
def test_list_version_latest_only(library):
307327
assert len(list(library.list_versions(symbol))) == 0
308328
dates = [None, None, None]

tests/unit/store/test_version_store.py

+3-2
Original file line numberDiff line numberDiff line change
@@ -34,14 +34,15 @@ def test_list_versions_localTime():
3434
vs._find_snapshots.return_value = 'snap'
3535
date = dt(2013, 4, 1, 9, 0)
3636
vs._versions.find.return_value = [{'_id': bson.ObjectId.from_datetime(date),
37-
'symbol': 's', 'version': 10}]
37+
'symbol': 's', 'version': 10, 'metadata': None}]
3838

3939
version = list(VersionStore.list_versions(vs, "symbol"))[0]
4040
local_date = date.replace(tzinfo=mktz("UTC"))
4141
assert version == {'symbol': version['symbol'], 'version': version['version'],
4242
# We return naive datetimes in 'default' time, which is London for us
4343
'date': local_date,
44-
'snapshots': 'snap'}
44+
'snapshots': 'snap',
45+
'deleted': False}
4546

4647

4748
def test__read_preference__allow_secondary_true():

0 commit comments

Comments
 (0)