| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835 |
- // OdbcConnectionStringBuilderTest.cs - NUnit Test Cases for testing the
- // OdbcConnectionStringBuilder Class.
- //
- // Authors:
- // Nidhi Rawal ([email protected])
- // Gert Driesen ([email protected])
- //
- // Copyright (c) 2007 Novell Inc., and the individuals listed on the
- // ChangeLog entries.
- //
- //
- // Permission is hereby granted, free of charge, to any person
- // obtaining a copy of this software and associated documentation
- // files (the "Software"), to deal in the Software without
- // restriction, including without limitation the rights to use, copy,
- // modify, merge, publish, distribute, sublicense, and/or sell copies
- // of the Software, and to permit persons to whom the Software is
- // furnished to do so, subject to the following conditions:
- //
- // The above copyright notice and this permission notice shall be
- // included in all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
- // BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
- // ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
- // CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- // SOFTWARE.
- #if NET_2_0
- using System;
- using System.Collections;
- using System.Data;
- using System.Data.Common;
- using System.Data.Odbc;
- using NUnit.Framework;
- namespace MonoTests.System.Data.Odbc
- {
- [TestFixture]
- public class OdbcConnectionStringBuilderTest
- {
- [Test]
- public void ConnectionStringConstructorTest ()
- {
- OdbcConnectionStringBuilder builder;
- builder = new OdbcConnectionStringBuilder ("Driver={SQL Server};Server=(local);Database=AdventureWorks;Uid=ab;Pwd=pass@word1");
- Assert.AreEqual ("AdventureWorks", builder ["Database"],"#A1");
- Assert.AreEqual ("pass@word1", builder ["Pwd"], "#A2");
- Assert.AreEqual ("ab", builder ["Uid"], "#A3");
- Assert.AreEqual ("{SQL Server}", builder ["Driver"], "#A4");
- Assert.AreEqual ("(local)", builder ["Server"],"#A5");
- Assert.AreEqual ("Driver={SQL Server};server=(local);database=AdventureWorks;uid=ab;pwd=pass@word1", builder.ConnectionString,"#A5");
- builder = new OdbcConnectionStringBuilder ("Driver=");
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#B");
- builder = new OdbcConnectionStringBuilder ("Dsn=");
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#C");
- builder = new OdbcConnectionStringBuilder (null);
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#D");
- builder = new OdbcConnectionStringBuilder (string.Empty);
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#E");
- builder = new OdbcConnectionStringBuilder ("Driver=SQL {Server;Dsn=Adventu{re");
- Assert.AreEqual ("SQL {Server", builder ["Driver"], "#F1");
- Assert.AreEqual ("SQL {Server", builder.Driver, "#F2");
- Assert.AreEqual ("Adventu{re", builder ["Dsn"], "#F3");
- Assert.AreEqual ("Adventu{re", builder.Dsn, "#F4");
- Assert.AreEqual ("Dsn=Adventu{re;Driver={SQL {Server}", builder.ConnectionString, "#F5");
- }
- [Test]
- public void Add ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder.Add ("driverid", "420");
- builder.Add ("driverid", "560");
- builder.Add ("DriverID", "840");
- Assert.AreEqual ("840", builder ["driverId"], "#A1");
- Assert.IsTrue (builder.ContainsKey ("driverId"), "#A2");
- builder.Add ("Driver", "OdbcDriver");
- Assert.AreEqual ("OdbcDriver", builder.Driver, "#B1");
- Assert.AreEqual ("OdbcDriver", builder ["Driver"], "#B2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#B3");
- builder.Add ("Driver", "{OdbcDriver");
- Assert.AreEqual ("{OdbcDriver", builder.Driver, "#C1");
- Assert.AreEqual ("{OdbcDriver", builder ["Driver"], "#C2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#C3");
- builder.Add ("Dsn", "MyDsn");
- Assert.AreEqual ("MyDsn", builder.Dsn, "#D1");
- Assert.AreEqual ("MyDsn", builder ["Dsn"], "#D2");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#D3");
- builder.Add ("dsN", "MyDsn2");
- Assert.AreEqual ("MyDsn2", builder.Dsn, "#E1");
- Assert.AreEqual ("MyDsn2", builder ["Dsn"], "#E2");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#E3");
- }
- [Test]
- public void Add_Keyword_Invalid ()
- {
- string [] invalid_keywords = new string [] {
- string.Empty,
- " ",
- " abc",
- "abc ",
- "\r",
- "ab\rc",
- ";abc",
- "a\0b"
- };
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- for (int i = 0; i < invalid_keywords.Length; i++) {
- string keyword = invalid_keywords [i];
- try {
- builder.Add (keyword, "abc");
- Assert.Fail ("#1:" + i);
- } catch (ArgumentException ex) {
- // Invalid keyword, contain one or more of 'no characters',
- // 'control characters', 'leading or trailing whitespace'
- // or 'leading semicolons'
- Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2:"+ i);
- Assert.IsNull (ex.InnerException, "#3:" + i);
- Assert.IsNotNull (ex.Message, "#4:" + i);
- Assert.IsTrue (ex.Message.IndexOf ("'" + keyword + "'") == -1, "#5:" + i);
- Assert.AreEqual (keyword, ex.ParamName, "#6:" + i);
- }
- }
- }
- [Test]
- public void Add_Keyword_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- try {
- builder.Add (null, "abc");
- Assert.Fail ("#1");
- } catch (ArgumentNullException ex) {
- Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
- Assert.IsNull (ex.InnerException, "#3");
- Assert.IsNotNull (ex.Message, "#4");
- Assert.AreEqual ("keyword", ex.ParamName, "#5");
- }
- }
- [Test]
- public void Clear ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["Dbq"] = "C:\\Data.xls";
- builder.Driver = "SQL Server";
- builder.Dsn = "AdventureWorks";
- builder.Add ("Port", "56");
- builder.Clear ();
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#1");
- Assert.IsFalse (builder.ContainsKey ("Dbq"), "#2");
- Assert.AreEqual (string.Empty, builder.Driver, "#3");
- Assert.AreEqual (string.Empty, builder.Dsn, "#4");
- Assert.IsFalse (builder.ContainsKey ("Port"), "#5");
- }
- [Test]
- public void ConnectionString ()
- {
- OdbcConnectionStringBuilder builder;
- builder = new OdbcConnectionStringBuilder (@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\Northwind.mdb;Jet OLEDB:System Database=|DataDirectory|\System.mdw;");
- Assert.AreEqual ("Microsoft.Jet.OLEDB.4.0", builder ["Provider"], "#A1");
- Assert.AreEqual (@"|DataDirectory|\Northwind.mdb", builder ["Data Source"], "#A2");
- Assert.AreEqual (@"|DataDirectory|\System.mdw", builder ["Jet OLEDB:System Database"], "#A3");
- builder = new OdbcConnectionStringBuilder ();
- builder ["Data SourcE"] = "(local)";
- builder ["Integrated SecuritY"] = true;
- builder.Driver = "SQL Server";
- builder ["Initial Catalog"] = "AdventureWorks;NewValue=Bad";
- Assert.AreEqual ("Driver={SQL Server};Data SourcE=(local);Integrated SecuritY=True;Initial Catalog={AdventureWorks;NewValue=Bad}",
- builder.ConnectionString, "#B");
- builder = new OdbcConnectionStringBuilder ();
- builder ["Integrated SecuritY"] = false;
- builder.Driver = "SQL Server";
- builder ["Data SourcE"] = "mother";
- builder ["Initial Catalog"] = "AdventureWorks;NewValue=OK";
- Assert.AreEqual ("Driver={SQL Server};Integrated SecuritY=False;Data SourcE=mother;Initial Catalog={AdventureWorks;NewValue=OK}",
- builder.ConnectionString, "#C");
- builder = new OdbcConnectionStringBuilder ();
- builder ["Initial Catalog"] = "AdventureWorks;NewValue=OK";
- builder.Driver = "SQL Server";
- builder.Dsn = "NorthWind";
- builder ["Data Source"] = "mother";
- Assert.AreEqual ("Dsn=NorthWind;Driver={SQL Server};Initial Catalog={AdventureWorks;NewValue=OK};Data Source=mother",
- builder.ConnectionString, "#D1");
- builder.Driver = string.Empty;
- Assert.AreEqual ("Dsn=NorthWind;Driver=;Initial Catalog={AdventureWorks;NewValue=OK};Data Source=mother",
- builder.ConnectionString, "#D2");
- builder = new OdbcConnectionStringBuilder ();
- builder ["Driver"] = "MySQL";
- builder.Driver = "SQL Server";
- builder.Dsn = "NorthWind";
- builder ["Dsn"] = "AdventureWorks";
- Assert.AreEqual ("Dsn=AdventureWorks;Driver={SQL Server}", builder.ConnectionString, "#E1");
- builder ["Dsn"] = string.Empty;
- Assert.AreEqual ("Dsn=;Driver={SQL Server}", builder.ConnectionString, "#E2");
- builder = new OdbcConnectionStringBuilder (@"Driver={Microsoft Excel Driver (*.xls)};DBQ=c:\bin\book1.xls");
- Assert.AreEqual ("{Microsoft Excel Driver (*.xls)}", builder ["Driver"], "#F1");
- Assert.AreEqual (@"c:\bin\book1.xls", builder ["DBQ"], "#F2");
-
- builder = new OdbcConnectionStringBuilder (@"Driver={Microsoft Text Driver (*.txt; *.csv)};DBQ=c:\bin");
- Assert.AreEqual ("{Microsoft Text Driver (*.txt; *.csv)}", builder ["Driver"], "#G1");
- Assert.AreEqual (@"c:\bin", builder ["DBQ"], "#G2");
- }
- [Test]
- public void ContainsKey ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["SourceType"] = "DBC";
- builder.Add ("Port", "56");
- Assert.IsTrue (builder.ContainsKey ("SourceType"), "#1");
- Assert.IsTrue (builder.ContainsKey ("Port"), "#2");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#3");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#4");
- Assert.IsFalse (builder.ContainsKey ("xyz"), "#5");
- builder.Dsn = "myDsn";
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#6");
- builder.Driver = "SQL Server";
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#7");
- builder ["Dsn"] = "myDsn";
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#8");
- builder ["Driver"] = "SQL Server";
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#9");
- builder ["abc"] = "pqr";
- Assert.IsTrue (builder.ContainsKey ("ABC"), "#10");
- Assert.IsFalse (builder.ContainsKey (string.Empty), "#11");
- }
- [Test]
- public void ContainsKey_Keyword_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["SourceType"] = "DBC";
- try {
- builder.ContainsKey (null);
- Assert.Fail ("#1");
- } catch (ArgumentNullException ex) {
- Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
- Assert.IsNull (ex.InnerException, "#3");
- Assert.IsNotNull (ex.Message, "#4");
- Assert.AreEqual ("keyword", ex.ParamName, "#5");
- }
- }
- [Test]
- public void Indexer ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["abc Def"] = "xa 34";
- Assert.AreEqual ("xa 34", builder ["abc def"], "#A1");
- Assert.AreEqual ("abc Def=xa 34", builder.ConnectionString, "#A2");
- builder ["na;"] = "abc;";
- Assert.AreEqual ("abc;", builder ["na;"], "#B1");
- Assert.AreEqual ("abc Def=xa 34;na;={abc;}", builder.ConnectionString, "#B2");
- builder ["Na;"] = "de\rfg";
- Assert.AreEqual ("de\rfg", builder ["na;"], "#C1");
- Assert.AreEqual ("abc Def=xa 34;na;=de\rfg", builder.ConnectionString, "#C2");
- builder ["val"] = ";xyz";
- Assert.AreEqual (";xyz", builder ["val"], "#D1");
- Assert.AreEqual ("abc Def=xa 34;na;=de\rfg;val={;xyz}", builder.ConnectionString, "#D2");
- builder ["name"] = string.Empty;
- Assert.AreEqual (string.Empty, builder ["name"], "#E1");
- Assert.AreEqual ("abc Def=xa 34;na;=de\rfg;val={;xyz};name=", builder.ConnectionString, "#E2");
- builder ["name"] = " ";
- Assert.AreEqual (" ", builder ["name"], "#F1");
- Assert.AreEqual ("abc Def=xa 34;na;=de\rfg;val={;xyz};name= ", builder.ConnectionString, "#F2");
- }
- [Test]
- public void Indexer_Keyword_Duplicate ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["DriverID"] = "120";
- builder ["DriverID"] = "790";
- Assert.AreEqual ("790", builder ["DriverID"], "#1");
- Assert.AreEqual ("DriverID=790", builder.ConnectionString, "#2");
- }
- [Test]
- public void Indexer_Keyword_Invalid ()
- {
- string [] invalid_keywords = new string [] {
- string.Empty,
- " ",
- " abc",
- "abc ",
- "\r",
- "ab\rc",
- ";abc",
- "a\0b"
- };
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- for (int i = 0; i < invalid_keywords.Length; i++) {
- string keyword = invalid_keywords [i];
- try {
- builder [keyword] = "abc";
- Assert.Fail ("#A1:" + i);
- } catch (ArgumentException ex) {
- // Invalid keyword, contain one or more of 'no characters',
- // 'control characters', 'leading or trailing whitespace'
- // or 'leading semicolons'
- Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#A2:"+ i);
- Assert.IsNull (ex.InnerException, "#A3:" + i);
- Assert.IsNotNull (ex.Message, "#A4:" + i);
- Assert.IsTrue (ex.Message.IndexOf ("'" + keyword + "'") == -1, "#A5:" + i);
- Assert.AreEqual (keyword, ex.ParamName, "#A6:" + i);
- }
- builder [keyword] = null;
- Assert.IsFalse (builder.ContainsKey (keyword), "#B");
- try {
- object value = builder [keyword];
- Assert.Fail ("#C1:" + value + " (" + i + ")");
- } catch (ArgumentException ex) {
- // Keyword not supported: '...'
- Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#C2:"+ i);
- Assert.IsNull (ex.InnerException, "#C3:" + i);
- Assert.IsNotNull (ex.Message, "#C4:" + i);
- Assert.IsTrue (ex.Message.IndexOf ("'" + keyword + "'") != -1, "#C5:" + i);
- Assert.IsNull (ex.ParamName, "#C6:" + i);
- }
- }
- }
- [Test]
- public void Indexer_Keyword_NotSupported ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- try {
- object value = builder ["abc"];
- Assert.Fail ("#1:" + value);
- } catch (ArgumentException ex) {
- // Keyword not supported: 'abc'
- Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#2");
- Assert.IsNull (ex.InnerException, "#3");
- Assert.IsNotNull (ex.Message, "#4");
- Assert.IsTrue (ex.Message.IndexOf ("'abc'") != -1, "#5");
- Assert.IsNull (ex.ParamName, "#6");
- }
- }
- [Test]
- public void Indexer_Keyword_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- try {
- builder [null] = "abc";
- Assert.Fail ("#A1");
- } catch (ArgumentNullException ex) {
- Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#A2");
- Assert.IsNull (ex.InnerException, "#A3");
- Assert.IsNotNull (ex.Message, "#A4");
- Assert.AreEqual ("keyword", ex.ParamName, "#A5");
- }
- try {
- object value = builder [null];
- Assert.Fail ("#B1:"+ value);
- } catch (ArgumentNullException ex) {
- Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#B2");
- Assert.IsNull (ex.InnerException, "#B3");
- Assert.IsNotNull (ex.Message, "#B4");
- Assert.AreEqual ("keyword", ex.ParamName, "#B5");
- }
- }
- [Test]
- public void Indexer_Value_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["DriverID"] = null;
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#A1");
- try {
- object value = builder ["DriverID"];
- Assert.Fail ("#A2:" + value);
- } catch (ArgumentException ex) {
- // Keyword not supported: 'DriverID'
- Assert.AreEqual (typeof (ArgumentException), ex.GetType (), "#A3");
- Assert.IsNull (ex.InnerException, "#A4");
- Assert.IsNotNull (ex.Message, "#A5");
- Assert.IsTrue (ex.Message.IndexOf ("'DriverID'") != -1, "#A6:" + ex.Message);
- Assert.IsNull (ex.ParamName, "#A7");
- }
- Assert.IsFalse (builder.ContainsKey ("DriverID"), "#A8");
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#A9");
- builder ["DriverID"] = "A";
- Assert.AreEqual ("DriverID=A", builder.ConnectionString, "#B1");
- builder ["DriverID"] = null;
- Assert.IsFalse (builder.ContainsKey ("DriverID"), "#B2");
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#B3");
- }
- [Test]
- public void Driver ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#A1");
- Assert.AreEqual (string.Empty, builder ["Driver"], "#A2");
- Assert.AreEqual (string.Empty, builder.Driver, "#A3");
- builder.Driver = "SQL Server";
- Assert.AreEqual ("Driver={SQL Server}", builder.ConnectionString, "#B1");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#B2");
- Assert.AreEqual ("SQL Server", builder ["Driver"], "#B3");
- Assert.AreEqual ("SQL Server", builder.Driver, "#B4");
- builder.Clear ();
- builder.Driver = "{SQL Server";
- Assert.AreEqual ("Driver={{SQL Server}", builder.ConnectionString, "#C1");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#C2");
- Assert.AreEqual ("{SQL Server", builder ["Driver"], "#C3");
- Assert.AreEqual ("{SQL Server", builder.Driver, "#C4");
- builder.Clear ();
- builder.Driver = "{SQL Server}";
- Assert.AreEqual ("Driver={SQL Server}", builder.ConnectionString, "#D1");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#D2");
- Assert.AreEqual ("{SQL Server}", builder ["Driver"], "#D3");
- Assert.AreEqual ("{SQL Server}", builder.Driver, "#D4");
- builder.Clear ();
- builder.Driver = string.Empty;
- Assert.AreEqual ("Driver=", builder.ConnectionString, "#E1");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#E2");
- Assert.AreEqual (string.Empty, builder ["Driver"], "#E3");
- Assert.AreEqual (string.Empty, builder.Driver, "#E4");
- builder.Clear ();
- builder ["Driver"] = "SQL Server";
- Assert.AreEqual ("Driver={SQL Server}", builder.ConnectionString, "#F1");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#F2");
- Assert.AreEqual ("SQL Server", builder ["Driver"], "#F3");
- Assert.AreEqual ("SQL Server", builder.Driver, "#F4");
- builder.Clear ();
- builder ["Driver"] = "{SQL Server";
- Assert.AreEqual ("Driver={{SQL Server}", builder.ConnectionString, "#G1");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#G2");
- Assert.AreEqual ("{SQL Server", builder ["Driver"], "#G3");
- Assert.AreEqual ("{SQL Server", builder.Driver, "#G4");
- builder.Clear ();
- builder ["Driver"] = "{SQL Server}";
- Assert.AreEqual ("Driver={SQL Server}", builder.ConnectionString, "#H1");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#H2");
- Assert.AreEqual ("{SQL Server}", builder ["Driver"], "#H3");
- Assert.AreEqual ("{SQL Server}", builder.Driver, "#H4");
- builder.Clear ();
- builder ["Driver"] = string.Empty;
- Assert.AreEqual ("Driver=", builder.ConnectionString, "#I1");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#I2");
- Assert.AreEqual (string.Empty, builder ["Driver"], "#I3");
- Assert.AreEqual (string.Empty, builder.Driver, "#I4");
- }
- [Test]
- public void Driver_Value_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- try {
- builder.Driver = null;
- Assert.Fail ("#1");
- } catch (ArgumentNullException ex) {
- Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
- Assert.IsNull (ex.InnerException, "#3");
- Assert.IsNotNull (ex.Message, "#4");
- Assert.AreEqual ("Driver", ex.ParamName, "#5");
- }
- }
- [Test]
- public void Indexer_Driver_Empty ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["Driver"] = string.Empty;
- Assert.AreEqual (string.Empty, builder.Driver, "#A1");
- Assert.AreEqual (string.Empty, builder ["Driver"], "#A2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#A3");
- Assert.AreEqual ("Driver=", builder.ConnectionString, "#A4");
- builder.Driver = "X";
- Assert.AreEqual ("X", builder.Driver, "#B1");
- Assert.AreEqual ("X", builder ["Driver"], "#B2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#B3");
- Assert.AreEqual ("Driver={X}", builder.ConnectionString, "#B4");
- builder ["Driver"] = string.Empty;
- Assert.AreEqual (string.Empty, builder.Driver, "#C1");
- Assert.AreEqual (string.Empty, builder ["Driver"], "#C2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#C3");
- Assert.AreEqual ("Driver=", builder.ConnectionString, "#C4");
- builder.Driver = "A";
- Assert.AreEqual ("A", builder.Driver, "#D1");
- Assert.AreEqual ("A", builder ["Driver"], "#D2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#D3");
- Assert.AreEqual ("Driver={A}", builder.ConnectionString, "#D4");
- builder ["Driver"] = " ";
- Assert.AreEqual (" ", builder.Driver, "#E1");
- Assert.AreEqual (" ", builder ["Driver"], "#E2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#E3");
- Assert.AreEqual ("Driver={ }", builder.ConnectionString, "#E4");
- }
- [Test]
- public void Indexer_Driver_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["Driver"] = null;
- Assert.AreEqual (string.Empty, builder.Driver, "#A1");
- Assert.AreEqual (string.Empty, builder ["Driver"], "#A2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#A3");
- Assert.IsTrue (builder.ContainsKey ("drivEr"), "#A4");
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#A5");
- builder.Driver = "X";
- Assert.AreEqual ("X", builder.Driver, "#B1");
- Assert.AreEqual ("X", builder ["Driver"], "#B2");
- Assert.AreEqual ("X", builder ["driVer"], "#B3");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#B4");
- Assert.IsTrue (builder.ContainsKey ("drivEr"), "#B5");
- Assert.AreEqual ("Driver={X}", builder.ConnectionString, "#B6");
- builder ["Driver"] = null;
- Assert.AreEqual (string.Empty, builder.Driver, "#C1");
- Assert.AreEqual (string.Empty, builder ["Driver"], "#C2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#C3");
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#C4");
- builder ["Driver"] = "A";
- Assert.AreEqual ("A", builder.Driver, "#D1");
- Assert.AreEqual ("A", builder ["Driver"], "#D2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#D3");
- Assert.AreEqual ("Driver={A}", builder.ConnectionString, "#D4");
- builder ["Driver"] = null;
- Assert.AreEqual (string.Empty, builder.Driver, "#E1");
- Assert.AreEqual (string.Empty, builder ["Driver"], "#E2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#E3");
- Assert.AreEqual (string.Empty, builder.ConnectionString, "#E4");
- }
- [Test]
- public void Dsn ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#A1");
- Assert.AreEqual (string.Empty, builder ["Dsn"], "#A2");
- Assert.AreEqual (string.Empty, builder.Dsn, "#A3");
- builder.Dsn = "myDsn";
- Assert.AreEqual ("Dsn=myDsn", builder.ConnectionString, "#B1");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#B2");
- Assert.AreEqual ("myDsn", builder ["Dsn"], "#B3");
- Assert.AreEqual ("myDsn", builder.Dsn, "#B4");
- builder.Clear ();
- builder ["Dsn"] = "myDsn";
- Assert.AreEqual ("Dsn=myDsn", builder.ConnectionString, "#C1");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#C2");
- Assert.AreEqual ("myDsn", builder ["Dsn"], "#C3");
- Assert.AreEqual ("myDsn", builder.Dsn, "#C4");
- }
-
- [Test]
- public void Dsn_Value_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- try {
- builder.Dsn = null;
- Assert.Fail ("#1");
- } catch (ArgumentNullException ex) {
- Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
- Assert.IsNull (ex.InnerException, "#3");
- Assert.IsNotNull (ex.Message, "#4");
- Assert.AreEqual ("Dsn", ex.ParamName, "#5");
- }
- }
- [Test]
- public void Indexer_Dsn_Empty ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["Dsn"] = string.Empty;
- Assert.AreEqual (string.Empty, builder.Dsn, "#A1");
- Assert.AreEqual (string.Empty, builder ["Dsn"], "#A2");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#A3");
- builder.Dsn = "X";
- Assert.AreEqual ("X", builder.Dsn, "#B1");
- Assert.AreEqual ("X", builder ["Dsn"], "#B2");
- Assert.AreEqual ("X", builder ["dsN"], "#B3");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#B4");
- Assert.IsTrue (builder.ContainsKey ("dSn"), "#B5");
- builder ["Dsn"] = string.Empty;
- Assert.AreEqual (string.Empty, builder.Dsn, "#C1");
- Assert.AreEqual (string.Empty, builder ["Dsn"], "#C2");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#C3");
- builder.Dsn = "A";
- Assert.AreEqual ("A", builder.Dsn, "#D1");
- Assert.AreEqual ("A", builder ["Dsn"], "#D2");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#D3");
- builder ["Dsn"] = " ";
- Assert.AreEqual (" ", builder.Dsn, "#E1");
- Assert.AreEqual (" ", builder ["Dsn"], "#E2");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#E3");
- }
- [Test]
- public void Indexer_Dsn_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- builder ["Dsn"] = null;
- Assert.AreEqual (string.Empty, builder.Dsn, "#A1");
- Assert.AreEqual (string.Empty, builder ["Dsn"], "#A2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#A3");
- builder.Dsn = "X";
- Assert.AreEqual ("X", builder.Dsn, "#B1");
- Assert.AreEqual ("X", builder ["Dsn"], "#B2");
- Assert.AreEqual ("X", builder ["dsN"], "#B3");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#B4");
- Assert.IsTrue (builder.ContainsKey ("drivEr"), "#B5");
- builder ["Dsn"] = null;
- Assert.AreEqual (string.Empty, builder.Dsn, "#C1");
- Assert.AreEqual (string.Empty, builder ["Dsn"], "#C2");
- builder ["Dsn"] = "A";
- Assert.AreEqual ("A", builder.Dsn, "#D1");
- Assert.AreEqual ("A", builder ["Dsn"], "#D2");
- builder ["Dsn"] = null;
- Assert.AreEqual (string.Empty, builder.Dsn, "#E1");
- Assert.AreEqual (string.Empty, builder ["Dsn"], "#E2");
- }
- [Test]
- public void Keys ()
- {
- OdbcConnectionStringBuilder builder;
- ICollection keys;
- object [] keylist;
- builder = new OdbcConnectionStringBuilder ();
- keys = builder.Keys;
- Assert.IsNotNull (keys, "#A1");
- Assert.AreEqual (2, keys.Count, "#A2");
- keylist = new object [keys.Count];
- keys.CopyTo (keylist, 0);
- Assert.AreEqual (2, keylist.Length, "#A3");
- Assert.AreEqual ("Dsn", keylist [0], "#A4");
- Assert.AreEqual ("Driver", keylist [1], "#A5");
- builder = new OdbcConnectionStringBuilder ("Database=test;Driver=SQL Server;dsn=AdventureWorks");
- keys = builder.Keys;
- Assert.IsNotNull (keys, "#B1");
- Assert.AreEqual (3, keys.Count, "#B2");
- keylist = new object [keys.Count];
- keys.CopyTo (keylist, 0);
- Assert.AreEqual (3, keylist.Length, "#B3");
- Assert.AreEqual ("Dsn", keylist [0], "#B4");
- Assert.AreEqual ("Driver", keylist [1], "#B5");
- Assert.AreEqual ("database", keylist [2], "#B6");
- builder = new OdbcConnectionStringBuilder ("Driver=SQL Server;dsn=AdventureWorks;Database=test;Port=");
- keys = builder.Keys;
- Assert.IsNotNull (keys, "#C1");
- Assert.AreEqual (3, keys.Count, "#C2");
- keylist = new object [keys.Count];
- keys.CopyTo (keylist, 0);
- Assert.AreEqual (3, keylist.Length, "#C3");
- Assert.AreEqual ("Dsn", keylist [0], "#C4");
- Assert.AreEqual ("Driver", keylist [1], "#C5");
- Assert.AreEqual ("database", keylist [2], "#C6");
- builder = new OdbcConnectionStringBuilder ();
- builder ["DataBase"] = "test";
- builder.Driver = "SQL Server";
- builder ["User"] = "sa";
- builder ["porT"] = "25";
- keys = builder.Keys;
- Assert.IsNotNull (keys, "#D1");
- Assert.AreEqual (5, keys.Count, "#D2");
- keylist = new object [keys.Count];
- keys.CopyTo (keylist, 0);
- Assert.AreEqual (5, keylist.Length, "#D3");
- Assert.AreEqual ("Dsn", keylist [0], "#D4");
- Assert.AreEqual ("Driver", keylist [1], "#D5");
- Assert.AreEqual ("DataBase", keylist [2], "#D6");
- Assert.AreEqual ("User", keylist [3], "#D7");
- Assert.AreEqual ("porT", keylist [4], "#D8");
- builder.Clear ();
- keys = builder.Keys;
- Assert.IsNotNull (keys, "#E1");
- Assert.AreEqual (2, keys.Count, "#E2");
- keylist = new object [keys.Count];
- keys.CopyTo (keylist, 0);
- Assert.AreEqual (2, keylist.Length, "#E3");
- Assert.AreEqual ("Dsn", keylist [0], "#E4");
- Assert.AreEqual ("Driver", keylist [1], "#E5");
- }
- [Test]
- public void Remove ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- Assert.IsFalse (builder.Remove ("Dsn"), "#A1");
- Assert.IsFalse (builder.Remove ("Driver"), "#A2");
- builder.Add ("DriverID", "790");
- builder ["DefaultDir"] = "C:\\";
- Assert.IsTrue (builder.Remove ("DriverID"), "#B1");
- Assert.IsFalse (builder.ContainsKey ("DriverID"), "#B2");
- Assert.IsFalse (builder.Remove ("DriverID"), "#B3");
- Assert.IsFalse (builder.ContainsKey ("DriverID"), "#B4");
- Assert.IsTrue (builder.Remove ("defaulTdIr"), "#B5");
- Assert.IsFalse (builder.ContainsKey ("DefaultDir"), "#B6");
- Assert.IsFalse (builder.Remove ("defaulTdIr"), "#B7");
- Assert.IsFalse (builder.Remove ("userid"), "#B8");
- Assert.IsFalse (builder.Remove (string.Empty), "#B9");
- Assert.IsFalse (builder.Remove ("\r"), "#B10");
- Assert.IsFalse (builder.Remove ("a;"), "#B11");
- builder.Dsn = "myDsn";
- Assert.IsTrue (builder.Remove ("dSn"), "#C1");
- Assert.IsTrue (builder.ContainsKey ("dSn"), "#C2");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#C3");
- Assert.AreEqual (string.Empty, builder.Dsn, "#C4");
- Assert.IsFalse (builder.Remove ("Dsn"), "#C5");
- builder.Driver = "SQL Server";
- Assert.IsTrue (builder.Remove ("driVer"), "#D1");
- Assert.IsTrue (builder.ContainsKey ("driVer"), "#D2");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#D3");
- Assert.AreEqual (string.Empty, builder.Driver, "#D4");
- Assert.IsFalse (builder.Remove ("Driver"), "#D5");
- builder ["Dsn"] = "myDsn";
- Assert.IsTrue (builder.Remove ("Dsn"), "#E1");
- Assert.IsTrue (builder.ContainsKey ("Dsn"), "#E2");
- Assert.AreEqual (string.Empty, builder.Dsn, "#E3");
- Assert.IsFalse (builder.Remove ("Dsn"), "#E4");
- builder ["Driver"] = "SQL Server";
- Assert.IsTrue (builder.Remove ("Driver"), "#F1");
- Assert.IsTrue (builder.ContainsKey ("Driver"), "#F2");
- Assert.AreEqual (string.Empty, builder.Driver, "#F3");
- Assert.IsFalse (builder.Remove ("Driver"), "#F4");
- }
- [Test]
- public void Remove_Keyword_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- try {
- builder.Remove (null);
- Assert.Fail ("#1");
- } catch (ArgumentNullException ex) {
- Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
- Assert.IsNull (ex.InnerException, "#3");
- Assert.IsNotNull (ex.Message, "#4");
- Assert.AreEqual ("keyword", ex.ParamName, "#5");
- }
- }
- [Test]
- public void TryGetValue ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- object value = null;
- builder ["DriverID"] = "790";
- builder.Add ("Server", "C:\\");
- Assert.IsTrue (builder.TryGetValue ("DriverID", out value), "#A1");
- Assert.AreEqual ("790", value, "#A2");
- Assert.IsTrue (builder.TryGetValue ("SERVER", out value), "#B1");
- Assert.AreEqual ("C:\\", value, "#B2");
- Assert.IsFalse (builder.TryGetValue (string.Empty, out value), "#C1");
- Assert.IsNull (value, "#C2");
- Assert.IsFalse (builder.TryGetValue ("a;", out value), "#D1");
- Assert.IsNull (value, "#D2");
- Assert.IsFalse (builder.TryGetValue ("\r", out value), "#E1");
- Assert.IsNull (value, "#E2");
- Assert.IsFalse (builder.TryGetValue (" ", out value), "#F1");
- Assert.IsNull (value, "#F2");
- Assert.IsFalse (builder.TryGetValue ("doesnotexist", out value), "#G1");
- Assert.IsNull (value, "#G2");
- Assert.IsTrue (builder.TryGetValue ("Driver", out value), "#H1");
- Assert.AreEqual (string.Empty, value, "#H2");
- Assert.IsTrue (builder.TryGetValue ("Dsn", out value), "#I1");
- Assert.AreEqual (string.Empty, value, "#I2");
- builder ["Driver"] = "SQL Server";
- Assert.IsTrue (builder.TryGetValue ("Driver", out value), "#J1");
- Assert.AreEqual ("SQL Server", value, "#J2");
- builder.Dsn = "AdventureWorks";
- Assert.IsTrue (builder.TryGetValue ("Dsn", out value), "#K1");
- Assert.AreEqual ("AdventureWorks", value, "#K2");
- }
- [Test]
- public void TryGetValue_Keyword_Null ()
- {
- OdbcConnectionStringBuilder builder = new OdbcConnectionStringBuilder ();
- object value = null;
- try {
- builder.TryGetValue (null, out value);
- Assert.Fail ("#1");
- } catch (ArgumentNullException ex) {
- Assert.AreEqual (typeof (ArgumentNullException), ex.GetType (), "#2");
- Assert.IsNull (ex.InnerException, "#3");
- Assert.IsNotNull (ex.Message, "#4");
- Assert.AreEqual ("keyword", ex.ParamName, "#5");
- }
- }
- }
- }
- #endif // NET_2_0 using
|