Skip to content
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

Fix default cache dataloader raise key error on non-existing key #3569

Open
wants to merge 11 commits into
base: main
Choose a base branch
from
16 changes: 16 additions & 0 deletions RELEASE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
Release type: patch

Calling `.clear(key)` on default dataloader with non-existing `key` will not throw `KeyError` anymore. Example:
```python
from strawberry.dataloader import DataLoader


async def load_data(keys):
return [str(key) for key in keys]


dataloader = DataLoader(load_fn=load_data)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

suggestion (documentation): Mention import statement for DataLoader

Consider adding a comment or a line to indicate that DataLoader should be imported from the relevant module to avoid confusion.

Suggested change
dataloader = DataLoader(load_fn=load_data)
```suggestion
```python
from some_module import DataLoader
dataloader = DataLoader(load_fn=load_data)

dataloader.clear(42) # does not throw KeyError anymore
```

This is a patch release with no breaking changes.
4 changes: 3 additions & 1 deletion strawberry/dataloader.py
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,9 @@ def set(self, key: K, value: Future[T]) -> None:
self.cache_map[self.cache_key_fn(key)] = value

def delete(self, key: K) -> None:
del self.cache_map[self.cache_key_fn(key)]
cache_key = self.cache_key_fn(key)
if cache_key in self.cache_map:
del self.cache_map[cache_key]

def clear(self) -> None:
self.cache_map.clear()
Expand Down
8 changes: 8 additions & 0 deletions tests/test_dataloaders.py
Original file line number Diff line number Diff line change
Expand Up @@ -288,6 +288,10 @@ async def idx(keys: List[int]) -> List[Tuple[int, int]]:

assert await loader.load_many([1, 2, 3]) == [(1, 4), (2, 4), (3, 4)]

loader.clear(-1)

assert await loader.load_many([1, 2, 3]) == [(1, 4), (2, 4), (3, 4)]


@pytest.mark.asyncio
async def test_clear_nocache():
Expand Down Expand Up @@ -315,6 +319,10 @@ async def idx(keys: List[int]) -> List[Tuple[int, int]]:

assert await loader.load_many([1, 2, 3]) == [(1, 4), (2, 4), (3, 4)]

loader.clear(-1)

assert await loader.load_many([1, 2, 3]) == [(1, 5), (2, 5), (3, 5)]


@pytest.mark.asyncio
async def test_dont_dispatch_cancelled():
Expand Down
Loading