feat(transport): manifest summary counts + schemaVersion 1.1 (M8 B3)
This commit is contained in:
@@ -14,7 +14,8 @@ public sealed class ManifestBuilderTests
|
||||
public void Build_populates_summary_from_contents()
|
||||
{
|
||||
var sut = new ManifestBuilder();
|
||||
var summary = new BundleSummary(2, 1, 0, 0, 0, 0, 0, 0);
|
||||
// M8 (B3): summary now carries trailing Sites/DataConnections/Instances counts.
|
||||
var summary = new BundleSummary(2, 1, 0, 0, 0, 0, 0, 0, Sites: 3, DataConnections: 4, Instances: 5);
|
||||
var contents = new[]
|
||||
{
|
||||
new ManifestContentEntry("Template", "T1", 1, Array.Empty<string>()),
|
||||
@@ -25,12 +26,17 @@ public sealed class ManifestBuilderTests
|
||||
var manifest = sut.Build("env", "user", "1.0.0", encryption: null, summary, contents, contentBytes: new byte[] { 1, 2, 3 });
|
||||
|
||||
Assert.Equal(summary, manifest.Summary);
|
||||
// New M8 summary counts flow through the builder verbatim.
|
||||
Assert.Equal(3, manifest.Summary.Sites);
|
||||
Assert.Equal(4, manifest.Summary.DataConnections);
|
||||
Assert.Equal(5, manifest.Summary.Instances);
|
||||
Assert.Equal(contents, manifest.Contents);
|
||||
Assert.Equal("env", manifest.SourceEnvironment);
|
||||
Assert.Equal("user", manifest.ExportedBy);
|
||||
Assert.Equal("1.0.0", manifest.ScadaBridgeVersion);
|
||||
Assert.Equal(1, manifest.BundleFormatVersion);
|
||||
Assert.Equal("1.0", manifest.SchemaVersion);
|
||||
// M8 (B3): schema minor bumped 1.0 → 1.1; format version stays 1.
|
||||
Assert.Equal("1.1", manifest.SchemaVersion);
|
||||
Assert.Null(manifest.Encryption);
|
||||
}
|
||||
|
||||
@@ -100,4 +106,51 @@ public sealed class ManifestBuilderTests
|
||||
|
||||
Assert.Equal(ManifestValidationResult.Ok, result);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void Validate_accepts_older_schemaVersion_1_0_manifest()
|
||||
{
|
||||
// An older "1.0" bundle (pre-M8) must still import: schema minor differences
|
||||
// are additive and the validator gates only on BundleFormatVersion.
|
||||
var bytes = Encoding.UTF8.GetBytes("legacy-bundle");
|
||||
var hash = "sha256:" + Convert.ToHexString(SHA256.HashData(bytes)).ToLowerInvariant();
|
||||
var manifest = new BundleManifest(
|
||||
BundleFormatVersion: ManifestBuilder.CurrentBundleFormatVersion,
|
||||
SchemaVersion: "1.0",
|
||||
CreatedAtUtc: DateTimeOffset.UtcNow,
|
||||
SourceEnvironment: "env",
|
||||
ExportedBy: "u",
|
||||
ScadaBridgeVersion: "v",
|
||||
ContentHash: hash,
|
||||
Encryption: null,
|
||||
Summary: EmptySummary,
|
||||
Contents: NoContents);
|
||||
|
||||
var result = new ManifestValidator().Validate(manifest, bytes);
|
||||
|
||||
Assert.Equal(ManifestValidationResult.Ok, result);
|
||||
}
|
||||
|
||||
[Fact]
|
||||
public void Validate_refuses_bundleFormatVersion_2()
|
||||
{
|
||||
// A future format-version 2 is a hard refusal (not a minor schema bump).
|
||||
var bytes = Encoding.UTF8.GetBytes("future-bundle");
|
||||
var hash = "sha256:" + Convert.ToHexString(SHA256.HashData(bytes)).ToLowerInvariant();
|
||||
var manifest = new BundleManifest(
|
||||
BundleFormatVersion: 2,
|
||||
SchemaVersion: "1.1",
|
||||
CreatedAtUtc: DateTimeOffset.UtcNow,
|
||||
SourceEnvironment: "env",
|
||||
ExportedBy: "u",
|
||||
ScadaBridgeVersion: "v",
|
||||
ContentHash: hash,
|
||||
Encryption: null,
|
||||
Summary: EmptySummary,
|
||||
Contents: NoContents);
|
||||
|
||||
var result = new ManifestValidator().Validate(manifest, bytes);
|
||||
|
||||
Assert.Equal(ManifestValidationResult.UnsupportedFormatVersion, result);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user