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.Common;
27 using System.Data.OracleClient;
29 using MonoTests.System.Data.Utils;
32 using NUnit.Framework;
34 namespace MonoTests.System.Data.OracleClient
37 [Category ("NotWorking")]
38 public class OracleDataAdapter_RowUpdating : ADONetTesterClass
40 public static void Main()
42 OracleDataAdapter_RowUpdating tc = new OracleDataAdapter_RowUpdating();
46 tc.BeginTest("OracleDataAdapter_RowUpdating");
60 //public TestClass():base(true){}
62 //Activate this constructor to log Failures to a log file
63 //public TestClass(System.IO.TextWriter tw):base(tw, false){}
66 //Activate this constructor to log All to a log file
67 //public TestClass(System.IO.TextWriter tw):base(tw, true){}
69 //BY DEFAULT LOGGING IS DONE TO THE STANDARD OUTPUT ONLY FOR FAILURES
73 DataRow drInsert,drDelete,drUpdate;
79 OracleDataAdapter oleDBda = new OracleDataAdapter();
80 oleDBda.SelectCommand = new OracleCommand("",new OracleConnection());
82 base.OracleDataAdapter_BuildUpdateCommands(ref oleDBda);
83 // --------- get data from DB -----------------
84 DataSet ds = base.PrepareDBData_Update((DbDataAdapter)oleDBda);
86 oleDBda.RowUpdating +=new OracleRowUpdatingEventHandler(oleDBda_RowUpdating);
88 //insert ,delete, update
89 drInsert = ds.Tables[0].NewRow();
90 drInsert.ItemArray = new object[] {9991,"Ofer","Borshtein","Insert"};
91 drDelete = ds.Tables[0].Rows.Find(9992);
92 drUpdate = ds.Tables[0].Rows.Find(9993);
94 ds.Tables[0].Rows.Add(drInsert);
96 drUpdate["Title"] = "Jack the ripper";
98 //execute update to db, will raise events
103 BeginCase("EventCounter ");
104 Compare(EventCounter ,3);
106 catch(Exception ex) {exp = ex;}
107 finally {EndCase(exp); exp = null;}
109 oleDBda.RowUpdating -=new OracleRowUpdatingEventHandler(oleDBda_RowUpdating);
112 if ( ((IDbDataAdapter)oleDBda).SelectCommand.Connection.State != ConnectionState.Closed )
113 ((IDbDataAdapter)oleDBda).SelectCommand.Connection.Close();
116 private void oleDBda_RowUpdating(object sender, OracleRowUpdatingEventArgs e)
118 Exception exp = null;
119 switch (e.StatementType)
121 case StatementType.Insert:
124 BeginCase("RowInsert");
125 Compare(drInsert ,e.Row );
127 catch(Exception ex) {exp = ex;}
128 finally {EndCase(exp); exp = null;}
131 case StatementType.Delete:
134 BeginCase("RowDelete");
135 Compare(drDelete ,e.Row );
137 catch(Exception ex) {exp = ex;}
138 finally {EndCase(exp); exp = null;}
141 case StatementType.Update:
144 BeginCase("RowUpdate");
145 Compare(drUpdate ,e.Row );
147 catch(Exception ex) {exp = ex;}
148 finally {EndCase(exp); exp = null;}