Open
Description
I wonder what is the best way to test race conditions with parallel web requests, where each request runs in its own transaction typically, but if both would insert the same data it would trigger an IntegrityError.
I've came up with using live_server
and asyncio/aiohttp for it:
def test_user_ephemeralkey_race(active_requests_mock, drf_renter, renter, org,
live_server, event_loop, mock_stripe_customer):
import asyncio
import aiohttp
import rest_framework_jwt
# …
url = '%s%s' % (live_server.url, reverse('app:name'))
event_loop.set_debug(True)
async def get_url():
async with aiohttp.ClientSession(headers={
'Accept': 'application/json; version=1.0',
}) as client:
async with client.get(url) as resp:
text = await resp.text()
assert resp.status == 200, text
assert json.loads(text) == expected_response
coros = asyncio.gather(
get_url(),
get_url(),
loop=event_loop,
)
event_loop.run_until_complete(coros)
It works for me, but I wonder if there's a lighter solution that would not
involve using transactional_db
(via live_server
) in particular.
If this makes sense we might want to add it to the documentation probably?