Add capture index manifest for group testing

This commit is contained in:
Jacob Dubin
2026-05-17 14:07:56 -05:00
parent c0485da46d
commit 14b5cb74cc
10 changed files with 198 additions and 17 deletions

View File

@@ -66,6 +66,14 @@ public sealed class FileWebSocketTelemetrySinkTests : IDisposable
Assert.Equal(1, document.RootElement.GetProperty("steps").GetArrayLength());
Assert.Equal("LISTEN",
document.RootElement.GetProperty("steps")[0].GetProperty("expectedReplyTypes")[0].GetString());
var indexPath = Path.Combine(_directoryPath, "capture-index.ndjson");
var indexEntries = await ReadNdjsonAsync(indexPath);
Assert.Contains(indexEntries, entry => entry.GetProperty("eventType").GetString() == "connection_opened");
Assert.Contains(indexEntries, entry => entry.GetProperty("eventType").GetString() == "message_in");
Assert.Contains(indexEntries, entry => entry.GetProperty("eventType").GetString() == "message_out");
Assert.Contains(indexEntries, entry => entry.GetProperty("eventType").GetString() == "connection_closed");
Assert.Contains(indexEntries, entry => entry.GetProperty("eventType").GetString() == "fixture_export");
}
[Fact]
@@ -124,4 +132,18 @@ public sealed class FileWebSocketTelemetrySinkTests : IDisposable
DirectoryPath = _directoryPath
}));
}
}
private static async Task<List<JsonElement>> ReadNdjsonAsync(string filePath)
{
var entries = new List<JsonElement>();
foreach (var line in await File.ReadAllLinesAsync(filePath))
{
if (string.IsNullOrWhiteSpace(line)) continue;
using var document = JsonDocument.Parse(line);
entries.Add(document.RootElement.Clone());
}
return entries;
}
}