annotate UnitTests/CS/Data/BinaryTest.cs @ 1:8f65451dc28f

Исправлена проблема с фабрикой и выборкой нескольких объектов в linq выражении
author cin
date Fri, 28 Mar 2014 01:04:56 +0400
parents f990fcb411a9
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
1 using System;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
2
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
3 using NUnit.Framework;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
4
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
5 using BLToolkit.Data;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
6 using BLToolkit.Data.DataProvider;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
7
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
8 namespace Data
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
9 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
10 [TestFixture]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
11 public class BinaryTest
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
12 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
13 public class BinaryData
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
14 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
15 public int BinaryDataID;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
16 public byte[] Stamp;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
17 public byte[] Data;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
18 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
19
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
20 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
21 public void Test()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
22 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
23 using (DbManager db = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
24 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
25 object id;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
26 #if ORACLE
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
27 id = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
28 .SetCommand("INSERT INTO BinaryData (Data) VALUES (:pData) RETURNING BinaryDataID INTO :pID",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
29 db.Parameter("pData", new byte[] { 1, 2, 3, 4, 5}),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
30 db.OutputParameter("pID", System.Data.DbType.Int32)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
31 )
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
32 .ExecuteScalar(ScalarSourceType.OutputParameter, "ID");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
33 #elif MSSQL
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
34 id = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
35 .SetCommand("INSERT INTO BinaryData (Data) VALUES (@Data)\nSELECT Cast(SCOPE_IDENTITY() as int)",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
36 db.Parameter("@Data", new byte[] { 1, 2, 3, 4, 5}))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
37 .ExecuteScalar();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
38 #elif FIREBIRD
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
39 db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
40 .SetCommand("INSERT INTO BinaryData (Data) VALUES (@Data)",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
41 db.Parameter("@Data", new byte[] { 1, 2, 3, 4, 5}))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
42 .ExecuteNonQuery();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
43
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
44 id = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
45 .SetCommand("SELECT GEN_ID(PersonID, 0) FROM dual")
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
46 .ExecuteScalar();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
47 #elif ACCESS || SQLCE
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
48 db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
49 .SetCommand("INSERT INTO BinaryData (Data) VALUES (@Data)",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
50 db.Parameter("@Data", new byte[] { 1, 2, 3, 4, 5}))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
51 .ExecuteNonQuery();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
52
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
53 id = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
54 .SetCommand("SELECT @@IDENTITY")
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
55 .ExecuteScalar();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
56 #elif SQLITE
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
57 db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
58 .SetCommand("INSERT INTO BinaryData (Stamp, Data) VALUES (datetime('now'), @Data)",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
59 db.Parameter("@Data", new byte[] { 1, 2, 3, 4, 5}))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
60 .ExecuteNonQuery();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
61
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
62 id = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
63 .SetCommand("SELECT last_insert_rowid()")
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
64 .ExecuteScalar();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
65 #else
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
66 Assert.Fail("Unknown DB type.");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
67 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
68
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
69 BinaryData bd = (BinaryData)db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
70 .SetCommand(
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
71 "SELECT * FROM BinaryData WHERE BinaryDataID = " + db.DataProvider.Convert("id", ConvertType.NameToQueryParameter),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
72 db.Parameter("id", id))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
73 .ExecuteObject(typeof(BinaryData));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
74
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
75 Assert.IsNotNull(bd);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
76 Assert.AreEqual(5, bd.Data. Length);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
77 #if FIREBIRD
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
78 // Stamps are integers in Firebird.
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
79 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
80 Assert.AreEqual(4, bd.Stamp.Length);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
81 #elif ACCESS || SQLCE
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
82 // Not supported in MS Access
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
83 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
84 Assert.IsNull(bd.Stamp);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
85 #else
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
86 Assert.AreEqual(8, bd.Stamp.Length);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
87 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
88
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
89 db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
90 #if FIREBIRD || ACCESS || SQLCE || SQLITE
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
91 .SetCommand("DELETE FROM BinaryData")
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
92 #else
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
93 .SetCommand("TRUNCATE TABLE BinaryData")
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
94 #endif
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
95 .ExecuteNonQuery();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
96 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
97 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
98 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
99 }