OdbcParameterCollectionTest.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391
  1. //
  2. // OdbcParameterCollectionTest.cs - NUnit Test Cases for testing the
  3. // OdbcParameterCollection class
  4. // Author:
  5. // Sureshkumar T ([email protected])
  6. //
  7. // Copyright (c) 2004 Novell Inc., and the individuals listed
  8. // on the ChangeLog entries.
  9. //
  10. // Permission is hereby granted, free of charge, to any person obtaining
  11. // a copy of this software and associated documentation files (the
  12. // "Software"), to deal in the Software without restriction, including
  13. // without limitation the rights to use, copy, modify, merge, publish,
  14. // distribute, sublicense, and/or sell copies of the Software, and to
  15. // permit persons to whom the Software is furnished to do so, subject to
  16. // the following conditions:
  17. //
  18. // The above copyright notice and this permission notice shall be
  19. // included in all copies or substantial portions of the Software.
  20. //
  21. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  22. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  23. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  24. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  25. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  26. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  27. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  28. //
  29. using System;
  30. using System.Text;
  31. using System.Data;
  32. using System.Data.Odbc;
  33. using NUnit.Framework;
  34. namespace MonoTests.System.Data.Odbc
  35. {
  36. [TestFixture]
  37. [Category ("odbc")]
  38. public class OdbcParameterCollectionTest
  39. {
  40. /// <remarks>
  41. /// This tests whether the value is trimmed to the
  42. /// given length while passing parameters
  43. /// </remarks>
  44. [Test]
  45. public void ParameterLengthTrimTest ()
  46. {
  47. IDbConnection conn = ConnectionManager.Singleton.Connection;
  48. try {
  49. ConnectionManager.Singleton.OpenConnection ();
  50. OdbcCommand cmd = (OdbcCommand) conn.CreateCommand ();
  51. cmd.CommandType = CommandType.Text;
  52. cmd.CommandText = "SELECT count(*) FROM employee WHERE fname=?";
  53. OdbcParameter param = cmd.Parameters.Add("@fname", OdbcType.Text, 15);
  54. param.Value = DateTime.Now.ToString ();
  55. Assert.AreEqual (15, param.Size, "#1");
  56. Convert.ToInt32(cmd.ExecuteScalar());
  57. } finally {
  58. ConnectionManager.Singleton.CloseConnection ();
  59. }
  60. }
  61. [Test]
  62. public void InsertTest()
  63. {
  64. IDbConnection conn = ConnectionManager.Singleton.Connection;
  65. try {
  66. ConnectionManager.Singleton.OpenConnection ();
  67. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  68. OdbcCmd.CommandType = CommandType.Text;
  69. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  70. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  71. OdbcParameter p2Age = new OdbcParameter (); //not initialized and not yet added
  72. Assert.AreEqual (1, OdbcCmd.Parameters.Count, "#1 Make sure only the initializing parameter is added");
  73. OdbcCmd.Parameters.Insert (1, p2Age); //Inserting the second parameter
  74. Assert.AreEqual (2, OdbcCmd.Parameters.Count, "#2 Collection now contains both the parameters");
  75. //check the inserted positions
  76. Assert.AreEqual (0, OdbcCmd.Parameters.IndexOf ("@lname")); //checking the positions as string
  77. Assert.AreEqual (1, OdbcCmd.Parameters.IndexOf (p2Age)); //checking the positions as OdbcParameter
  78. Assert.AreEqual (-1, OdbcCmd.Parameters.IndexOf ("non-exixting-parameter")); //non exixting parameters should return index -1
  79. } finally {
  80. ConnectionManager.Singleton.CloseConnection ();
  81. }
  82. }
  83. [Test]
  84. public void AddRangeTest ()
  85. {
  86. IDbConnection conn = ConnectionManager.Singleton.Connection;
  87. try {
  88. ConnectionManager.Singleton.OpenConnection ();
  89. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  90. OdbcCmd.CommandType = CommandType.Text;
  91. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  92. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  93. OdbcParameter p2Age = new OdbcParameter (); //not initialized and not yet added
  94. OdbcParameter p3Tmp = new OdbcParameter (); //not initialized and not yet added
  95. OdbcParameter p4Tmp = new OdbcParameter (); //not initialized and not yet added
  96. OdbcParameter p5Tmp = new OdbcParameter (); //not initialized and not yet added
  97. Assert.AreEqual (1, OdbcCmd.Parameters.Count, "#1 Make sure only the initializing parameter is added");
  98. OdbcParameter [] paramArray = new OdbcParameter [4];
  99. paramArray [0] = p2Age;
  100. paramArray [1] = p3Tmp;
  101. paramArray [2] = p4Tmp;
  102. paramArray [3] = p5Tmp;
  103. OdbcCmd.Parameters.AddRange (paramArray);
  104. Assert.AreEqual (5, OdbcCmd.Parameters.Count, "#2 The array elements are added");
  105. Assert.AreEqual (1, OdbcCmd.Parameters.IndexOf (p2Age), "#3 The first element must be added after the last parameter");
  106. Assert.AreEqual (4, OdbcCmd.Parameters.IndexOf (p5Tmp), "#4 Ensure all the elements are added");
  107. } finally {
  108. ConnectionManager.Singleton.CloseConnection ();
  109. }
  110. }
  111. [Test]
  112. [ExpectedException (typeof (ArgumentOutOfRangeException))]
  113. public void InsertArgumentGreaterThanCountTest ()
  114. {
  115. IDbConnection conn = ConnectionManager.Singleton.Connection;
  116. try {
  117. ConnectionManager.Singleton.OpenConnection ();
  118. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  119. OdbcCmd.CommandType = CommandType.Text;
  120. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  121. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  122. OdbcParameter p2Age = new OdbcParameter ();
  123. Assert.AreEqual (1, OdbcCmd.Parameters.Count, "#1 Make sure only the initializing parameter is added");
  124. OdbcCmd.Parameters.Insert (2, p2Age); //Inserting with wrong index
  125. } finally {
  126. ConnectionManager.Singleton.CloseConnection ();
  127. }
  128. }
  129. [Test]
  130. [ExpectedException (typeof (ArgumentOutOfRangeException))]
  131. public void InsertNegetiveArgumentTest ()
  132. {
  133. IDbConnection conn = ConnectionManager.Singleton.Connection;
  134. try {
  135. ConnectionManager.Singleton.OpenConnection ();
  136. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  137. OdbcCmd.CommandType = CommandType.Text;
  138. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  139. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  140. OdbcParameter p2Age = new OdbcParameter (); //not initialized and not added
  141. Assert.AreEqual (1, OdbcCmd.Parameters.Count, "#1 Make sure no other parameters are present");
  142. OdbcCmd.Parameters.Insert (-3, p2Age); //Insert with negetive index
  143. } finally {
  144. ConnectionManager.Singleton.CloseConnection ();
  145. }
  146. }
  147. [Test]
  148. [ExpectedException (typeof (ArgumentException))]
  149. public void AddRangeParameterAlreadyContainedTest ()
  150. {
  151. IDbConnection conn = ConnectionManager.Singleton.Connection;
  152. try {
  153. ConnectionManager.Singleton.OpenConnection ();
  154. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  155. OdbcCmd.CommandType = CommandType.Text;
  156. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  157. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  158. OdbcParameter p2Age = new OdbcParameter (); //not initialized and not yet added
  159. OdbcParameter p3Tmp = new OdbcParameter (); //not initialized and not yet added
  160. Assert.AreEqual (1, OdbcCmd.Parameters.Count, "#1 Make sure only the initializing parameter is added");
  161. OdbcParameter [] paramArray = new OdbcParameter [3];
  162. paramArray [0] = p2Age;
  163. paramArray [1] = p1Lname; //p1Lname is already contained
  164. paramArray [2] = p3Tmp;
  165. OdbcCmd.Parameters.AddRange (paramArray);
  166. } finally {
  167. ConnectionManager.Singleton.CloseConnection ();
  168. }
  169. }
  170. [Test]
  171. [ExpectedException (typeof (ArgumentNullException))]
  172. public void AddRangeArgumentNullExceptionTest ()
  173. {
  174. IDbConnection conn = ConnectionManager.Singleton.Connection;
  175. try {
  176. ConnectionManager.Singleton.OpenConnection ();
  177. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  178. OdbcCmd.CommandType = CommandType.Text;
  179. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  180. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  181. OdbcParameter p2Age = new OdbcParameter ();
  182. OdbcParameter p3Tmp = new OdbcParameter ();
  183. Assert.AreEqual (1, OdbcCmd.Parameters.Count, "#1 Make sure only the initializing parameter is added");
  184. OdbcParameter [] paramArray = new OdbcParameter [3];
  185. paramArray [0] = p2Age;
  186. paramArray [1] = p3Tmp;
  187. paramArray [2] = null;
  188. OdbcCmd.Parameters.AddRange (paramArray);
  189. } finally {
  190. ConnectionManager.Singleton.CloseConnection ();
  191. }
  192. }
  193. [Test]
  194. public void AddRangeMultiDimensionalArrayTest ()
  195. {
  196. IDbConnection conn = ConnectionManager.Singleton.Connection;
  197. try {
  198. ConnectionManager.Singleton.OpenConnection ();
  199. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  200. OdbcCmd.CommandType = CommandType.Text;
  201. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  202. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  203. OdbcParameter p2Age = new OdbcParameter ();
  204. OdbcParameter p3Tmp = new OdbcParameter ();
  205. OdbcParameter p4Tmp = new OdbcParameter ();
  206. OdbcParameter p5Tmp = new OdbcParameter ();
  207. Assert.AreEqual (1, OdbcCmd.Parameters.Count, "#1 Make sure only the initializing parameter is added");
  208. OdbcParameter [,] paramArray = new OdbcParameter [2, 2];
  209. paramArray [0, 0] = p2Age;
  210. paramArray [0, 1] = p3Tmp;
  211. paramArray [1, 0] = p4Tmp;
  212. paramArray [1, 1] = p5Tmp;
  213. OdbcCmd.Parameters.AddRange (paramArray);
  214. Assert.AreEqual (5, OdbcCmd.Parameters.Count, "#2 Four parameters of the 2x2 Array are added");
  215. Assert.AreEqual (1, OdbcCmd.Parameters.IndexOf (p2Age), "#3 The first element must be added after the last parameter");
  216. Assert.AreEqual (4, OdbcCmd.Parameters.IndexOf (p5Tmp), "#4 Ensure all the elements are added");
  217. } finally {
  218. ConnectionManager.Singleton.CloseConnection ();
  219. }
  220. }
  221. //<remarks>
  222. //Tests all the three overloads of Contains
  223. //</remarks>
  224. [Test]
  225. public void ContainsTest ()
  226. {
  227. IDbConnection conn = ConnectionManager.Singleton.Connection;
  228. try {
  229. ConnectionManager.Singleton.OpenConnection ();
  230. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  231. OdbcCmd.CommandType = CommandType.Text;
  232. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  233. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  234. OdbcParameter p2Age = OdbcCmd.Parameters.Add ("@age", OdbcType.Int, 2);
  235. OdbcParameter p3Tmp = new OdbcParameter ();
  236. OdbcCmd.Parameters.Insert (2, p3Tmp);
  237. Assert.AreEqual (3, OdbcCmd.Parameters.Count, "#1 All the parameters are added");
  238. Assert.IsTrue (OdbcCmd.Parameters.Contains (p1Lname), "#2 Checking Contains with OdbcParameter value");
  239. Assert.IsTrue (OdbcCmd.Parameters.Contains ("@age"), "#3 Checking Contains with string value");
  240. Assert.IsTrue (OdbcCmd.Parameters.Contains (p3Tmp), "#4 Checking Contains with object value");
  241. } finally {
  242. ConnectionManager.Singleton.CloseConnection ();
  243. }
  244. }
  245. [Test]
  246. public void IndexOfTest ()
  247. {
  248. IDbConnection conn = ConnectionManager.Singleton.Connection;
  249. try {
  250. ConnectionManager.Singleton.OpenConnection ();
  251. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  252. OdbcCmd.CommandType = CommandType.Text;
  253. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  254. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  255. OdbcParameter p2Age = OdbcCmd.Parameters.Add ("@age", OdbcType.Int, 2);
  256. OdbcParameter p3Tmp = new OdbcParameter ();
  257. Assert.AreEqual (2, OdbcCmd.Parameters.Count, "#1 both the parameters are added");
  258. Assert.AreEqual (0, OdbcCmd.Parameters.IndexOf (p1Lname), "#1 first parameter");
  259. Assert.AreEqual (1, OdbcCmd.Parameters.IndexOf (p2Age), "#2 second parametr");
  260. Assert.AreEqual (-1, OdbcCmd.Parameters.IndexOf (p3Tmp), "#3 not present");
  261. } finally {
  262. ConnectionManager.Singleton.CloseConnection ();
  263. }
  264. }
  265. [Test]
  266. public void CopyToTest ()
  267. {
  268. IDbConnection conn = ConnectionManager.Singleton.Connection;
  269. try {
  270. ConnectionManager.Singleton.OpenConnection ();
  271. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  272. OdbcCmd.CommandType = CommandType.Text;
  273. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  274. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  275. OdbcParameter p2Age = OdbcCmd.Parameters.Add ("@age", OdbcType.Int, 2);
  276. Assert.AreEqual (2, OdbcCmd.Parameters.Count, "#1 Make sure both the parameters are present");
  277. OdbcParameter [] DestinationParamArray = new OdbcParameter [4];
  278. OdbcCmd.Parameters.CopyTo (DestinationParamArray, 1); //starting at 1 instead of 0
  279. Assert.AreEqual (4, DestinationParamArray.Length, "#2 The array length should not change");
  280. Assert.AreEqual ("@lname", DestinationParamArray [1].ParameterName, "#3 The first parameter copied to array at index 1");
  281. Assert.AreEqual ("@age", DestinationParamArray [2].ParameterName, "#4 The second parameter copied to array at index 2");
  282. Assert.AreEqual (null, DestinationParamArray [0], "#5 The remaining elements remain un-initialized");
  283. Assert.AreEqual (null, DestinationParamArray [3], "#6 The remaining elements remain un-initialized");
  284. } finally {
  285. ConnectionManager.Singleton.CloseConnection ();
  286. }
  287. }
  288. [Test]
  289. [ExpectedException (typeof (ArgumentException))]
  290. public void CopyToArgumentExceptionTest ()
  291. {
  292. IDbConnection conn = ConnectionManager.Singleton.Connection;
  293. try {
  294. ConnectionManager.Singleton.OpenConnection ();
  295. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  296. OdbcCmd.CommandType = CommandType.Text;
  297. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  298. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  299. OdbcParameter p2Age = OdbcCmd.Parameters.Add ("@age", OdbcType.Int, 2);
  300. Assert.AreEqual (2, OdbcCmd.Parameters.Count, "#1 Make sure both the parameters are present");
  301. OdbcParameter [] DestinationParamArray = new OdbcParameter [4];
  302. OdbcCmd.Parameters.CopyTo (DestinationParamArray, 3); //starting at 3, thus the second element will be at index 4
  303. } finally {
  304. ConnectionManager.Singleton.CloseConnection ();
  305. }
  306. }
  307. [Test]
  308. [ExpectedException (typeof (ArgumentException))]
  309. public void CopyToMultiDimensionalArrayTest ()
  310. {
  311. IDbConnection conn = ConnectionManager.Singleton.Connection;
  312. try {
  313. ConnectionManager.Singleton.OpenConnection ();
  314. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  315. OdbcCmd.CommandType = CommandType.Text;
  316. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  317. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  318. OdbcParameter p2Age = OdbcCmd.Parameters.Add ("@age", OdbcType.Int, 2);
  319. Assert.AreEqual (2, OdbcCmd.Parameters.Count, "#1 Make sure both the parameters are present");
  320. OdbcParameter [,] DestinationParamArray = new OdbcParameter [2, 4];
  321. OdbcCmd.Parameters.CopyTo (DestinationParamArray, 1); //DestinationParamArray is multi Dimensional
  322. } finally {
  323. ConnectionManager.Singleton.CloseConnection ();
  324. }
  325. }
  326. [Test]
  327. [ExpectedException (typeof (ArgumentOutOfRangeException))]
  328. public void CopyToLowerBoundCheckTest ()
  329. {
  330. IDbConnection conn = ConnectionManager.Singleton.Connection;
  331. try {
  332. ConnectionManager.Singleton.OpenConnection ();
  333. OdbcCommand OdbcCmd = (OdbcCommand) conn.CreateCommand ();
  334. OdbcCmd.CommandType = CommandType.Text;
  335. OdbcCmd.CommandText = "SELECT fname FROM employee WHERE lname=? AND age=?";
  336. OdbcParameter p1Lname = OdbcCmd.Parameters.Add ("@lname", OdbcType.Text, 15);
  337. OdbcParameter p2Age = OdbcCmd.Parameters.Add ("@age", OdbcType.Int, 2);
  338. Assert.AreEqual (2, OdbcCmd.Parameters.Count, "#1 Make sure both the parameters are present");
  339. OdbcParameter [] DestinationParamArray = new OdbcParameter [4];
  340. OdbcCmd.Parameters.CopyTo (DestinationParamArray, -1); //index must be >= 0
  341. } finally {
  342. ConnectionManager.Singleton.CloseConnection ();
  343. }
  344. }
  345. }
  346. }