39132be4e8
PR Checks / test-and-build (pull_request) Successful in 6m6s
Move neutral join/leave handlers into GmRelay.Shared so Telegram and Discord share capacity, waitlist, duplicate-click, and schedule-update behavior. Add Discord component routing for join_session and leave_session buttons with deferred ephemeral replies and serialized schedule message updates. Bump version to 2.5.0 and update Discord docs. Refs #29
41 lines
2.1 KiB
C#
41 lines
2.1 KiB
C#
namespace GmRelay.Bot.Tests.Discord;
|
|
|
|
public sealed class DiscordSessionInteractionModuleSourceTests
|
|
{
|
|
[Fact]
|
|
public async Task Module_ShouldRouteJoinAndLeaveButtonsToNeutralHandlers()
|
|
{
|
|
var source = await ReadRepositoryFileAsync("src/GmRelay.DiscordBot/Features/Sessions/DiscordSessionInteractionModule.cs");
|
|
|
|
Assert.Contains("ComponentInteractionModule<ButtonInteractionContext>", source, StringComparison.Ordinal);
|
|
Assert.Contains("[ComponentInteraction(\"join_session\")]", source, StringComparison.Ordinal);
|
|
Assert.Contains("[ComponentInteraction(\"leave_session\")]", source, StringComparison.Ordinal);
|
|
Assert.Contains("JoinSessionHandler", source, StringComparison.Ordinal);
|
|
Assert.Contains("LeaveSessionHandler", source, StringComparison.Ordinal);
|
|
Assert.Contains("DiscordSessionInteractionMapper.CreateJoinCommand", source, StringComparison.Ordinal);
|
|
Assert.Contains("DiscordSessionInteractionMapper.CreateLeaveCommand", source, StringComparison.Ordinal);
|
|
Assert.Contains("RespondAsync", source, StringComparison.Ordinal);
|
|
Assert.Contains("InteractionCallback.DeferredMessage(MessageFlags.Ephemeral)", source, StringComparison.Ordinal);
|
|
Assert.Contains("ModifyResponseAsync", source, StringComparison.Ordinal);
|
|
Assert.Contains("Не удалось обработать кнопку.", source, StringComparison.Ordinal);
|
|
Assert.Contains("MessageFlags.Ephemeral", source, StringComparison.Ordinal);
|
|
}
|
|
|
|
private static async Task<string> ReadRepositoryFileAsync(string relativePath)
|
|
{
|
|
var directory = new DirectoryInfo(AppContext.BaseDirectory);
|
|
while (directory is not null)
|
|
{
|
|
var candidate = Path.Combine(directory.FullName, relativePath);
|
|
if (File.Exists(candidate))
|
|
{
|
|
return await File.ReadAllTextAsync(candidate);
|
|
}
|
|
|
|
directory = directory.Parent;
|
|
}
|
|
|
|
throw new FileNotFoundException($"Could not locate repository file '{relativePath}'.");
|
|
}
|
|
}
|