Skip to content

Commit

Permalink
allow strings instead of sequences as input for sort_keys in search. …
Browse files Browse the repository at this point in the history
…Updates #448
  • Loading branch information
tobixen committed Nov 5, 2024
1 parent f13387f commit b5a5dde
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 0 deletions.
3 changes: 3 additions & 0 deletions caldav/objects.py
Original file line number Diff line number Diff line change
Expand Up @@ -1311,6 +1311,7 @@ def sort_key_func(x):
> datetime.now().strftime("%F%H%M%S")
),
}
## ref https://github.com/python-caldav/caldav/issues/448 - allow strings instead of a sequence here
for sort_key in sort_keys:
val = comp.get(sort_key, None)
if val is None:
Expand All @@ -1327,6 +1328,8 @@ def sort_key_func(x):
return ret

if sort_keys:
if isinstance(sort_keys, str):
sort_keys = (sort_keys,)
objects.sort(key=sort_key_func, reverse=sort_reverse)

## partial workaround for https://github.com/python-caldav/caldav/issues/201
Expand Down
34 changes: 34 additions & 0 deletions tests/test_caldav.py
Original file line number Diff line number Diff line change
Expand Up @@ -1500,6 +1500,40 @@ def testSearchEvent(self):
assert len(all_events) == 3
assert all_events[0].instance.vevent.summary.value == "Our Blissful Anniversary"

## A more robust check for the sort key
all_events = c.search(sort_keys=("DTSTART",))
assert len(all_events) == 3
assert str(all_events[0].icalendar_component["DTSTART"].dt) < str(
all_events[1].icalendar_component["DTSTART"].dt
)
assert str(all_events[1].icalendar_component["DTSTART"].dt) < str(
all_events[2].icalendar_component["DTSTART"].dt
)
all_events = c.search(sort_keys=("DTSTART",), sort_reverse=True)
assert str(all_events[0].icalendar_component["DTSTART"].dt) > str(
all_events[1].icalendar_component["DTSTART"].dt
)
assert str(all_events[1].icalendar_component["DTSTART"].dt) > str(
all_events[2].icalendar_component["DTSTART"].dt
)

## Ref https://github.com/python-caldav/caldav/issues/448
all_events = c.search(sort_keys=("DTSTART"))
assert len(all_events) == 3
assert str(all_events[0].icalendar_component["DTSTART"].dt) < str(
all_events[1].icalendar_component["DTSTART"].dt
)
assert str(all_events[1].icalendar_component["DTSTART"].dt) < str(
all_events[2].icalendar_component["DTSTART"].dt
)
all_events = c.search(sort_keys=("DTSTART"), sort_reverse=True)
assert str(all_events[0].icalendar_component["DTSTART"].dt) > str(
all_events[1].icalendar_component["DTSTART"].dt
)
assert str(all_events[1].icalendar_component["DTSTART"].dt) > str(
all_events[2].icalendar_component["DTSTART"].dt
)

def testSearchSortTodo(self):
self.skip_on_compatibility_flag("read_only")
self.skip_on_compatibility_flag("no_todo")
Expand Down

0 comments on commit b5a5dde

Please sign in to comment.