Skip to content

Commit

Permalink
Add debug performance logs for in_guild sync
Browse files Browse the repository at this point in the history
  • Loading branch information
ChrisLovering committed Jun 30, 2024
1 parent 3f86123 commit e47b967
Showing 1 changed file with 17 additions and 2 deletions.
19 changes: 17 additions & 2 deletions metricity/exts/event_listeners/startup_sync.py
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
"""An ext to sync the guild when the bot starts up."""

import math
import time

import discord
from discord.ext import commands
Expand All @@ -25,7 +26,7 @@ def __init__(self, bot: Bot) -> None:
self.bot = bot
scheduling.create_task(self.sync_guild())

async def sync_guild(self) -> None:
async def sync_guild(self) -> None: # noqa: PLR0914
"""Sync all channels and members in the guild."""
await self.bot.wait_until_guild_available()

Expand Down Expand Up @@ -96,16 +97,30 @@ async def sync_guild(self) -> None:
users_updated = 0
guild_member_ids = {str(member.id) for member in guild.members}
async with async_session() as sess:
start = time.perf_counter()

stmt = select(models.User).filter_by(in_guild=True).options(load_only(models.User.id))
res = await sess.execute(stmt)
in_guild_users = res.scalars()
query = time.perf_counter()

for user in in_guild_users:
if user.id not in guild_member_ids:
users_updated += 1
user.in_guild = False
proc = time.perf_counter()

await sess.commit()
log.info("User in_guild sync updated %d users to be off guild", users_updated)
end = time.perf_counter()

log.debug(
"in_guild sync: total time %fs, query %fs, processing %fs, commit %fs",
end - start,
query - start,
proc - query,
end - proc,
)
log.info("User in_guild sync updated %d users to be off guild", users_updated)
log.info("User sync complete")

self.bot.sync_process_complete.set()
Expand Down

0 comments on commit e47b967

Please sign in to comment.