|  | @@ -4,7 +4,7 @@ import os
 | 
	
		
			
				|  |  |  import jinja2
 | 
	
		
			
				|  |  |  from fastapi import FastAPI
 | 
	
		
			
				|  |  |  from starlette.responses import HTMLResponse, JSONResponse, PlainTextResponse
 | 
	
		
			
				|  |  | -from random import randint
 | 
	
		
			
				|  |  | +from random import randint, sample
 | 
	
		
			
				|  |  |  from operator import itemgetter
 | 
	
		
			
				|  |  |  from urllib.parse import parse_qs
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -14,31 +14,6 @@ WRITE_ROW_SQL = 'UPDATE "world" SET "randomnumber"=$1 WHERE id=$2'
 | 
	
		
			
				|  |  |  ADDITIONAL_ROW = [0, 'Additional fortune added at request time.']
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -# https://www.starlette.io/responses/#custom-json-serialization
 | 
	
		
			
				|  |  | -try:
 | 
	
		
			
				|  |  | -    import orjson
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    class CustomJSONResponse(JSONResponse):
 | 
	
		
			
				|  |  | -        def render(self, content):
 | 
	
		
			
				|  |  | -            return orjson.dumps(content)
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -except ImportError:
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    class CustomJSONResponse(JSONResponse):
 | 
	
		
			
				|  |  | -        pass
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -async def setup_database():
 | 
	
		
			
				|  |  | -    global connection_pool
 | 
	
		
			
				|  |  | -    connection_pool = await asyncpg.create_pool(
 | 
	
		
			
				|  |  | -        user=os.getenv('PGUSER', 'benchmarkdbuser'),
 | 
	
		
			
				|  |  | -        password=os.getenv('PGPASS', 'benchmarkdbpass'),
 | 
	
		
			
				|  |  | -        database='hello_world',
 | 
	
		
			
				|  |  | -        host='tfb-database',
 | 
	
		
			
				|  |  | -        port=5432
 | 
	
		
			
				|  |  | -    )
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |  def load_fortunes_template():
 | 
	
		
			
				|  |  |      path = os.path.join('templates', 'fortune.html')
 | 
	
		
			
				|  |  |      with open(path, 'r') as template_file:
 | 
	
	
		
			
				|  | @@ -62,16 +37,25 @@ def get_num_queries(queries):
 | 
	
		
			
				|  |  |  connection_pool = None
 | 
	
		
			
				|  |  |  sort_fortunes_key = itemgetter(1)
 | 
	
		
			
				|  |  |  template = load_fortunes_template()
 | 
	
		
			
				|  |  | -loop = asyncio.get_event_loop()
 | 
	
		
			
				|  |  | -loop.run_until_complete(setup_database())
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  app = FastAPI()
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | [email protected]_event("startup")
 | 
	
		
			
				|  |  | +async def setup_database():
 | 
	
		
			
				|  |  | +    global connection_pool
 | 
	
		
			
				|  |  | +    connection_pool = await asyncpg.create_pool(
 | 
	
		
			
				|  |  | +        user=os.getenv('PGUSER', 'benchmarkdbuser'),
 | 
	
		
			
				|  |  | +        password=os.getenv('PGPASS', 'benchmarkdbpass'),
 | 
	
		
			
				|  |  | +        database='hello_world',
 | 
	
		
			
				|  |  | +        host='tfb-database',
 | 
	
		
			
				|  |  | +        port=5432
 | 
	
		
			
				|  |  | +    )
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  | +
 | 
	
		
			
				|  |  |  @app.get('/json')
 | 
	
		
			
				|  |  |  async def json_serialization():
 | 
	
		
			
				|  |  | -    return CustomJSONResponse({'message': 'Hello, world!'})
 | 
	
		
			
				|  |  | +    return JSONResponse({'message': 'Hello, world!'})
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  @app.get('/db')
 | 
	
	
		
			
				|  | @@ -81,14 +65,13 @@ async def single_database_query():
 | 
	
		
			
				|  |  |      async with connection_pool.acquire() as connection:
 | 
	
		
			
				|  |  |          number = await connection.fetchval(READ_ROW_SQL, row_id)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    return CustomJSONResponse({'id': row_id, 'randomNumber': number})
 | 
	
		
			
				|  |  | +    return JSONResponse({'id': row_id, 'randomNumber': number})
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  @app.get('/queries')
 | 
	
		
			
				|  |  |  async def multiple_database_queries(queries = None):
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  |      num_queries = get_num_queries(queries)
 | 
	
		
			
				|  |  | -    row_ids = [randint(1, 10000) for _ in range(num_queries)]
 | 
	
		
			
				|  |  | +    row_ids = sample(range(1, 10000), num_queries)
 | 
	
		
			
				|  |  |      worlds = []
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      async with connection_pool.acquire() as connection:
 | 
	
	
		
			
				|  | @@ -97,7 +80,7 @@ async def multiple_database_queries(queries = None):
 | 
	
		
			
				|  |  |              number = await statement.fetchval(row_id)
 | 
	
		
			
				|  |  |              worlds.append({'id': row_id, 'randomNumber': number})
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    return CustomJSONResponse(worlds)
 | 
	
		
			
				|  |  | +    return JSONResponse(worlds)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  @app.get('/fortunes')
 | 
	
	
		
			
				|  | @@ -114,7 +97,7 @@ async def fortunes():
 | 
	
		
			
				|  |  |  @app.get('/updates')
 | 
	
		
			
				|  |  |  async def database_updates(queries = None):
 | 
	
		
			
				|  |  |      num_queries = get_num_queries(queries)
 | 
	
		
			
				|  |  | -    updates = [(randint(1, 10000), randint(1, 10000)) for _ in range(num_queries)]
 | 
	
		
			
				|  |  | +    updates = [(row_id, randint(1, 10000)) for row_id in sample(range(1, 10000), num_queries)]
 | 
	
		
			
				|  |  |      worlds = [{'id': row_id, 'randomNumber': number} for row_id, number in updates]
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |      async with connection_pool.acquire() as connection:
 | 
	
	
		
			
				|  | @@ -123,7 +106,7 @@ async def database_updates(queries = None):
 | 
	
		
			
				|  |  |              await statement.fetchval(row_id)
 | 
	
		
			
				|  |  |          await connection.executemany(WRITE_ROW_SQL, updates)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    return CustomJSONResponse(worlds)
 | 
	
		
			
				|  |  | +    return JSONResponse(worlds)
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  @app.get('/plaintext')
 |