linux-packaging-mono/mcs/class/System.Data/Test/System.Data.Odbc/OdbcConnectionStringBuilderTest.cs
Jo Shields 3c1f479b9d Imported Upstream version 4.0.0~alpha1
Former-commit-id: 806294f5ded97629b74c85c09952f2a74fe182d9
2015-04-07 09:35:12 +01:00

834 lines
32 KiB
C#

// OdbcConnectionStringBuilderTest.cs - NUnit Test Cases for testing the
// OdbcConnectionStringBuilder Class.
//
// Authors:
// Nidhi Rawal (rawalnidhi_rawal@yahoo.com)
// Gert Driesen (drieseng@users.sourceforge.net)
//
// 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.
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");
}
}
}
}