mirror of https://github.com/ivanch/tcc.git
add script de teste
This commit is contained in:
parent
6f6a77f897
commit
258f3a0243
|
@ -0,0 +1,33 @@
|
||||||
|
import requests
|
||||||
|
import concurrent.futures
|
||||||
|
import time
|
||||||
|
|
||||||
|
URL_BASE = 'http://localhost:5100'
|
||||||
|
|
||||||
|
num_requests = [1000, 5000, 10_000, 50_000, 100_000, 500_000, 1_000_000]
|
||||||
|
|
||||||
|
def send_request(session, url):
|
||||||
|
response = session.get(url)
|
||||||
|
return response.status_code
|
||||||
|
|
||||||
|
def main():
|
||||||
|
for num_request in num_requests:
|
||||||
|
with concurrent.futures.ThreadPoolExecutor(max_workers=10) as executor:
|
||||||
|
url = f'{URL_BASE}/status/ok'
|
||||||
|
|
||||||
|
start_time = time.time()
|
||||||
|
|
||||||
|
futures = []
|
||||||
|
with requests.Session() as session:
|
||||||
|
futures = [executor.submit(send_request, session, url) for _ in range(num_request)]
|
||||||
|
|
||||||
|
concurrent.futures.wait(futures)
|
||||||
|
|
||||||
|
elapsed_time = time.time() - start_time
|
||||||
|
|
||||||
|
successful_responses = sum(1 for future in futures if future.result() == 200)
|
||||||
|
|
||||||
|
print(f"All requests completed in {elapsed_time:.2f} seconds. {elapsed_time/num_request:.4f} seconds per request. {num_request/elapsed_time:.2f} requests per second.")
|
||||||
|
print(f"Successful responses: {successful_responses}/{num_request}")
|
||||||
|
|
||||||
|
main()
|
Loading…
Reference in New Issue