Enhance export test

This commit is contained in:
2025-10-02 18:30:36 +09:00
parent c180209322
commit 6c759ebe20
2 changed files with 63 additions and 5 deletions

View File

@ -6,6 +6,8 @@
@using Hcs.Service.Async.Nsi
@using Hcs.WebApp.Components.Shared
@inject NavigationManager NavigationManager
<PageTitle>Тестирование экспорта</PageTitle>
<RadzenSplitter Orientation="Orientation.Vertical" Style="height: 100%; border: 1px solid rgba(0,0,0,.08);">
@ -16,7 +18,7 @@
<RadzenStack JustifyContent="JustifyContent.SpaceBetween" Gap="1rem">
<RadzenStack Orientation="Orientation.Vertical" AlignItems="AlignItems.Start" JustifyContent="JustifyContent.Normal">
<RadzenText TextStyle="TextStyle.H6">Сервис nsi</RadzenText>
<RadzenButton Click=@(() => OnNsiExportItem1Click()) Text="Экспорт НСИ 1" ButtonStyle="ButtonStyle.Primary" />
<RadzenButton Click=@(() => OnNsiExportItem1Click()) Disabled=@interactable Text="Экспорт НСИ 1" ButtonStyle="ButtonStyle.Primary" />
</RadzenStack>
</RadzenStack>
</RadzenCard>
@ -27,8 +29,10 @@
<RadzenTabs RenderMode="TabRenderMode.Client" Style="height: 100%;">
<Tabs>
<RadzenTabsItem Text="Запрос">
<RadzenTextArea @bind-Value=@messageBody Disabled="true" />
</RadzenTabsItem>
<RadzenTabsItem Text="Результат">
<RadzenTextArea @bind-Value=@responseBody Disabled="true" />
</RadzenTabsItem>
</Tabs>
</RadzenTabs>
@ -40,13 +44,22 @@
@code {
EventConsole console = default!;
ActionLogger logger = new ActionLogger();
bool interactable = true;
string messageBody;
string responseBody;
Client client;
ActionLogger logger = new ActionLogger();
FileMessageCapturer messageCapturer;
bool catchMessageBody;
public Export()
{
logger.OnWriteLine += OnLog;
messageCapturer = new FileMessageCapturer("test/export", logger);
messageCapturer.OnFileWritten += OnFileWritten;
client = new Client
{
OrgPPAGUID = "ccd7fa02-a2bf-428a-984b-faef69ae0eb2",
@ -55,7 +68,7 @@
IsPPAK = false,
Role = OrganizationRole.RSO,
Logger = logger,
MessageCapturer = new FileMessageCapturer("test/export", logger)
MessageCapturer = messageCapturer
};
client.SetSigningCertificate("0636D2330032B3C38A4A26D765C787C248");
@ -66,8 +79,45 @@
console.Log(log);
}
void OnNsiExportItem1Click()
void OnFileWritten(string fileName)
{
client.Nsi.ExportDataProviderNsiItemAsync(exportDataProviderNsiItemRequestRegistryNumber.Item1);
if (catchMessageBody)
{
catchMessageBody = false;
messageBody = File.ReadAllText(fileName);
}
}
async Task OnNsiExportItem1Click()
{
try
{
StartExport();
await client.Nsi.ExportDataProviderNsiItemAsync(exportDataProviderNsiItemRequestRegistryNumber.Item1);
EndExport();
}
catch
{
NavigationManager.NavigateTo("/error");
}
}
void StartExport()
{
interactable = false;
messageBody = string.Empty;
responseBody = string.Empty;
catchMessageBody = true;
console.Clear();
}
void EndExport()
{
interactable = true;
responseBody = File.ReadAllText(messageCapturer.LastFileName);
}
}