64e3fbe035
v2-ci / build (push) Failing after 1m43s
v2-ci / unit-tests (tests/Core/ZB.MOM.WW.OtOpcUa.Cluster.Tests) (push) Has been skipped
v2-ci / unit-tests (tests/Server/ZB.MOM.WW.OtOpcUa.ControlPlane.Tests) (push) Has been skipped
v2-ci / unit-tests (tests/Server/ZB.MOM.WW.OtOpcUa.OpcUaServer.Tests) (push) Has been skipped
v2-ci / unit-tests (tests/Server/ZB.MOM.WW.OtOpcUa.Runtime.Tests) (push) Has been skipped
v2-ci / unit-tests (tests/Server/ZB.MOM.WW.OtOpcUa.Security.Tests) (push) Has been skipped
v2-ci / integration (tests/Server/ZB.MOM.WW.OtOpcUa.Host.IntegrationTests) (push) Has been skipped
v2-ci / integration (tests/Server/ZB.MOM.WW.OtOpcUa.OpcUaServer.IntegrationTests) (push) Has been skipped
Adds <summary>, <param>, <typeparam>, and <inheritdoc/> tags to public members surfaced by commentchecker — resolves 5,847 of 5,869 issues (99.6%) across three /fixdocs passes.
40 lines
1.8 KiB
C#
40 lines
1.8 KiB
C#
using Shouldly;
|
|
using Xunit;
|
|
|
|
namespace ZB.MOM.WW.OtOpcUa.Driver.OpcUaClient.Tests;
|
|
|
|
/// <summary>
|
|
/// Scaffold tests for <see cref="SessionReconnectHandler"/> wiring. Wire-level
|
|
/// disconnect-reconnect-resume coverage against a live upstream server lands with the
|
|
/// in-process fixture — too much machinery for a unit-test-only lane.
|
|
/// </summary>
|
|
[Trait("Category", "Unit")]
|
|
public sealed class OpcUaClientReconnectTests
|
|
{
|
|
/// <summary>Verifies that the default reconnect period matches the driver specification of 5 seconds.</summary>
|
|
[Fact]
|
|
public void Default_ReconnectPeriod_matches_driver_specs_5_seconds()
|
|
{
|
|
new OpcUaClientDriverOptions().ReconnectPeriod.ShouldBe(TimeSpan.FromSeconds(5));
|
|
}
|
|
|
|
/// <summary>Verifies that reconnect period can be configured for aggressive or relaxed retries.</summary>
|
|
[Fact]
|
|
public void Options_ReconnectPeriod_is_configurable_for_aggressive_or_relaxed_retry()
|
|
{
|
|
var opts = new OpcUaClientDriverOptions { ReconnectPeriod = TimeSpan.FromMilliseconds(500) };
|
|
opts.ReconnectPeriod.ShouldBe(TimeSpan.FromMilliseconds(500));
|
|
}
|
|
|
|
/// <summary>Verifies that the driver starts with no reconnect handler active before initialization.</summary>
|
|
[Fact]
|
|
public void Driver_starts_with_no_reconnect_handler_active_pre_init()
|
|
{
|
|
// The reconnect handler is lazy — spun up only when a bad keep-alive fires. Pre-init
|
|
// there's no session to reconnect, so the field must be null (indirectly verified by
|
|
// the lifecycle-shape test suite catching any accidental construction).
|
|
using var drv = new OpcUaClientDriver(new OpcUaClientDriverOptions(), "opcua-reconnect");
|
|
drv.GetHealth().State.ShouldBe(Core.Abstractions.DriverState.Unknown);
|
|
}
|
|
}
|