Files
sqltoolsservice/test/Microsoft.Kusto.ServiceLayer.UnitTests/Connection/ConnectionInfoTests.cs
Charles Gagnon c248400a6c Add linting for copyright and unused usings (#1416)
* Add linting for copyright and unused usings

* Add one more + comment

* Enforce in build and fix errors

* Fix build
2022-03-04 15:17:29 -08:00

94 lines
4.3 KiB
C#

//
// Copyright (c) Microsoft. All rights reserved.
// Licensed under the MIT license. See LICENSE file in the project root for full license information.
//
using System;
using Microsoft.Kusto.ServiceLayer.Connection;
using Microsoft.Kusto.ServiceLayer.Connection.Contracts;
using Microsoft.Kusto.ServiceLayer.DataSource;
using Microsoft.SqlTools.ServiceLayer.Connection.ReliableConnection;
using Moq;
using NUnit.Framework;
namespace Microsoft.Kusto.ServiceLayer.UnitTests.Connection
{
public class ConnectionInfoTests
{
[TestCase("")]
[TestCase(null)]
public void AddConnection_Throws_Exception_For_Invalid_ConnectionType(string connectionType)
{
var datasourceFactoryMock = new Mock<IDataSourceConnectionFactory>();
var connectionInfo = new ConnectionInfo(datasourceFactoryMock.Object, "", new ConnectionDetails());
Assert.Throws<ArgumentException>(() => connectionInfo.AddConnection(connectionType, null));
}
[TestCase("")]
[TestCase(null)]
public void GetConnection_Throws_Exception_For_Invalid_ConnectionType(string connectionType)
{
var datasourceFactoryMock = new Mock<IDataSourceConnectionFactory>();
var connectionInfo = new ConnectionInfo(datasourceFactoryMock.Object, "", new ConnectionDetails());
Assert.Throws<ArgumentException>(() => connectionInfo.TryGetConnection(connectionType, out var connection));
}
[Test]
public void AddConnection_And_GetConnection_AddAndGet()
{
var connectionFactoryMock = new Mock<IDataSourceConnectionFactory>();
var connectionInfo = new ConnectionInfo(connectionFactoryMock.Object, "", new ConnectionDetails());
var dataSourceFactoryMock = new Mock<IDataSourceFactory>();
var reliableDataSource = new ReliableDataSourceConnection(new ConnectionDetails(), RetryPolicyFactory.NoRetryPolicy,
RetryPolicyFactory.NoRetryPolicy, dataSourceFactoryMock.Object, "");
connectionInfo.AddConnection("ConnectionType", reliableDataSource);
connectionInfo.TryGetConnection("ConnectionType", out var connection);
Assert.AreEqual(reliableDataSource, connection);
}
[TestCase("")]
[TestCase(null)]
public void RemoveConnection_Throws_Exception_For_Invalid_ConnectionType(string connectionType)
{
var datasourceFactoryMock = new Mock<IDataSourceConnectionFactory>();
var connectionInfo = new ConnectionInfo(datasourceFactoryMock.Object, "", new ConnectionDetails());
Assert.Throws<ArgumentException>(() => connectionInfo.RemoveConnection(connectionType));
}
[Test]
public void RemoveConnection_Removes_Connection()
{
var connectionFactoryMock = new Mock<IDataSourceConnectionFactory>();
var connectionInfo = new ConnectionInfo(connectionFactoryMock.Object, "", new ConnectionDetails());
var dataSourceFactoryMock = new Mock<IDataSourceFactory>();
var reliableDataSource = new ReliableDataSourceConnection(new ConnectionDetails(), RetryPolicyFactory.NoRetryPolicy,
RetryPolicyFactory.NoRetryPolicy, dataSourceFactoryMock.Object, "");
connectionInfo.AddConnection("ConnectionType", reliableDataSource);
connectionInfo.RemoveConnection("ConnectionType");
connectionInfo.TryGetConnection("ConnectionType", out var connection);
Assert.IsNull(connection);
}
[Test]
public void RemoveAllConnections_RemovesAllConnections()
{
var connectionFactoryMock = new Mock<IDataSourceConnectionFactory>();
var connectionInfo = new ConnectionInfo(connectionFactoryMock.Object, "", new ConnectionDetails());
var dataSourceFactoryMock = new Mock<IDataSourceFactory>();
var reliableDataSource = new ReliableDataSourceConnection(new ConnectionDetails(), RetryPolicyFactory.NoRetryPolicy,
RetryPolicyFactory.NoRetryPolicy, dataSourceFactoryMock.Object, "");
connectionInfo.AddConnection("ConnectionType", reliableDataSource);
connectionInfo.RemoveAllConnections();
connectionInfo.TryGetConnection("ConnectionType", out var connection);
Assert.IsNull(connection);
}
}
}