annotate HowTo/Data/Parameter.cs @ 4:f757da6161a1

!bug 100 + 2h fixed gregression
author cin
date Sun, 24 Aug 2014 17:57:42 +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 using System.Data;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
3
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
4 using NUnit.Framework;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
5
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
6 using BLToolkit.Data;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
7
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
8 namespace HowTo.Data
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
9 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
10 using DataAccess;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
11
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
12 [TestFixture]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
13 public class Parameter
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
14 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
15 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
16 public void AssignParameterTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
17 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
18 using (DbManager db = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
19 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
20 int n = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
21 .SetCommand("SELECT @par1 + @par2",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
22 db./*[a]*/Parameter/*[/a]*/("@par1", 2),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
23 db./*[a]*/Parameter/*[/a]*/("@par2", 2))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
24 .ExecuteScalar<int>();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
25
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
26 Assert.AreEqual(4, n);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
27 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
28 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
29
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
30 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
31 public void SetValueTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
32 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
33 using (DbManager db = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
34 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
35 db.SetCommand("SELECT @par * 2",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
36 db./*[a]*/Parameter/*[/a]*/("@par", DbType.Int32));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
37
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
38 db./*[a]*/Parameter("@par").Value/*[/a]*/ = 2;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
39
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
40 Assert.AreEqual(4, db.ExecuteScalar<int>());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
41 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
42 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
43
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
44 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
45 public void ReturnValueTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
46 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
47 using (DbManager db = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
48 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
49 /*
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
50 * CREATE Function Scalar_ReturnParameter()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
51 * RETURNS int
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
52 * AS
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
53 * BEGIN
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
54 * RETURN 12345
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
55 * END
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
56 */
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
57 db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
58 .SetSpCommand("Scalar_ReturnParameter")
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
59 .ExecuteNonQuery();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
60
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
61 int n = (int)db./*[a]*/Parameter("@RETURN_VALUE").Value/*[/a]*/;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
62
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
63 Assert.AreEqual(12345, n);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
64 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
65 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
66
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
67 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
68 public void ReturnValueTest2()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
69 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
70 using (DbManager db = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
71 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
72 int n = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
73 .SetSpCommand("Scalar_ReturnParameter")
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
74 .ExecuteScalar<int>(ScalarSourceType.ReturnValue);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
75
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
76 Assert.AreEqual(12345, n);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
77 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
78 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
79
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
80 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
81 public void OutputParameterTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
82 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
83 using (DbManager db = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
84 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
85 /*
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
86 * CREATE Procedure Scalar_OutputParameter
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
87 * @outputInt int = 0 output,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
88 * @outputString varchar(50) = '' output
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
89 * AS
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
90 * BEGIN
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
91 * SET @outputInt = 12345
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
92 * SET @outputString = '54321'
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
93 * END
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
94 */
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
95
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
96 db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
97 .SetSpCommand("Scalar_OutputParameter",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
98 db./*[a]*/OutputParameter/*[/a]*/("@outputInt", 1),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
99 db./*[a]*/OutputParameter/*[/a]*/("@outputString", "1"))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
100 .ExecuteNonQuery();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
101
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
102 Assert.AreEqual(12345, (int) db./*[a]*/Parameter("@outputInt"). Value/*[/a]*/);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
103 Assert.AreEqual("54321", (string)db./*[a]*/Parameter("@outputString").Value/*[/a]*/);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
104 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
105 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
106
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
107 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
108 public void OutputParameterAsReturnValueTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
109 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
110 using (DbManager db = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
111 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
112 string returnValue = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
113 .SetSpCommand("Scalar_OutputParameter")
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
114 .ExecuteScalar<string>(/*[a]*/ScalarSourceType.OutputParameter/*[/a]*/, /*[a]*/"outputString"/*[/a]*/);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
115
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
116 Assert.AreEqual("54321", returnValue);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
117 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
118 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
119
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
120 [Test]
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
121 public void CreateParametersTest()
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
122 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
123 Person person = new Person();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
124
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
125 person.FirstName = "John";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
126 person.LastName = "Smith";
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
127 person.Gender = Gender.Male;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
128
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
129 using (DbManager db = new DbManager())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
130 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
131 db.BeginTransaction();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
132
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
133 // Prepare command.
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
134 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
135 int id = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
136 .SetSpCommand("Person_Insert",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
137 db./*[a]*/CreateParameters/*[/a]*/(person))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
138 .ExecuteScalar<int>();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
139
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
140 // Check the result.
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
141 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
142 person = db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
143 .SetCommand(
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
144 "SELECT * FROM Person WHERE PersonID = @id",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
145 db.Parameter("@id", id))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
146 .ExecuteObject<Person>();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
147
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
148 Assert.IsNotNull(person);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
149
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
150 // Cleanup.
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
151 //
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
152 db
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
153 .SetCommand(
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
154 "DELETE FROM Person WHERE PersonID = @id",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
155 db.Parameter("@id", id))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
156 .ExecuteNonQuery();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
157
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
158 db.CommitTransaction();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
159 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
160 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
161 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
162 }