2 // Copyright (c) 2006 Mainsoft Co.
4 // Permission is hereby granted, free of charge, to any person obtaining
5 // a copy of this software and associated documentation files (the
6 // "Software"), to deal in the Software without restriction, including
7 // without limitation the rights to use, copy, modify, merge, publish,
8 // distribute, sublicense, and/or sell copies of the Software, and to
9 // permit persons to whom the Software is furnished to do so, subject to
10 // the following conditions:
12 // The above copyright notice and this permission notice shall be
13 // included in all copies or substantial portions of the Software.
15 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
19 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
20 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
21 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 using System.Data.OleDb;
28 using MonoTests.System.Data.Utils;
31 using NUnit.Framework;
33 namespace MonoTests.System.Data.OleDb
36 public class OleDbDataReader_GetOrdinal : ADONetTesterClass
38 public static void Main()
40 OleDbDataReader_GetOrdinal tc = new OleDbDataReader_GetOrdinal();
44 tc.BeginTest("OleDbDataReader_GetOrdinal");
47 catch(Exception ex){exp = ex;}
48 finally {tc.EndTest(exp);}
56 OleDbConnection con = new OleDbConnection(MonoTests.System.Data.Utils.ConnectedDataProvider.ConnectionString);
58 OleDbCommand cmd = new OleDbCommand("Select * From Customers", con);
59 OleDbDataReader rdr = cmd.ExecuteReader();
64 BeginCase("column REGION ordinal");
65 Compare(rdr.GetOrdinal("REGION"),6 );
67 catch(Exception ex){exp = ex;}
68 finally{EndCase(exp); exp = null;}
72 BeginCase("column not exists");
75 int i = rdr.GetOrdinal("blabla");
77 catch (Exception ex) {exp=ex;}
78 Compare(exp.GetType().FullName,typeof(IndexOutOfRangeException).FullName);
81 catch(Exception ex){exp = ex;}
82 finally{EndCase(exp); exp = null;}
84 if (con.State == ConnectionState.Open) con.Close();