New test.
[mono.git] / mcs / class / System.Data / Test / ProviderTests / System.Data.SqlClient / SqlParameterTest.cs
1 //
2 // SqlParameterTest.cs - NUnit Test Cases for testing the
3 //                          SqlParameter class
4 // Author:
5 //      Senganal T (tsenganal@novell.com)
6 //
7 // Copyright (c) 2004 Novell Inc., and the individuals listed
8 // on the ChangeLog entries.
9 //
10 // Permission is hereby granted, free of charge, to any person obtaining
11 // a copy of this software and associated documentation files (the
12 // "Software"), to deal in the Software without restriction, including
13 // without limitation the rights to use, copy, modify, merge, publish,
14 // distribute, sublicense, and/or sell copies of the Software, and to
15 // permit persons to whom the Software is furnished to do so, subject to
16 // the following conditions:
17 //
18 // The above copyright notice and this permission notice shall be
19 // included in all copies or substantial portions of the Software.
20 //
21 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
22 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
23 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
24 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
25 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
26 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
27 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
28 //
29
30 using System;
31 using System.Data;
32 using System.Data.Common;
33 using System.Data.SqlClient;
34
35 using NUnit.Framework;
36
37 namespace MonoTests.System.Data.SqlClient
38 {
39         [TestFixture]
40         [Category ("sqlserver")]
41         //FIXME : Add more testcases
42         public class SqlParameterTest
43         {
44                 //testcase for #77410
45                 [Test]
46                 public void ParameterNullTest ()
47                 {
48                         SqlParameter param = new SqlParameter ("param", SqlDbType.Decimal);
49                         Assert.AreEqual (0, param.Scale, "#1");
50                         param.Value = DBNull.Value;
51                         Assert.AreEqual (0, param.Scale, "#2");
52
53                         param = new SqlParameter ("param", SqlDbType.Int);
54                         Assert.AreEqual (0, param.Scale, "#3");
55                         param.Value = DBNull.Value;
56                         Assert.AreEqual (0, param.Scale, "#4");
57                 }
58
59                 [Test]
60                 public void ParameterType ()
61                 {
62                         // If Type is not set, then type is inferred from the value
63                         // assigned. The Type should inferred everytime Value is assigned
64                         // If value is null/DBNull, then the current Type should retained.
65                         SqlParameter param = new SqlParameter ();
66                         Assert.AreEqual (SqlDbType.NVarChar, param.SqlDbType, "#1");
67                         param.Value = DBNull.Value;
68                         Assert.AreEqual (SqlDbType.NVarChar, param.SqlDbType, "#2");
69                         param.Value = 1;
70                         Assert.AreEqual (SqlDbType.Int, param.SqlDbType, "#3");
71                         param.Value = DBNull.Value;
72                         Assert.AreEqual (SqlDbType.Int, param.SqlDbType, "#4");
73                         param.Value = null;
74                         Assert.AreEqual (SqlDbType.Int, param.SqlDbType, "#4");
75
76                         //If Type is set, then the Type should not inferred from the value 
77                         //assigned.
78                         SqlParameter param1 = new SqlParameter ();
79                         param1.DbType = DbType.String; 
80                         Assert.AreEqual (SqlDbType.NVarChar, param1.SqlDbType, "#5");
81                         param1.Value = 1;
82                         Assert.AreEqual (SqlDbType.NVarChar, param1.SqlDbType, "#6");
83
84                         SqlParameter param2 = new SqlParameter ();
85                         param2.SqlDbType = SqlDbType.NVarChar;
86                         Assert.AreEqual (SqlDbType.NVarChar, param2.SqlDbType, "#7");
87                         param2.Value = 1;
88                         Assert.AreEqual (SqlDbType.NVarChar, param2.SqlDbType, "#8");
89                 }
90         }
91 }