diff --git a/Fauna.Test/Configuration.Tests.cs b/Fauna.Test/Configuration.Tests.cs index 21367698..53d5c8fa 100644 --- a/Fauna.Test/Configuration.Tests.cs +++ b/Fauna.Test/Configuration.Tests.cs @@ -17,6 +17,20 @@ public void ConstructorWorksFine() Assert.IsTrue(b.DisposeHttpClient); } + [Test] + public void ConstructorWithSecretVar() + { + string? currentVal = Environment.GetEnvironmentVariable("FAUNA_ENDPOINT"); + Environment.SetEnvironmentVariable("FAUNA_SECRET", null); + + Configuration config = new Configuration { Secret = "secret" }; + Assert.AreEqual("secret", config.Secret); + + Environment.SetEnvironmentVariable("FAUNA_SECRET", currentVal); + + Assert.DoesNotThrow(() => config.Validate()); + } + [Test] public void ConstructorWithEndpointEnvVar() { @@ -28,6 +42,8 @@ public void ConstructorWithEndpointEnvVar() Assert.AreEqual("http://localhost:8443/", config.Endpoint.ToString()); Environment.SetEnvironmentVariable("FAUNA_ENDPOINT", currentVal); + + Assert.DoesNotThrow(() => config.Validate()); } [Test] @@ -53,6 +69,7 @@ public void ConstructorUsesEnvVar() Assert.AreEqual("secret", b.Secret); Assert.AreEqual(Endpoints.Default, b.Endpoint); Assert.IsTrue(b.DisposeHttpClient); + Assert.DoesNotThrow(() => b.Validate()); } [Test] @@ -63,7 +80,7 @@ public void ConstructorThrowsWithNullSecret() { Environment.SetEnvironmentVariable("FAUNA_SECRET", null); var b = new Configuration(); - + b.Validate(); }); Environment.SetEnvironmentVariable("FAUNA_SECRET", currentVal); } @@ -76,6 +93,7 @@ public void ConstructorWithHttpClient() Assert.AreEqual("secret", b.Secret); Assert.AreEqual(Endpoints.Default, b.Endpoint); Assert.IsFalse(b.DisposeHttpClient); + Assert.DoesNotThrow(() => b.Validate()); } [Test] diff --git a/Fauna.Test/Connection.Tests.cs b/Fauna.Test/Connection.Tests.cs index e399da56..88b6138b 100644 --- a/Fauna.Test/Connection.Tests.cs +++ b/Fauna.Test/Connection.Tests.cs @@ -44,7 +44,7 @@ public void OneTimeSetup() var httpClient = new HttpClient(_handlerMock.Object) { BaseAddress = new Uri(TestBaseUri), }; - Configuration configuration = new("", httpClient) + Configuration configuration = new("secret", httpClient) { Endpoint = new Uri(TestBaseUri), RetryConfiguration = new RetryConfiguration(MaxRetries, TimeSpan.FromMilliseconds(20)) diff --git a/Fauna/Client.cs b/Fauna/Client.cs index 38ec0918..4257e5d9 100644 --- a/Fauna/Client.cs +++ b/Fauna/Client.cs @@ -59,6 +59,7 @@ public Client(string secret) : /// The configuration settings for the client. public Client(Configuration config) { + config.Validate(); _config = config; StatsCollector = config.StatsCollector; _connection = new Connection(config); diff --git a/Fauna/Configuration.cs b/Fauna/Configuration.cs index 582d3546..cb58bcab 100644 --- a/Fauna/Configuration.cs +++ b/Fauna/Configuration.cs @@ -61,11 +61,6 @@ public record class Configuration /// A logger. If null, a default logger is used. public Configuration(string secret = "", HttpClient? httpClient = null, ILogger? logger = null) { - if (string.IsNullOrEmpty(secret) && string.IsNullOrEmpty(Secret)) - { - throw new ArgumentNullException(nameof(Secret), "Need to set FAUNA_SECRET environment variable or pass a secret as a parameter when creating the Client."); - } - if (!string.IsNullOrEmpty(secret)) { Secret = secret; @@ -86,4 +81,13 @@ public Configuration(string secret = "", HttpClient? httpClient = null, ILogger? Logger.Initialize(logger); } } + + internal void Validate() + { + if (string.IsNullOrEmpty(Secret)) + throw new ArgumentNullException( + nameof(Secret), + "Need to set FAUNA_SECRET environment variable or pass a secret as a parameter when creating the Client." + ); + } }