Clémentine commited on
Commit
a39e583
·
1 Parent(s): b974197

prevent too many concurrent calls

Browse files
Files changed (1) hide show
  1. app.py +20 -13
app.py CHANGED
@@ -48,6 +48,7 @@ logging.basicConfig(level=logging.INFO, format="%(asctime)s - %(levelname)s - %(
48
  # Convert the environment variable "LEADERBOARD_FULL_INIT" to a boolean value, defaulting to True if the variable is not set.
49
  # This controls whether a full initialization should be performed.
50
  DO_FULL_INIT = os.getenv("LEADERBOARD_FULL_INIT", "True") == "True"
 
51
 
52
  def restart_space():
53
  API.restart_space(repo_id=REPO_ID, token=HF_TOKEN)
@@ -89,7 +90,11 @@ def download_dataset(repo_id, local_dir, repo_type="dataset", max_attempts=3, ba
89
  attempt += 1
90
  raise Exception(f"Failed to download {repo_id} after {max_attempts} attempts")
91
 
92
- def get_latest_data_leaderboard():
 
 
 
 
93
  leaderboard_dataset = datasets.load_dataset(
94
  AGGREGATED_REPO,
95
  "default",
@@ -306,6 +311,8 @@ with demo:
306
  )
307
 
308
  demo.load(fn=get_latest_data_leaderboard, inputs=None, outputs=[leaderboard])
 
 
309
 
310
  demo.queue(default_concurrency_limit=40)
311
 
@@ -355,17 +362,17 @@ async def update_leaderboard(payload: WebhookPayload) -> None:
355
  verification_mode="no_checks"
356
  )
357
 
358
- if False:
359
- LAST_UPDATE_QUEUE = datetime.datetime.now()
360
- @webhooks_server.add_webhook
361
- async def update_queue(payload: WebhookPayload) -> None:
362
- """Redownloads the queue dataset each time it updates"""
363
- if payload.repo.type == "dataset" and payload.event.action == "update":
364
- current_time = datetime.datetime.now()
365
- if current_time - LAST_UPDATE_QUEUE > datetime.timedelta(minutes=10):
366
- # We only redownload is last update was more than 10 minutes ago, as the queue is
367
- # updated regularly and heavy to download
368
- download_dataset(QUEUE_REPO, EVAL_REQUESTS_PATH)
369
- LAST_UPDATE_QUEUE = datetime.datetime.now()
370
 
371
  webhooks_server.launch()
 
48
  # Convert the environment variable "LEADERBOARD_FULL_INIT" to a boolean value, defaulting to True if the variable is not set.
49
  # This controls whether a full initialization should be performed.
50
  DO_FULL_INIT = os.getenv("LEADERBOARD_FULL_INIT", "True") == "True"
51
+ LAST_UPDATE_LEADERBOARD = datetime.datetime.now()
52
 
53
  def restart_space():
54
  API.restart_space(repo_id=REPO_ID, token=HF_TOKEN)
 
90
  attempt += 1
91
  raise Exception(f"Failed to download {repo_id} after {max_attempts} attempts")
92
 
93
+ def get_latest_data_leaderboard(init: bool = False):
94
+ current_time = datetime.datetime.now()
95
+ if current_time - LAST_UPDATE_LEADERBOARD < datetime.timedelta(minutes=10):
96
+ return
97
+ LAST_UPDATE_LEADERBOARD = current_time
98
  leaderboard_dataset = datasets.load_dataset(
99
  AGGREGATED_REPO,
100
  "default",
 
311
  )
312
 
313
  demo.load(fn=get_latest_data_leaderboard, inputs=None, outputs=[leaderboard])
314
+ #demo.load(fn=get_latest_data_queue, inputs=None, outputs=[finished_eval_table, running_eval_table, pending_eval_table])
315
+
316
 
317
  demo.queue(default_concurrency_limit=40)
318
 
 
362
  verification_mode="no_checks"
363
  )
364
 
365
+ LAST_UPDATE_QUEUE = datetime.datetime.now()
366
+ @webhooks_server.add_webhook
367
+ async def update_queue(payload: WebhookPayload) -> None:
368
+ """Redownloads the queue dataset each time it updates"""
369
+ if payload.repo.type == "dataset" and payload.event.action == "update":
370
+ current_time = datetime.datetime.now()
371
+ if current_time - LAST_UPDATE_QUEUE > datetime.timedelta(minutes=10):
372
+ print("would have updated")
373
+ # We only redownload is last update was more than 10 minutes ago, as the queue is
374
+ # updated regularly and heavy to download
375
+ #download_dataset(QUEUE_REPO, EVAL_REQUESTS_PATH)
376
+ LAST_UPDATE_QUEUE = datetime.datetime.now()
377
 
378
  webhooks_server.launch()