Skip to content

Commit

Permalink
Provide more context in exception messages
Browse files Browse the repository at this point in the history
  • Loading branch information
Tyrrrz committed Nov 16, 2023
1 parent a46bf9b commit e89701e
Show file tree
Hide file tree
Showing 5 changed files with 33 additions and 19 deletions.
4 changes: 2 additions & 2 deletions DiscordChatExporter.Cli.Tests/Infra/ExportWrapper.cs
Original file line number Diff line number Diff line change
Expand Up @@ -105,7 +105,7 @@ Snowflake messageId
if (message is null)
{
throw new InvalidOperationException(
$"Message '{messageId}' does not exist in the export of channel '{channelId}'."
$"Message #{messageId} does not exist in the export of channel #{channelId}."
);
}

Expand All @@ -129,7 +129,7 @@ Snowflake messageId
if (message.ValueKind == JsonValueKind.Undefined)
{
throw new InvalidOperationException(
$"Message '{messageId}' does not exist in the export of channel '{channelId}'."
$"Message #{messageId} does not exist in the export of channel #{channelId}."
);
}

Expand Down
4 changes: 3 additions & 1 deletion DiscordChatExporter.Cli/Commands/Base/ExportCommandBase.cs
Original file line number Diff line number Diff line change
Expand Up @@ -168,7 +168,9 @@ protected async ValueTask ExportAsync(IConsole console, IReadOnlyList<Channel> c
{
throw new CommandException(
"Attempted to export multiple channels, but the output path is neither a directory nor a template. "
+ "If the provided output path is meant to be treated as a directory, make sure it ends with a slash."
+ "If the provided output path is meant to be treated as a directory, make sure it ends with a slash. "
+ "Provided output path: "
+ OutputPath
);
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,8 +6,8 @@ public class DiscordChatExporterException : Exception
{
public bool IsFatal { get; }

public DiscordChatExporterException(string message, bool isFatal = false)
: base(message)
public DiscordChatExporterException(string message, bool isFatal = false, Exception? innerException = null)
: base(message, innerException)
{
IsFatal = isFatal;
}
Expand Down
36 changes: 25 additions & 11 deletions DiscordChatExporter.Core/Exporting/ChannelExporter.cs
Original file line number Diff line number Diff line change
Expand Up @@ -22,22 +22,24 @@ public async ValueTask ExportChannelAsync(
if (request.Channel.Kind == ChannelKind.GuildForum)
{
throw new DiscordChatExporterException(
"Channel is a forum and cannot be exported directly. "
$"Channel '{request.Channel.Name}' (#{request.Channel.Id}) is a forum and cannot be exported directly. "
+ "You need to pull its threads and export them individually."
);
}

// Check if the channel is empty
if (request.Channel.IsEmpty)
{
throw new DiscordChatExporterException("Channel does not contain any messages.");
throw new DiscordChatExporterException(
$"Channel '{request.Channel.Name}' (#{request.Channel.Id}) does not contain any messages."
);
}

// Check if the 'after' boundary is valid
if (request.After is not null && !request.Channel.MayHaveMessagesAfter(request.After.Value))
{
throw new DiscordChatExporterException(
"Channel does not contain any messages within the specified period."
$"Channel '{request.Channel.Name}' (#{request.Channel.Id}) does not contain any messages within the specified period."
);
}

Expand All @@ -48,7 +50,7 @@ request.Before is not null
)
{
throw new DiscordChatExporterException(
"Channel does not contain any messages within the specified period."
$"Channel '{request.Channel.Name}' (#{request.Channel.Id}) does not contain any messages within the specified period."
);
}

Expand All @@ -68,20 +70,32 @@ var message in _discord.GetMessagesAsync(
)
)
{
// Resolve members for referenced users
foreach (var user in message.GetReferencedUsers())
await context.PopulateMemberAsync(user, cancellationToken);
try
{
// Resolve members for referenced users
foreach (var user in message.GetReferencedUsers())
await context.PopulateMemberAsync(user, cancellationToken);

// Export the message
if (request.MessageFilter.IsMatch(message))
await messageExporter.ExportMessageAsync(message, cancellationToken);
// Export the message
if (request.MessageFilter.IsMatch(message))
await messageExporter.ExportMessageAsync(message, cancellationToken);
}
catch (Exception ex)
{
// Provide more context to the exception, to simplify debugging based on error messages
throw new DiscordChatExporterException(
$"Failed to export message #{message.Id} in channel '{request.Channel.Name}' (#{request.Channel.Id}).",
ex is not DiscordChatExporterException dex || dex.IsFatal,
ex
);
}
}

// Throw if no messages were exported
if (messageExporter.MessagesExported <= 0)
{
throw new DiscordChatExporterException(
"Channel does not contain any matching messages within the specified period."
$"Channel '{request.Channel.Name}' (#{request.Channel.Id}) does not contain any matching messages within the specified period."
);
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -277,9 +277,7 @@ await Parallel.ForEachAsync(
}
catch (DiscordChatExporterException ex) when (!ex.IsFatal)
{
_eventAggregator.Publish(
new NotificationMessage(ex.Message.TrimEnd('.') + $" ({channel.Name})")
);
_eventAggregator.Publish(new NotificationMessage(ex.Message.TrimEnd('.')));
}
finally
{
Expand Down

0 comments on commit e89701e

Please sign in to comment.