diff options
| author | 2020-02-16 17:38:41 -0800 | |
|---|---|---|
| committer | 2020-02-16 17:54:25 -0800 | |
| commit | 476d5e7851f5b53ece319f023eeca88ae5c345eb (patch) | |
| tree | 54c61a64857cae06b7e2793540764fc527eb6ad0 | |
| parent | Error handler: handle ArgumentParsingError (diff) | |
Error handler: (almost) always log the error being handled
The log level is debug for most errors and it's mainly useful for
precisely that - debugging. This is why some "useless" errors are also
logged e.g. CommandNotFound. Unexpected errors and some API errors will
still have higher levels.
* Add a single log statement to the end of the handler to cover
  UserInputError, CheckFailure, and CommandNotFound (when it's not
  trying to get a tag)
* Log 404s from API
| -rw-r--r-- | bot/cogs/error_handler.py | 27 | 
1 files changed, 11 insertions, 16 deletions
| diff --git a/bot/cogs/error_handler.py b/bot/cogs/error_handler.py index 07b93283d..ff8b36ddc 100644 --- a/bot/cogs/error_handler.py +++ b/bot/cogs/error_handler.py @@ -50,23 +50,26 @@ class ErrorHandler(Cog):          if isinstance(e, errors.CommandNotFound) and not hasattr(ctx, "invoked_from_error_handler"):              if ctx.channel.id != Channels.verification:                  await self.try_get_tag(ctx) +                return  # Exit early to avoid logging.          elif isinstance(e, errors.UserInputError):              await self.handle_user_input_error(ctx, e)          elif isinstance(e, errors.CheckFailure):              await self.handle_check_failure(ctx, e) -        elif isinstance(e, (errors.CommandOnCooldown, errors.DisabledCommand)): -            log.debug( -                f"Command {command} invoked by {ctx.message.author} with error " -                f"{e.__class__.__name__}: {e}" -            )          elif isinstance(e, errors.CommandInvokeError):              if isinstance(e.original, ResponseCodeError):                  await self.handle_api_error(ctx, e.original)              else:                  await self.handle_unexpected_error(ctx, e.original) -        else: -            # MaxConcurrencyReached, ExtensionError +            return  # Exit early to avoid logging. +        elif not isinstance(e, (errors.CommandOnCooldown, errors.DisabledCommand)): +            # ConversionError, MaxConcurrencyReached, ExtensionError              await self.handle_unexpected_error(ctx, e) +            return  # Exit early to avoid logging. + +        log.debug( +            f"Command {command} invoked by {ctx.message.author} with error " +            f"{e.__class__.__name__}: {e}" +        )      async def get_help_command(self, command: t.Optional[Command]) -> t.Tuple:          """Return the help command invocation args to display help for `command`.""" @@ -129,10 +132,6 @@ class ErrorHandler(Cog):          else:              await ctx.send("Something about your input seems off. Check the arguments:")              await ctx.invoke(*help_command) -            log.debug( -                f"Command {ctx.command} invoked by {ctx.message.author} with error " -                f"{e.__class__.__name__}: {e}" -            )      @staticmethod      async def handle_check_failure(ctx: Context, e: errors.CheckFailure) -> None: @@ -153,17 +152,13 @@ class ErrorHandler(Cog):              )          elif isinstance(e, InChannelCheckFailure):              await ctx.send(e) -        else: -            log.debug( -                f"Command {command} invoked by {ctx.message.author} with error " -                f"{e.__class__.__name__}: {e}" -            )      @staticmethod      async def handle_api_error(ctx: Context, e: ResponseCodeError) -> None:          """Handle ResponseCodeError exceptions."""          if e.status == 404:              await ctx.send("There does not seem to be anything matching your query.") +            log.debug(f"API responded with 404 for command {ctx.command}")          elif e.status == 400:              content = await e.response.json()              log.debug(f"API responded with 400 for command {ctx.command}: %r.", content) | 
