Mercurial > pub > bltoolkit
view UnitTests/CS/Data/BinaryTest.cs @ 0:f990fcb411a9
Копия текущей версии из github
author | cin |
---|---|
date | Thu, 27 Mar 2014 21:46:09 +0400 (2014-03-27) |
parents | |
children |
line wrap: on
line source
using System; using NUnit.Framework; using BLToolkit.Data; using BLToolkit.Data.DataProvider; namespace Data { [TestFixture] public class BinaryTest { public class BinaryData { public int BinaryDataID; public byte[] Stamp; public byte[] Data; } [Test] public void Test() { using (DbManager db = new DbManager()) { object id; #if ORACLE id = db .SetCommand("INSERT INTO BinaryData (Data) VALUES (:pData) RETURNING BinaryDataID INTO :pID", db.Parameter("pData", new byte[] { 1, 2, 3, 4, 5}), db.OutputParameter("pID", System.Data.DbType.Int32) ) .ExecuteScalar(ScalarSourceType.OutputParameter, "ID"); #elif MSSQL id = db .SetCommand("INSERT INTO BinaryData (Data) VALUES (@Data)\nSELECT Cast(SCOPE_IDENTITY() as int)", db.Parameter("@Data", new byte[] { 1, 2, 3, 4, 5})) .ExecuteScalar(); #elif FIREBIRD db .SetCommand("INSERT INTO BinaryData (Data) VALUES (@Data)", db.Parameter("@Data", new byte[] { 1, 2, 3, 4, 5})) .ExecuteNonQuery(); id = db .SetCommand("SELECT GEN_ID(PersonID, 0) FROM dual") .ExecuteScalar(); #elif ACCESS || SQLCE db .SetCommand("INSERT INTO BinaryData (Data) VALUES (@Data)", db.Parameter("@Data", new byte[] { 1, 2, 3, 4, 5})) .ExecuteNonQuery(); id = db .SetCommand("SELECT @@IDENTITY") .ExecuteScalar(); #elif SQLITE db .SetCommand("INSERT INTO BinaryData (Stamp, Data) VALUES (datetime('now'), @Data)", db.Parameter("@Data", new byte[] { 1, 2, 3, 4, 5})) .ExecuteNonQuery(); id = db .SetCommand("SELECT last_insert_rowid()") .ExecuteScalar(); #else Assert.Fail("Unknown DB type."); #endif BinaryData bd = (BinaryData)db .SetCommand( "SELECT * FROM BinaryData WHERE BinaryDataID = " + db.DataProvider.Convert("id", ConvertType.NameToQueryParameter), db.Parameter("id", id)) .ExecuteObject(typeof(BinaryData)); Assert.IsNotNull(bd); Assert.AreEqual(5, bd.Data. Length); #if FIREBIRD // Stamps are integers in Firebird. // Assert.AreEqual(4, bd.Stamp.Length); #elif ACCESS || SQLCE // Not supported in MS Access // Assert.IsNull(bd.Stamp); #else Assert.AreEqual(8, bd.Stamp.Length); #endif db #if FIREBIRD || ACCESS || SQLCE || SQLITE .SetCommand("DELETE FROM BinaryData") #else .SetCommand("TRUNCATE TABLE BinaryData") #endif .ExecuteNonQuery(); } } } }