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 public class OracleDataAdapter_RowUpdating : ADONetTesterClass
39 public static void Main()
41 OracleDataAdapter_RowUpdating tc = new OracleDataAdapter_RowUpdating();
45 tc.BeginTest("OracleDataAdapter_RowUpdating");
59 //public TestClass():base(true){}
61 //Activate this constructor to log Failures to a log file
62 //public TestClass(System.IO.TextWriter tw):base(tw, false){}
65 //Activate this constructor to log All to a log file
66 //public TestClass(System.IO.TextWriter tw):base(tw, true){}
68 //BY DEFAULT LOGGING IS DONE TO THE STANDARD OUTPUT ONLY FOR FAILURES
72 DataRow drInsert,drDelete,drUpdate;
78 OracleDataAdapter oleDBda = new OracleDataAdapter();
79 oleDBda.SelectCommand = new OracleCommand("",new OracleConnection());
81 base.OracleDataAdapter_BuildUpdateCommands(ref oleDBda);
82 // --------- get data from DB -----------------
83 DataSet ds = base.PrepareDBData_Update((DbDataAdapter)oleDBda);
85 oleDBda.RowUpdating +=new OracleRowUpdatingEventHandler(oleDBda_RowUpdating);
87 //insert ,delete, update
88 drInsert = ds.Tables[0].NewRow();
89 drInsert.ItemArray = new object[] {9991,"Ofer","Borshtein","Insert"};
90 drDelete = ds.Tables[0].Rows.Find(9992);
91 drUpdate = ds.Tables[0].Rows.Find(9993);
93 ds.Tables[0].Rows.Add(drInsert);
95 drUpdate["Title"] = "Jack the ripper";
97 //execute update to db, will raise events
102 BeginCase("EventCounter ");
103 Compare(EventCounter ,3);
105 catch(Exception ex) {exp = ex;}
106 finally {EndCase(exp); exp = null;}
108 oleDBda.RowUpdating -=new OracleRowUpdatingEventHandler(oleDBda_RowUpdating);
111 if ( ((IDbDataAdapter)oleDBda).SelectCommand.Connection.State != ConnectionState.Closed )
112 ((IDbDataAdapter)oleDBda).SelectCommand.Connection.Close();
115 private void oleDBda_RowUpdating(object sender, OracleRowUpdatingEventArgs e)
117 Exception exp = null;
118 switch (e.StatementType)
120 case StatementType.Insert:
123 BeginCase("RowInsert");
124 Compare(drInsert ,e.Row );
126 catch(Exception ex) {exp = ex;}
127 finally {EndCase(exp); exp = null;}
130 case StatementType.Delete:
133 BeginCase("RowDelete");
134 Compare(drDelete ,e.Row );
136 catch(Exception ex) {exp = ex;}
137 finally {EndCase(exp); exp = null;}
140 case StatementType.Update:
143 BeginCase("RowUpdate");
144 Compare(drUpdate ,e.Row );
146 catch(Exception ex) {exp = ex;}
147 finally {EndCase(exp); exp = null;}