diff --git a/Snowflake.Data.Tests/IntegrationTests/SFDbDataReaderIT.cs b/Snowflake.Data.Tests/IntegrationTests/SFDbDataReaderIT.cs index 158abc7f0..4a80e6ca0 100755 --- a/Snowflake.Data.Tests/IntegrationTests/SFDbDataReaderIT.cs +++ b/Snowflake.Data.Tests/IntegrationTests/SFDbDataReaderIT.cs @@ -562,6 +562,47 @@ public void testGetBoolean() } } + [Test] + public void testGetByte() + { + using (IDbConnection conn = new SnowflakeDbConnection()) + { + // Arrange + conn.ConnectionString = ConnectionString; + conn.Open(); + + CreateOrReplaceTable(conn, TableName, new[] + { + "col1 BINARY", + }); + + byte[] testBytes = Encoding.UTF8.GetBytes("TEST_GET_BINARAY"); + + IDbCommand cmd = conn.CreateCommand(); + + var p1 = cmd.CreateParameter(); + p1.ParameterName = "1"; + p1.DbType = DbType.Binary; + p1.Value = testBytes; + + cmd.Parameters.Add(p1); + cmd.CommandText = $"insert into {TableName} values (?)"; + cmd.ExecuteNonQuery(); + cmd.CommandText = $"select * from {TableName}"; + + // Act + using (IDataReader reader = cmd.ExecuteReader()) + { + int index = 0; + while (reader.Read()) + { + // Assert + Assert.AreEqual(testBytes[index++], reader.GetByte(0)); + } + } + } + } + [Test] public void testGetBinary() { @@ -705,6 +746,37 @@ public void testGetBinary() } } + [Test] + public void testGetChar() + { + using (IDbConnection conn = new SnowflakeDbConnection()) + { + // Arrange + conn.ConnectionString = ConnectionString; + conn.Open(); + + CreateOrReplaceTable(conn, TableName, new[] + { + "col1 VARCHAR(50)", + }); + + char testChar = 'T'; + + IDbCommand cmd = conn.CreateCommand(); + cmd.CommandText = $"insert into {TableName} values ('{testChar}')"; + cmd.ExecuteNonQuery(); + cmd.CommandText = $"select * from {TableName}"; + + // Act + using (IDataReader reader = cmd.ExecuteReader()) + { + // Assert + Assert.IsTrue(reader.Read()); + Assert.AreEqual(testChar, reader.GetChar(0)); + } + } + } + [Test] public void testGetChars() { @@ -850,6 +922,50 @@ public void testGetChars() } } + [Test] + public void testGetDataTypeName() + { + using (IDbConnection conn = new SnowflakeDbConnection()) + { + // Arrange + conn.ConnectionString = ConnectionString; + conn.Open(); + + CreateOrReplaceTable(conn, TableName, new[] + { + "col1 VARCHAR(50)", + "col2 BINARY", + "col3 DOUBLE" + }); + + string testChars = "TEST_GET_CHARS"; + byte[] testBytes = Encoding.UTF8.GetBytes("TEST_GET_BINARY"); + double testDouble = 1.2345678; + + IDbCommand cmd = conn.CreateCommand(); + + var p1 = cmd.CreateParameter(); + p1.ParameterName = "1"; + p1.DbType = DbType.Binary; + p1.Value = testBytes; + + cmd.Parameters.Add(p1); + cmd.CommandText = $"insert into {TableName} values ('{testChars}', ?, {testDouble.ToString()})"; + cmd.ExecuteNonQuery(); + cmd.CommandText = $"select * from {TableName}"; + + // Act + using (DbDataReader reader = (DbDataReader)cmd.ExecuteReader()) + { + // Assert + Assert.IsTrue(reader.Read()); + Assert.AreEqual("TEXT", reader.GetDataTypeName(0)); + Assert.AreEqual("BINARY", reader.GetDataTypeName(1)); + Assert.AreEqual("REAL", reader.GetDataTypeName(2)); + } + } + } + [Test] public void testGetStream() { diff --git a/Snowflake.Data.Tests/IntegrationTests/SFDbTransactionIT.cs b/Snowflake.Data.Tests/IntegrationTests/SFDbTransactionIT.cs index c0b571f98..2786d8226 100644 --- a/Snowflake.Data.Tests/IntegrationTests/SFDbTransactionIT.cs +++ b/Snowflake.Data.Tests/IntegrationTests/SFDbTransactionIT.cs @@ -15,6 +15,42 @@ namespace Snowflake.Data.Tests.IntegrationTests [TestFixture] class SFDbTransactionIT : SFBaseTest { + [Test] + public void TestTransactionDbConnection() + { + using (var conn = new SnowflakeDbConnection()) + { + // Arrange + conn.ConnectionString = ConnectionString; + conn.Open(); + + // Act + using (IDbTransaction t1 = conn.BeginTransaction()) + { + // Assert + Assert.AreEqual(conn, t1.Connection); + } + } + } + + [Test] + public void TestTransactionIsolationLevel() + { + using (var conn = new SnowflakeDbConnection()) + { + // Arrange + conn.ConnectionString = ConnectionString; + conn.Open(); + + // Act + using (IDbTransaction t1 = conn.BeginTransaction()) + { + // Assert + Assert.AreEqual(IsolationLevel.ReadCommitted, t1.IsolationLevel); + } + } + } + [Test] // Test that when a transaction is disposed, rollback would be sent out public void TestTransactionDispose() diff --git a/Snowflake.Data.Tests/UnitTests/SFDbCommandTest.cs b/Snowflake.Data.Tests/UnitTests/SFDbCommandTest.cs new file mode 100644 index 000000000..e4350cd61 --- /dev/null +++ b/Snowflake.Data.Tests/UnitTests/SFDbCommandTest.cs @@ -0,0 +1,43 @@ +/* + * Copyright (c) 2012-2023 Snowflake Computing Inc. All rights reserved. + */ + +namespace Snowflake.Data.Tests.UnitTests +{ + using NUnit.Framework; + using Snowflake.Data.Client; + using System; + + [TestFixture] + class SFDbCommandTest + { + SnowflakeDbCommand command; + + [SetUp] + public void BeforeTest() + { + command = new SnowflakeDbCommand(); + } + + [Test] + public void TestCommandWithConnectionAndCommandText() + { + // Arrange + SnowflakeDbConnection conn = new SnowflakeDbConnection(); + string commandText = "select 1"; + + // Act + command = new SnowflakeDbCommand(conn, commandText); + + // Assert + Assert.AreEqual(conn, command.Connection); + Assert.AreEqual(commandText, command.CommandText); + } + + [Test] + public void TestCommandPrepareThrowsNotImplemented() + { + Assert.Throws(() => command.Prepare()); + } + } +}