using NSubstitute; using ScadaLink.Commons.Entities.InboundApi; using ScadaLink.Commons.Interfaces.Repositories; namespace ScadaLink.InboundAPI.Tests; /// /// WP-1: Tests for API key validation — X-API-Key header, enabled/disabled keys, /// method approval. /// public class ApiKeyValidatorTests { private readonly IInboundApiRepository _repository = Substitute.For(); private readonly ApiKeyValidator _validator; public ApiKeyValidatorTests() { _validator = new ApiKeyValidator(_repository); } [Fact] public async Task MissingApiKey_Returns401() { var result = await _validator.ValidateAsync(null, "testMethod"); Assert.False(result.IsValid); Assert.Equal(401, result.StatusCode); } [Fact] public async Task EmptyApiKey_Returns401() { var result = await _validator.ValidateAsync("", "testMethod"); Assert.False(result.IsValid); Assert.Equal(401, result.StatusCode); } [Fact] public async Task InvalidApiKey_Returns401() { _repository.GetApiKeyByValueAsync("bad-key").Returns((ApiKey?)null); var result = await _validator.ValidateAsync("bad-key", "testMethod"); Assert.False(result.IsValid); Assert.Equal(401, result.StatusCode); } [Fact] public async Task DisabledApiKey_Returns401() { var key = new ApiKey("test", "valid-key") { Id = 1, IsEnabled = false }; _repository.GetApiKeyByValueAsync("valid-key").Returns(key); var result = await _validator.ValidateAsync("valid-key", "testMethod"); Assert.False(result.IsValid); Assert.Equal(401, result.StatusCode); } [Fact] public async Task ValidKey_MethodNotFound_Returns400() { var key = new ApiKey("test", "valid-key") { Id = 1, IsEnabled = true }; _repository.GetApiKeyByValueAsync("valid-key").Returns(key); _repository.GetMethodByNameAsync("nonExistent").Returns((ApiMethod?)null); var result = await _validator.ValidateAsync("valid-key", "nonExistent"); Assert.False(result.IsValid); Assert.Equal(400, result.StatusCode); } [Fact] public async Task ValidKey_NotApprovedForMethod_Returns403() { var key = new ApiKey("test", "valid-key") { Id = 1, IsEnabled = true }; var method = new ApiMethod("testMethod", "return 1;") { Id = 10 }; _repository.GetApiKeyByValueAsync("valid-key").Returns(key); _repository.GetMethodByNameAsync("testMethod").Returns(method); _repository.GetApprovedKeysForMethodAsync(10).Returns(new List()); var result = await _validator.ValidateAsync("valid-key", "testMethod"); Assert.False(result.IsValid); Assert.Equal(403, result.StatusCode); } [Fact] public async Task ValidKey_ApprovedForMethod_ReturnsValid() { var key = new ApiKey("test", "valid-key") { Id = 1, IsEnabled = true }; var method = new ApiMethod("testMethod", "return 1;") { Id = 10 }; _repository.GetApiKeyByValueAsync("valid-key").Returns(key); _repository.GetMethodByNameAsync("testMethod").Returns(method); _repository.GetApprovedKeysForMethodAsync(10).Returns(new List { key }); var result = await _validator.ValidateAsync("valid-key", "testMethod"); Assert.True(result.IsValid); Assert.Equal(200, result.StatusCode); Assert.Equal(key, result.ApiKey); Assert.Equal(method, result.Method); } }