OdbcConnectionStringBuilderTest.cs 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835
  1. // OdbcConnectionStringBuilderTest.cs - NUnit Test Cases for testing the
  2. // OdbcConnectionStringBuilder Class.
  3. //
  4. // Authors:
  5. // Nidhi Rawal ([email protected])
  6. // Gert Driesen ([email protected])
  7. //
  8. // Copyright (c) 2007 Novell Inc., and the individuals listed on the
  9. // ChangeLog entries.
  10. //
  11. //
  12. // Permission is hereby granted, free of charge, to any person
  13. // obtaining a copy of this software and associated documentation
  14. // files (the "Software"), to deal in the Software without
  15. // restriction, including without limitation the rights to use, copy,
  16. // modify, merge, publish, distribute, sublicense, and/or sell copies
  17. // of the Software, and to permit persons to whom the Software is
  18. // furnished to do so, subject to the following conditions:
  19. //
  20. // The above copyright notice and this permission notice shall be
  21. // included in all copies or substantial portions of the Software.
  22. //
  23. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  24. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  25. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  26. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
  27. // BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
  28. // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  29. // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  30. // SOFTWARE.
  31. #if NET_2_0
  32. using System;
  33. using System.Collections;
  34. using System.Data;
  35. using System.Data.Common;
  36. using System.Data.Odbc;
  37. using NUnit.Framework;
  38. namespace MonoTests.System.Data.Odbc
  39. {
  40. [TestFixture]
  41. public class OdbcConnectionStringBuilderTest
  42. {
  43. [Test]
  44. public void ConnectionStringConstructorTest ()
  45. {
  46. OdbcConnectionStringBuilder builder;
  47. builder = new OdbcConnectionStringBuilder ("Driver={SQL Server};Server=(local);Database=AdventureWorks;Uid=ab;Pwd=pass@word1");
  48. Assert.AreEqual ("AdventureWorks", builder ["Database"],"#A1");
  49. Assert.AreEqual ("pass@word1", builder ["Pwd"], "#A2");
  50. Assert.AreEqual ("ab", builder ["Uid"], "#A3");
  51. Assert.AreEqual ("{SQL Server}", builder ["Driver"], "#A4");
  52. Assert.AreEqual ("(local)", builder ["Server"],"#A5");
  53. Assert.AreEqual ("Driver={SQL Server};server=(local);database=AdventureWorks;uid=ab;pwd=pass@word1", builder.ConnectionString,"#A5");
  54. builder = new OdbcConnectionStringBuilder ("Driver=");
  55. Assert.AreEqual (string.Empty, builder.ConnectionString, "#B");
  56. builder = new OdbcConnectionStringBuilder ("Dsn=");
  57. Assert.AreEqual (string.Empty, builder.ConnectionString, "#C");
  58. builder = new OdbcConnectionStringBuilder (null);
  59. Assert.AreEqual (string.Empty, builder.ConnectionString, "#D");
  60. builder = new OdbcConnectionStringBuilder (string.Empty);
  61. Assert.AreEqual (string.Empty, builder.ConnectionString, "#E");
  62. builder = new OdbcConnectionStringBuilder ("Driver=SQL {Server;Dsn=Adventu{re");
  63. Assert.AreEqual ("SQL {Server", builder ["Driver"], "#F1");
  64. Assert.AreEqual ("SQL {Server", builder.Driver, "#F2");
  65. Assert.AreEqual ("Adventu{re", builder ["Dsn"], "#F3");
  66. Assert.AreEqual ("Adventu{re", builder.Dsn, "#F4");
  67. Assert.AreEqual ("Dsn=Adventu{re;Driver={SQL {Server}", builder.ConnectionString, "#F5");
  68. }
  69. [Test]
  70. public void Add ()
  71. {
  72. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  73. builder.Add ("driverid", "420");
  74. builder.Add ("driverid", "560");
  75. builder.Add ("DriverID", "840");
  76. Assert.AreEqual ("840", builder ["driverId"], "#A1");
  77. Assert.IsTrue (builder.ContainsKey ("driverId"), "#A2");
  78. builder.Add ("Driver", "OdbcDriver");
  79. Assert.AreEqual ("OdbcDriver", builder.Driver, "#B1");
  80. Assert.AreEqual ("OdbcDriver", builder ["Driver"], "#B2");
  81. Assert.IsTrue (builder.ContainsKey ("Driver"), "#B3");
  82. builder.Add ("Driver", "{OdbcDriver");
  83. Assert.AreEqual ("{OdbcDriver", builder.Driver, "#C1");
  84. Assert.AreEqual ("{OdbcDriver", builder ["Driver"], "#C2");
  85. Assert.IsTrue (builder.ContainsKey ("Driver"), "#C3");
  86. builder.Add ("Dsn", "MyDsn");
  87. Assert.AreEqual ("MyDsn", builder.Dsn, "#D1");
  88. Assert.AreEqual ("MyDsn", builder ["Dsn"], "#D2");
  89. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#D3");
  90. builder.Add ("dsN", "MyDsn2");
  91. Assert.AreEqual ("MyDsn2", builder.Dsn, "#E1");
  92. Assert.AreEqual ("MyDsn2", builder ["Dsn"], "#E2");
  93. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#E3");
  94. }
  95. [Test]
  96. public void Add_Keyword_Invalid ()
  97. {
  98. string [] invalid_keywords = new string [] {
  99. string.Empty,
  100. " ",
  101. " abc",
  102. "abc ",
  103. "\r",
  104. "ab\rc",
  105. ";abc",
  106. "a\0b"
  107. };
  108. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  109. for (int i = 0; i < invalid_keywords.Length; i++) {
  110. string keyword = invalid_keywords [i];
  111. try {
  112. builder.Add (keyword, "abc");
  113. Assert.Fail ("#1:" + i);
  114. } catch (ArgumentException ex) {
  115. // Invalid keyword, contain one or more of 'no characters',
  116. // 'control characters', 'leading or trailing whitespace'
  117. // or 'leading semicolons'
  118. Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:"+ i);
  119. Assert.IsNull (ex.InnerException, "#3:" + i);
  120. Assert.IsNotNull (ex.Message, "#4:" + i);
  121. Assert.IsTrue (ex.Message.IndexOf ("'" + keyword + "'") == -1, "#5:" + i);
  122. Assert.AreEqual (keyword, ex.ParamName, "#6:" + i);
  123. }
  124. }
  125. }
  126. [Test]
  127. public void Add_Keyword_Null ()
  128. {
  129. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  130. try {
  131. builder.Add (null, "abc");
  132. Assert.Fail ("#1");
  133. } catch (ArgumentNullException ex) {
  134. Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
  135. Assert.IsNull (ex.InnerException, "#3");
  136. Assert.IsNotNull (ex.Message, "#4");
  137. Assert.AreEqual ("keyword", ex.ParamName, "#5");
  138. }
  139. }
  140. [Test]
  141. public void Clear ()
  142. {
  143. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  144. builder ["Dbq"] = "C:\\Data.xls";
  145. builder.Driver = "SQL Server";
  146. builder.Dsn = "AdventureWorks";
  147. builder.Add ("Port", "56");
  148. builder.Clear ();
  149. Assert.AreEqual (string.Empty, builder.ConnectionString, "#1");
  150. Assert.IsFalse (builder.ContainsKey ("Dbq"), "#2");
  151. Assert.AreEqual (string.Empty, builder.Driver, "#3");
  152. Assert.AreEqual (string.Empty, builder.Dsn, "#4");
  153. Assert.IsFalse (builder.ContainsKey ("Port"), "#5");
  154. }
  155. [Test]
  156. public void ConnectionString ()
  157. {
  158. OdbcConnectionStringBuilder builder;
  159. builder = new OdbcConnectionStringBuilder (@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\Northwind.mdb;Jet OLEDB:System Database=|DataDirectory|\System.mdw;");
  160. Assert.AreEqual ("Microsoft.Jet.OLEDB.4.0", builder ["Provider"], "#A1");
  161. Assert.AreEqual (@"|DataDirectory|\Northwind.mdb", builder ["Data Source"], "#A2");
  162. Assert.AreEqual (@"|DataDirectory|\System.mdw", builder ["Jet OLEDB:System Database"], "#A3");
  163. builder = new OdbcConnectionStringBuilder ();
  164. builder ["Data SourcE"] = "(local)";
  165. builder ["Integrated SecuritY"] = true;
  166. builder.Driver = "SQL Server";
  167. builder ["Initial Catalog"] = "AdventureWorks;NewValue=Bad";
  168. Assert.AreEqual ("Driver={SQL Server};Data SourcE=(local);Integrated SecuritY=True;Initial Catalog={AdventureWorks;NewValue=Bad}",
  169. builder.ConnectionString, "#B");
  170. builder = new OdbcConnectionStringBuilder ();
  171. builder ["Integrated SecuritY"] = false;
  172. builder.Driver = "SQL Server";
  173. builder ["Data SourcE"] = "mother";
  174. builder ["Initial Catalog"] = "AdventureWorks;NewValue=OK";
  175. Assert.AreEqual ("Driver={SQL Server};Integrated SecuritY=False;Data SourcE=mother;Initial Catalog={AdventureWorks;NewValue=OK}",
  176. builder.ConnectionString, "#C");
  177. builder = new OdbcConnectionStringBuilder ();
  178. builder ["Initial Catalog"] = "AdventureWorks;NewValue=OK";
  179. builder.Driver = "SQL Server";
  180. builder.Dsn = "NorthWind";
  181. builder ["Data Source"] = "mother";
  182. Assert.AreEqual ("Dsn=NorthWind;Driver={SQL Server};Initial Catalog={AdventureWorks;NewValue=OK};Data Source=mother",
  183. builder.ConnectionString, "#D1");
  184. builder.Driver = string.Empty;
  185. Assert.AreEqual ("Dsn=NorthWind;Driver=;Initial Catalog={AdventureWorks;NewValue=OK};Data Source=mother",
  186. builder.ConnectionString, "#D2");
  187. builder = new OdbcConnectionStringBuilder ();
  188. builder ["Driver"] = "MySQL";
  189. builder.Driver = "SQL Server";
  190. builder.Dsn = "NorthWind";
  191. builder ["Dsn"] = "AdventureWorks";
  192. Assert.AreEqual ("Dsn=AdventureWorks;Driver={SQL Server}", builder.ConnectionString, "#E1");
  193. builder ["Dsn"] = string.Empty;
  194. Assert.AreEqual ("Dsn=;Driver={SQL Server}", builder.ConnectionString, "#E2");
  195. builder = new OdbcConnectionStringBuilder (@"Driver={Microsoft Excel Driver (*.xls)};DBQ=c:\bin\book1.xls");
  196. Assert.AreEqual ("{Microsoft Excel Driver (*.xls)}", builder ["Driver"], "#F1");
  197. Assert.AreEqual (@"c:\bin\book1.xls", builder ["DBQ"], "#F2");
  198. builder = new OdbcConnectionStringBuilder (@"Driver={Microsoft Text Driver (*.txt; *.csv)};DBQ=c:\bin");
  199. Assert.AreEqual ("{Microsoft Text Driver (*.txt; *.csv)}", builder ["Driver"], "#G1");
  200. Assert.AreEqual (@"c:\bin", builder ["DBQ"], "#G2");
  201. }
  202. [Test]
  203. public void ContainsKey ()
  204. {
  205. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  206. builder ["SourceType"] = "DBC";
  207. builder.Add ("Port", "56");
  208. Assert.IsTrue (builder.ContainsKey ("SourceType"), "#1");
  209. Assert.IsTrue (builder.ContainsKey ("Port"), "#2");
  210. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#3");
  211. Assert.IsTrue (builder.ContainsKey ("Driver"), "#4");
  212. Assert.IsFalse (builder.ContainsKey ("xyz"), "#5");
  213. builder.Dsn = "myDsn";
  214. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#6");
  215. builder.Driver = "SQL Server";
  216. Assert.IsTrue (builder.ContainsKey ("Driver"), "#7");
  217. builder ["Dsn"] = "myDsn";
  218. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#8");
  219. builder ["Driver"] = "SQL Server";
  220. Assert.IsTrue (builder.ContainsKey ("Driver"), "#9");
  221. builder ["abc"] = "pqr";
  222. Assert.IsTrue (builder.ContainsKey ("ABC"), "#10");
  223. Assert.IsFalse (builder.ContainsKey (string.Empty), "#11");
  224. }
  225. [Test]
  226. public void ContainsKey_Keyword_Null ()
  227. {
  228. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  229. builder ["SourceType"] = "DBC";
  230. try {
  231. builder.ContainsKey (null);
  232. Assert.Fail ("#1");
  233. } catch (ArgumentNullException ex) {
  234. Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
  235. Assert.IsNull (ex.InnerException, "#3");
  236. Assert.IsNotNull (ex.Message, "#4");
  237. Assert.AreEqual ("keyword", ex.ParamName, "#5");
  238. }
  239. }
  240. [Test]
  241. public void Indexer ()
  242. {
  243. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  244. builder ["abc Def"] = "xa 34";
  245. Assert.AreEqual ("xa 34", builder ["abc def"], "#A1");
  246. Assert.AreEqual ("abc Def=xa 34", builder.ConnectionString, "#A2");
  247. builder ["na;"] = "abc;";
  248. Assert.AreEqual ("abc;", builder ["na;"], "#B1");
  249. Assert.AreEqual ("abc Def=xa 34;na;={abc;}", builder.ConnectionString, "#B2");
  250. builder ["Na;"] = "de\rfg";
  251. Assert.AreEqual ("de\rfg", builder ["na;"], "#C1");
  252. Assert.AreEqual ("abc Def=xa 34;na;=de\rfg", builder.ConnectionString, "#C2");
  253. builder ["val"] = ";xyz";
  254. Assert.AreEqual (";xyz", builder ["val"], "#D1");
  255. Assert.AreEqual ("abc Def=xa 34;na;=de\rfg;val={;xyz}", builder.ConnectionString, "#D2");
  256. builder ["name"] = string.Empty;
  257. Assert.AreEqual (string.Empty, builder ["name"], "#E1");
  258. Assert.AreEqual ("abc Def=xa 34;na;=de\rfg;val={;xyz};name=", builder.ConnectionString, "#E2");
  259. builder ["name"] = " ";
  260. Assert.AreEqual (" ", builder ["name"], "#F1");
  261. Assert.AreEqual ("abc Def=xa 34;na;=de\rfg;val={;xyz};name= ", builder.ConnectionString, "#F2");
  262. }
  263. [Test]
  264. public void Indexer_Keyword_Duplicate ()
  265. {
  266. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  267. builder ["DriverID"] = "120";
  268. builder ["DriverID"] = "790";
  269. Assert.AreEqual ("790", builder ["DriverID"], "#1");
  270. Assert.AreEqual ("DriverID=790", builder.ConnectionString, "#2");
  271. }
  272. [Test]
  273. public void Indexer_Keyword_Invalid ()
  274. {
  275. string [] invalid_keywords = new string [] {
  276. string.Empty,
  277. " ",
  278. " abc",
  279. "abc ",
  280. "\r",
  281. "ab\rc",
  282. ";abc",
  283. "a\0b"
  284. };
  285. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  286. for (int i = 0; i < invalid_keywords.Length; i++) {
  287. string keyword = invalid_keywords [i];
  288. try {
  289. builder [keyword] = "abc";
  290. Assert.Fail ("#A1:" + i);
  291. } catch (ArgumentException ex) {
  292. // Invalid keyword, contain one or more of 'no characters',
  293. // 'control characters', 'leading or trailing whitespace'
  294. // or 'leading semicolons'
  295. Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#A2:"+ i);
  296. Assert.IsNull (ex.InnerException, "#A3:" + i);
  297. Assert.IsNotNull (ex.Message, "#A4:" + i);
  298. Assert.IsTrue (ex.Message.IndexOf ("'" + keyword + "'") == -1, "#A5:" + i);
  299. Assert.AreEqual (keyword, ex.ParamName, "#A6:" + i);
  300. }
  301. builder [keyword] = null;
  302. Assert.IsFalse (builder.ContainsKey (keyword), "#B");
  303. try {
  304. object value = builder [keyword];
  305. Assert.Fail ("#C1:" + value + " (" + i + ")");
  306. } catch (ArgumentException ex) {
  307. // Keyword not supported: '...'
  308. Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2:"+ i);
  309. Assert.IsNull (ex.InnerException, "#C3:" + i);
  310. Assert.IsNotNull (ex.Message, "#C4:" + i);
  311. Assert.IsTrue (ex.Message.IndexOf ("'" + keyword + "'") != -1, "#C5:" + i);
  312. Assert.IsNull (ex.ParamName, "#C6:" + i);
  313. }
  314. }
  315. }
  316. [Test]
  317. public void Indexer_Keyword_NotSupported ()
  318. {
  319. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  320. try {
  321. object value = builder ["abc"];
  322. Assert.Fail ("#1:" + value);
  323. } catch (ArgumentException ex) {
  324. // Keyword not supported: 'abc'
  325. Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
  326. Assert.IsNull (ex.InnerException, "#3");
  327. Assert.IsNotNull (ex.Message, "#4");
  328. Assert.IsTrue (ex.Message.IndexOf ("'abc'") != -1, "#5");
  329. Assert.IsNull (ex.ParamName, "#6");
  330. }
  331. }
  332. [Test]
  333. public void Indexer_Keyword_Null ()
  334. {
  335. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  336. try {
  337. builder [null] = "abc";
  338. Assert.Fail ("#A1");
  339. } catch (ArgumentNullException ex) {
  340. Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
  341. Assert.IsNull (ex.InnerException, "#A3");
  342. Assert.IsNotNull (ex.Message, "#A4");
  343. Assert.AreEqual ("keyword", ex.ParamName, "#A5");
  344. }
  345. try {
  346. object value = builder [null];
  347. Assert.Fail ("#B1:"+ value);
  348. } catch (ArgumentNullException ex) {
  349. Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#B2");
  350. Assert.IsNull (ex.InnerException, "#B3");
  351. Assert.IsNotNull (ex.Message, "#B4");
  352. Assert.AreEqual ("keyword", ex.ParamName, "#B5");
  353. }
  354. }
  355. [Test]
  356. public void Indexer_Value_Null ()
  357. {
  358. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  359. builder ["DriverID"] = null;
  360. Assert.AreEqual (string.Empty, builder.ConnectionString, "#A1");
  361. try {
  362. object value = builder ["DriverID"];
  363. Assert.Fail ("#A2:" + value);
  364. } catch (ArgumentException ex) {
  365. // Keyword not supported: 'DriverID'
  366. Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#A3");
  367. Assert.IsNull (ex.InnerException, "#A4");
  368. Assert.IsNotNull (ex.Message, "#A5");
  369. Assert.IsTrue (ex.Message.IndexOf ("'DriverID'") != -1, "#A6:" + ex.Message);
  370. Assert.IsNull (ex.ParamName, "#A7");
  371. }
  372. Assert.IsFalse (builder.ContainsKey ("DriverID"), "#A8");
  373. Assert.AreEqual (string.Empty, builder.ConnectionString, "#A9");
  374. builder ["DriverID"] = "A";
  375. Assert.AreEqual ("DriverID=A", builder.ConnectionString, "#B1");
  376. builder ["DriverID"] = null;
  377. Assert.IsFalse (builder.ContainsKey ("DriverID"), "#B2");
  378. Assert.AreEqual (string.Empty, builder.ConnectionString, "#B3");
  379. }
  380. [Test]
  381. public void Driver ()
  382. {
  383. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  384. Assert.IsTrue (builder.ContainsKey ("Driver"), "#A1");
  385. Assert.AreEqual (string.Empty, builder ["Driver"], "#A2");
  386. Assert.AreEqual (string.Empty, builder.Driver, "#A3");
  387. builder.Driver = "SQL Server";
  388. Assert.AreEqual ("Driver={SQL Server}", builder.ConnectionString, "#B1");
  389. Assert.IsTrue (builder.ContainsKey ("Driver"), "#B2");
  390. Assert.AreEqual ("SQL Server", builder ["Driver"], "#B3");
  391. Assert.AreEqual ("SQL Server", builder.Driver, "#B4");
  392. builder.Clear ();
  393. builder.Driver = "{SQL Server";
  394. Assert.AreEqual ("Driver={{SQL Server}", builder.ConnectionString, "#C1");
  395. Assert.IsTrue (builder.ContainsKey ("Driver"), "#C2");
  396. Assert.AreEqual ("{SQL Server", builder ["Driver"], "#C3");
  397. Assert.AreEqual ("{SQL Server", builder.Driver, "#C4");
  398. builder.Clear ();
  399. builder.Driver = "{SQL Server}";
  400. Assert.AreEqual ("Driver={SQL Server}", builder.ConnectionString, "#D1");
  401. Assert.IsTrue (builder.ContainsKey ("Driver"), "#D2");
  402. Assert.AreEqual ("{SQL Server}", builder ["Driver"], "#D3");
  403. Assert.AreEqual ("{SQL Server}", builder.Driver, "#D4");
  404. builder.Clear ();
  405. builder.Driver = string.Empty;
  406. Assert.AreEqual ("Driver=", builder.ConnectionString, "#E1");
  407. Assert.IsTrue (builder.ContainsKey ("Driver"), "#E2");
  408. Assert.AreEqual (string.Empty, builder ["Driver"], "#E3");
  409. Assert.AreEqual (string.Empty, builder.Driver, "#E4");
  410. builder.Clear ();
  411. builder ["Driver"] = "SQL Server";
  412. Assert.AreEqual ("Driver={SQL Server}", builder.ConnectionString, "#F1");
  413. Assert.IsTrue (builder.ContainsKey ("Driver"), "#F2");
  414. Assert.AreEqual ("SQL Server", builder ["Driver"], "#F3");
  415. Assert.AreEqual ("SQL Server", builder.Driver, "#F4");
  416. builder.Clear ();
  417. builder ["Driver"] = "{SQL Server";
  418. Assert.AreEqual ("Driver={{SQL Server}", builder.ConnectionString, "#G1");
  419. Assert.IsTrue (builder.ContainsKey ("Driver"), "#G2");
  420. Assert.AreEqual ("{SQL Server", builder ["Driver"], "#G3");
  421. Assert.AreEqual ("{SQL Server", builder.Driver, "#G4");
  422. builder.Clear ();
  423. builder ["Driver"] = "{SQL Server}";
  424. Assert.AreEqual ("Driver={SQL Server}", builder.ConnectionString, "#H1");
  425. Assert.IsTrue (builder.ContainsKey ("Driver"), "#H2");
  426. Assert.AreEqual ("{SQL Server}", builder ["Driver"], "#H3");
  427. Assert.AreEqual ("{SQL Server}", builder.Driver, "#H4");
  428. builder.Clear ();
  429. builder ["Driver"] = string.Empty;
  430. Assert.AreEqual ("Driver=", builder.ConnectionString, "#I1");
  431. Assert.IsTrue (builder.ContainsKey ("Driver"), "#I2");
  432. Assert.AreEqual (string.Empty, builder ["Driver"], "#I3");
  433. Assert.AreEqual (string.Empty, builder.Driver, "#I4");
  434. }
  435. [Test]
  436. public void Driver_Value_Null ()
  437. {
  438. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  439. try {
  440. builder.Driver = null;
  441. Assert.Fail ("#1");
  442. } catch (ArgumentNullException ex) {
  443. Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
  444. Assert.IsNull (ex.InnerException, "#3");
  445. Assert.IsNotNull (ex.Message, "#4");
  446. Assert.AreEqual ("Driver", ex.ParamName, "#5");
  447. }
  448. }
  449. [Test]
  450. public void Indexer_Driver_Empty ()
  451. {
  452. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  453. builder ["Driver"] = string.Empty;
  454. Assert.AreEqual (string.Empty, builder.Driver, "#A1");
  455. Assert.AreEqual (string.Empty, builder ["Driver"], "#A2");
  456. Assert.IsTrue (builder.ContainsKey ("Driver"), "#A3");
  457. Assert.AreEqual ("Driver=", builder.ConnectionString, "#A4");
  458. builder.Driver = "X";
  459. Assert.AreEqual ("X", builder.Driver, "#B1");
  460. Assert.AreEqual ("X", builder ["Driver"], "#B2");
  461. Assert.IsTrue (builder.ContainsKey ("Driver"), "#B3");
  462. Assert.AreEqual ("Driver={X}", builder.ConnectionString, "#B4");
  463. builder ["Driver"] = string.Empty;
  464. Assert.AreEqual (string.Empty, builder.Driver, "#C1");
  465. Assert.AreEqual (string.Empty, builder ["Driver"], "#C2");
  466. Assert.IsTrue (builder.ContainsKey ("Driver"), "#C3");
  467. Assert.AreEqual ("Driver=", builder.ConnectionString, "#C4");
  468. builder.Driver = "A";
  469. Assert.AreEqual ("A", builder.Driver, "#D1");
  470. Assert.AreEqual ("A", builder ["Driver"], "#D2");
  471. Assert.IsTrue (builder.ContainsKey ("Driver"), "#D3");
  472. Assert.AreEqual ("Driver={A}", builder.ConnectionString, "#D4");
  473. builder ["Driver"] = " ";
  474. Assert.AreEqual (" ", builder.Driver, "#E1");
  475. Assert.AreEqual (" ", builder ["Driver"], "#E2");
  476. Assert.IsTrue (builder.ContainsKey ("Driver"), "#E3");
  477. Assert.AreEqual ("Driver={ }", builder.ConnectionString, "#E4");
  478. }
  479. [Test]
  480. public void Indexer_Driver_Null ()
  481. {
  482. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  483. builder ["Driver"] = null;
  484. Assert.AreEqual (string.Empty, builder.Driver, "#A1");
  485. Assert.AreEqual (string.Empty, builder ["Driver"], "#A2");
  486. Assert.IsTrue (builder.ContainsKey ("Driver"), "#A3");
  487. Assert.IsTrue (builder.ContainsKey ("drivEr"), "#A4");
  488. Assert.AreEqual (string.Empty, builder.ConnectionString, "#A5");
  489. builder.Driver = "X";
  490. Assert.AreEqual ("X", builder.Driver, "#B1");
  491. Assert.AreEqual ("X", builder ["Driver"], "#B2");
  492. Assert.AreEqual ("X", builder ["driVer"], "#B3");
  493. Assert.IsTrue (builder.ContainsKey ("Driver"), "#B4");
  494. Assert.IsTrue (builder.ContainsKey ("drivEr"), "#B5");
  495. Assert.AreEqual ("Driver={X}", builder.ConnectionString, "#B6");
  496. builder ["Driver"] = null;
  497. Assert.AreEqual (string.Empty, builder.Driver, "#C1");
  498. Assert.AreEqual (string.Empty, builder ["Driver"], "#C2");
  499. Assert.IsTrue (builder.ContainsKey ("Driver"), "#C3");
  500. Assert.AreEqual (string.Empty, builder.ConnectionString, "#C4");
  501. builder ["Driver"] = "A";
  502. Assert.AreEqual ("A", builder.Driver, "#D1");
  503. Assert.AreEqual ("A", builder ["Driver"], "#D2");
  504. Assert.IsTrue (builder.ContainsKey ("Driver"), "#D3");
  505. Assert.AreEqual ("Driver={A}", builder.ConnectionString, "#D4");
  506. builder ["Driver"] = null;
  507. Assert.AreEqual (string.Empty, builder.Driver, "#E1");
  508. Assert.AreEqual (string.Empty, builder ["Driver"], "#E2");
  509. Assert.IsTrue (builder.ContainsKey ("Driver"), "#E3");
  510. Assert.AreEqual (string.Empty, builder.ConnectionString, "#E4");
  511. }
  512. [Test]
  513. public void Dsn ()
  514. {
  515. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  516. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#A1");
  517. Assert.AreEqual (string.Empty, builder ["Dsn"], "#A2");
  518. Assert.AreEqual (string.Empty, builder.Dsn, "#A3");
  519. builder.Dsn = "myDsn";
  520. Assert.AreEqual ("Dsn=myDsn", builder.ConnectionString, "#B1");
  521. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#B2");
  522. Assert.AreEqual ("myDsn", builder ["Dsn"], "#B3");
  523. Assert.AreEqual ("myDsn", builder.Dsn, "#B4");
  524. builder.Clear ();
  525. builder ["Dsn"] = "myDsn";
  526. Assert.AreEqual ("Dsn=myDsn", builder.ConnectionString, "#C1");
  527. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#C2");
  528. Assert.AreEqual ("myDsn", builder ["Dsn"], "#C3");
  529. Assert.AreEqual ("myDsn", builder.Dsn, "#C4");
  530. }
  531. [Test]
  532. public void Dsn_Value_Null ()
  533. {
  534. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  535. try {
  536. builder.Dsn = null;
  537. Assert.Fail ("#1");
  538. } catch (ArgumentNullException ex) {
  539. Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
  540. Assert.IsNull (ex.InnerException, "#3");
  541. Assert.IsNotNull (ex.Message, "#4");
  542. Assert.AreEqual ("Dsn", ex.ParamName, "#5");
  543. }
  544. }
  545. [Test]
  546. public void Indexer_Dsn_Empty ()
  547. {
  548. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  549. builder ["Dsn"] = string.Empty;
  550. Assert.AreEqual (string.Empty, builder.Dsn, "#A1");
  551. Assert.AreEqual (string.Empty, builder ["Dsn"], "#A2");
  552. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#A3");
  553. builder.Dsn = "X";
  554. Assert.AreEqual ("X", builder.Dsn, "#B1");
  555. Assert.AreEqual ("X", builder ["Dsn"], "#B2");
  556. Assert.AreEqual ("X", builder ["dsN"], "#B3");
  557. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#B4");
  558. Assert.IsTrue (builder.ContainsKey ("dSn"), "#B5");
  559. builder ["Dsn"] = string.Empty;
  560. Assert.AreEqual (string.Empty, builder.Dsn, "#C1");
  561. Assert.AreEqual (string.Empty, builder ["Dsn"], "#C2");
  562. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#C3");
  563. builder.Dsn = "A";
  564. Assert.AreEqual ("A", builder.Dsn, "#D1");
  565. Assert.AreEqual ("A", builder ["Dsn"], "#D2");
  566. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#D3");
  567. builder ["Dsn"] = " ";
  568. Assert.AreEqual (" ", builder.Dsn, "#E1");
  569. Assert.AreEqual (" ", builder ["Dsn"], "#E2");
  570. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#E3");
  571. }
  572. [Test]
  573. public void Indexer_Dsn_Null ()
  574. {
  575. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  576. builder ["Dsn"] = null;
  577. Assert.AreEqual (string.Empty, builder.Dsn, "#A1");
  578. Assert.AreEqual (string.Empty, builder ["Dsn"], "#A2");
  579. Assert.IsTrue (builder.ContainsKey ("Driver"), "#A3");
  580. builder.Dsn = "X";
  581. Assert.AreEqual ("X", builder.Dsn, "#B1");
  582. Assert.AreEqual ("X", builder ["Dsn"], "#B2");
  583. Assert.AreEqual ("X", builder ["dsN"], "#B3");
  584. Assert.IsTrue (builder.ContainsKey ("Driver"), "#B4");
  585. Assert.IsTrue (builder.ContainsKey ("drivEr"), "#B5");
  586. builder ["Dsn"] = null;
  587. Assert.AreEqual (string.Empty, builder.Dsn, "#C1");
  588. Assert.AreEqual (string.Empty, builder ["Dsn"], "#C2");
  589. builder ["Dsn"] = "A";
  590. Assert.AreEqual ("A", builder.Dsn, "#D1");
  591. Assert.AreEqual ("A", builder ["Dsn"], "#D2");
  592. builder ["Dsn"] = null;
  593. Assert.AreEqual (string.Empty, builder.Dsn, "#E1");
  594. Assert.AreEqual (string.Empty, builder ["Dsn"], "#E2");
  595. }
  596. [Test]
  597. public void Keys ()
  598. {
  599. OdbcConnectionStringBuilder builder;
  600. ICollection keys;
  601. object [] keylist;
  602. builder = new OdbcConnectionStringBuilder ();
  603. keys = builder.Keys;
  604. Assert.IsNotNull (keys, "#A1");
  605. Assert.AreEqual (2, keys.Count, "#A2");
  606. keylist = new object [keys.Count];
  607. keys.CopyTo (keylist, 0);
  608. Assert.AreEqual (2, keylist.Length, "#A3");
  609. Assert.AreEqual ("Dsn", keylist [0], "#A4");
  610. Assert.AreEqual ("Driver", keylist [1], "#A5");
  611. builder = new OdbcConnectionStringBuilder ("Database=test;Driver=SQL Server;dsn=AdventureWorks");
  612. keys = builder.Keys;
  613. Assert.IsNotNull (keys, "#B1");
  614. Assert.AreEqual (3, keys.Count, "#B2");
  615. keylist = new object [keys.Count];
  616. keys.CopyTo (keylist, 0);
  617. Assert.AreEqual (3, keylist.Length, "#B3");
  618. Assert.AreEqual ("Dsn", keylist [0], "#B4");
  619. Assert.AreEqual ("Driver", keylist [1], "#B5");
  620. Assert.AreEqual ("database", keylist [2], "#B6");
  621. builder = new OdbcConnectionStringBuilder ("Driver=SQL Server;dsn=AdventureWorks;Database=test;Port=");
  622. keys = builder.Keys;
  623. Assert.IsNotNull (keys, "#C1");
  624. Assert.AreEqual (3, keys.Count, "#C2");
  625. keylist = new object [keys.Count];
  626. keys.CopyTo (keylist, 0);
  627. Assert.AreEqual (3, keylist.Length, "#C3");
  628. Assert.AreEqual ("Dsn", keylist [0], "#C4");
  629. Assert.AreEqual ("Driver", keylist [1], "#C5");
  630. Assert.AreEqual ("database", keylist [2], "#C6");
  631. builder = new OdbcConnectionStringBuilder ();
  632. builder ["DataBase"] = "test";
  633. builder.Driver = "SQL Server";
  634. builder ["User"] = "sa";
  635. builder ["porT"] = "25";
  636. keys = builder.Keys;
  637. Assert.IsNotNull (keys, "#D1");
  638. Assert.AreEqual (5, keys.Count, "#D2");
  639. keylist = new object [keys.Count];
  640. keys.CopyTo (keylist, 0);
  641. Assert.AreEqual (5, keylist.Length, "#D3");
  642. Assert.AreEqual ("Dsn", keylist [0], "#D4");
  643. Assert.AreEqual ("Driver", keylist [1], "#D5");
  644. Assert.AreEqual ("DataBase", keylist [2], "#D6");
  645. Assert.AreEqual ("User", keylist [3], "#D7");
  646. Assert.AreEqual ("porT", keylist [4], "#D8");
  647. builder.Clear ();
  648. keys = builder.Keys;
  649. Assert.IsNotNull (keys, "#E1");
  650. Assert.AreEqual (2, keys.Count, "#E2");
  651. keylist = new object [keys.Count];
  652. keys.CopyTo (keylist, 0);
  653. Assert.AreEqual (2, keylist.Length, "#E3");
  654. Assert.AreEqual ("Dsn", keylist [0], "#E4");
  655. Assert.AreEqual ("Driver", keylist [1], "#E5");
  656. }
  657. [Test]
  658. public void Remove ()
  659. {
  660. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  661. Assert.IsFalse (builder.Remove ("Dsn"), "#A1");
  662. Assert.IsFalse (builder.Remove ("Driver"), "#A2");
  663. builder.Add ("DriverID", "790");
  664. builder ["DefaultDir"] = "C:\\";
  665. Assert.IsTrue (builder.Remove ("DriverID"), "#B1");
  666. Assert.IsFalse (builder.ContainsKey ("DriverID"), "#B2");
  667. Assert.IsFalse (builder.Remove ("DriverID"), "#B3");
  668. Assert.IsFalse (builder.ContainsKey ("DriverID"), "#B4");
  669. Assert.IsTrue (builder.Remove ("defaulTdIr"), "#B5");
  670. Assert.IsFalse (builder.ContainsKey ("DefaultDir"), "#B6");
  671. Assert.IsFalse (builder.Remove ("defaulTdIr"), "#B7");
  672. Assert.IsFalse (builder.Remove ("userid"), "#B8");
  673. Assert.IsFalse (builder.Remove (string.Empty), "#B9");
  674. Assert.IsFalse (builder.Remove ("\r"), "#B10");
  675. Assert.IsFalse (builder.Remove ("a;"), "#B11");
  676. builder.Dsn = "myDsn";
  677. Assert.IsTrue (builder.Remove ("dSn"), "#C1");
  678. Assert.IsTrue (builder.ContainsKey ("dSn"), "#C2");
  679. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#C3");
  680. Assert.AreEqual (string.Empty, builder.Dsn, "#C4");
  681. Assert.IsFalse (builder.Remove ("Dsn"), "#C5");
  682. builder.Driver = "SQL Server";
  683. Assert.IsTrue (builder.Remove ("driVer"), "#D1");
  684. Assert.IsTrue (builder.ContainsKey ("driVer"), "#D2");
  685. Assert.IsTrue (builder.ContainsKey ("Driver"), "#D3");
  686. Assert.AreEqual (string.Empty, builder.Driver, "#D4");
  687. Assert.IsFalse (builder.Remove ("Driver"), "#D5");
  688. builder ["Dsn"] = "myDsn";
  689. Assert.IsTrue (builder.Remove ("Dsn"), "#E1");
  690. Assert.IsTrue (builder.ContainsKey ("Dsn"), "#E2");
  691. Assert.AreEqual (string.Empty, builder.Dsn, "#E3");
  692. Assert.IsFalse (builder.Remove ("Dsn"), "#E4");
  693. builder ["Driver"] = "SQL Server";
  694. Assert.IsTrue (builder.Remove ("Driver"), "#F1");
  695. Assert.IsTrue (builder.ContainsKey ("Driver"), "#F2");
  696. Assert.AreEqual (string.Empty, builder.Driver, "#F3");
  697. Assert.IsFalse (builder.Remove ("Driver"), "#F4");
  698. }
  699. [Test]
  700. public void Remove_Keyword_Null ()
  701. {
  702. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  703. try {
  704. builder.Remove (null);
  705. Assert.Fail ("#1");
  706. } catch (ArgumentNullException ex) {
  707. Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
  708. Assert.IsNull (ex.InnerException, "#3");
  709. Assert.IsNotNull (ex.Message, "#4");
  710. Assert.AreEqual ("keyword", ex.ParamName, "#5");
  711. }
  712. }
  713. [Test]
  714. public void TryGetValue ()
  715. {
  716. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  717. object value = null;
  718. builder ["DriverID"] = "790";
  719. builder.Add ("Server", "C:\\");
  720. Assert.IsTrue (builder.TryGetValue ("DriverID", out value), "#A1");
  721. Assert.AreEqual ("790", value, "#A2");
  722. Assert.IsTrue (builder.TryGetValue ("SERVER", out value), "#B1");
  723. Assert.AreEqual ("C:\\", value, "#B2");
  724. Assert.IsFalse (builder.TryGetValue (string.Empty, out value), "#C1");
  725. Assert.IsNull (value, "#C2");
  726. Assert.IsFalse (builder.TryGetValue ("a;", out value), "#D1");
  727. Assert.IsNull (value, "#D2");
  728. Assert.IsFalse (builder.TryGetValue ("\r", out value), "#E1");
  729. Assert.IsNull (value, "#E2");
  730. Assert.IsFalse (builder.TryGetValue (" ", out value), "#F1");
  731. Assert.IsNull (value, "#F2");
  732. Assert.IsFalse (builder.TryGetValue ("doesnotexist", out value), "#G1");
  733. Assert.IsNull (value, "#G2");
  734. Assert.IsTrue (builder.TryGetValue ("Driver", out value), "#H1");
  735. Assert.AreEqual (string.Empty, value, "#H2");
  736. Assert.IsTrue (builder.TryGetValue ("Dsn", out value), "#I1");
  737. Assert.AreEqual (string.Empty, value, "#I2");
  738. builder ["Driver"] = "SQL Server";
  739. Assert.IsTrue (builder.TryGetValue ("Driver", out value), "#J1");
  740. Assert.AreEqual ("SQL Server", value, "#J2");
  741. builder.Dsn = "AdventureWorks";
  742. Assert.IsTrue (builder.TryGetValue ("Dsn", out value), "#K1");
  743. Assert.AreEqual ("AdventureWorks", value, "#K2");
  744. }
  745. [Test]
  746. public void TryGetValue_Keyword_Null ()
  747. {
  748. OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
  749. object value = null;
  750. try {
  751. builder.TryGetValue (null, out value);
  752. Assert.Fail ("#1");
  753. } catch (ArgumentNullException ex) {
  754. Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
  755. Assert.IsNull (ex.InnerException, "#3");
  756. Assert.IsNotNull (ex.Message, "#4");
  757. Assert.AreEqual ("keyword", ex.ParamName, "#5");
  758. }
  759. }
  760. }
  761. }
  762. #endif // NET_2_0 using