SqlDataAdapter_RowUpdated.cs 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. using System;
  2. using System.Data;
  3. using System.Data.Common;
  4. using System.Data.SqlClient;
  5. using MonoTests.System.Data.Utils;
  6. using NUnit.Framework;
  7. namespace MonoTests.System.Data.SqlClient
  8. {
  9. [TestFixture]
  10. public class SqlDataAdapter_RowUpdated : ADONetTesterClass
  11. {
  12. public static void Main()
  13. {
  14. SqlDataAdapter_RowUpdated tc = new SqlDataAdapter_RowUpdated();
  15. Exception exp = null;
  16. try
  17. {
  18. tc.BeginTest("SqlDataAdapter_RowUpdated");
  19. tc.run();
  20. }
  21. catch(Exception ex)
  22. {
  23. exp = ex;
  24. }
  25. finally
  26. {
  27. tc.EndTest(exp);
  28. }
  29. }
  30. int EventCounter = 0;
  31. DataRow drInsert,drDelete,drUpdate;
  32. [Test]
  33. public void run()
  34. {
  35. if (ConnectedDataProvider.GetDbType() != DataBaseServer.SQLServer)
  36. {
  37. Log("Test \"SqlDataAdapter_RowUpdated\" skipped: [Test applies only to sql server]");
  38. return;
  39. }
  40. Exception exp = null;
  41. SqlDataAdapter sqlDa = new SqlDataAdapter();
  42. SqlConnection con = new SqlConnection(ConnectedDataProvider.ConnectionStringSQLClient);
  43. sqlDa.SelectCommand = new SqlCommand("",con);
  44. base.SqlDataAdapter_BuildUpdateCommands(ref sqlDa);
  45. // --------- get data from DB -----------------
  46. DataSet ds = base.PrepareDBData_Update((DbDataAdapter)sqlDa,true);
  47. // add event handler
  48. sqlDa.RowUpdated+=new SqlRowUpdatedEventHandler(sqlDa_RowUpdated);
  49. //insert ,delete, update
  50. drInsert = ds.Tables[0].NewRow();
  51. drInsert.ItemArray = new object[] {9991,"Ofer","Borshtein","Insert"};
  52. drDelete = ds.Tables[0].Rows.Find(9992);
  53. drUpdate = ds.Tables[0].Rows.Find(9993);
  54. ds.Tables[0].Rows.Add(drInsert);
  55. drDelete.Delete();
  56. drUpdate["Title"] = "Jack the ripper";
  57. //execute update to db, will raise events
  58. sqlDa.Update(ds);
  59. try
  60. {
  61. BeginCase("EventCounter ");
  62. Compare(EventCounter ,3);
  63. }
  64. catch(Exception ex) {exp = ex;}
  65. finally {EndCase(exp); exp = null;}
  66. sqlDa.RowUpdated-= new SqlRowUpdatedEventHandler(sqlDa_RowUpdated);
  67. //close connection
  68. if ( ((IDbDataAdapter)sqlDa).SelectCommand.Connection.State != ConnectionState.Closed )
  69. ((IDbDataAdapter)sqlDa).SelectCommand.Connection.Close();
  70. }
  71. private void sqlDa_RowUpdated(object sender, SqlRowUpdatedEventArgs e)
  72. {
  73. Exception exp = null;
  74. switch (e.StatementType)
  75. {
  76. case StatementType.Insert:
  77. try
  78. {
  79. BeginCase("RowInsert");
  80. Compare(drInsert ,e.Row );
  81. }
  82. catch(Exception ex) {exp = ex;}
  83. finally {EndCase(exp); exp = null;}
  84. EventCounter++;
  85. break;
  86. case StatementType.Delete:
  87. try
  88. {
  89. BeginCase("RowDelete");
  90. Compare(drDelete ,e.Row );
  91. }
  92. catch(Exception ex) {exp = ex;}
  93. finally {EndCase(exp); exp = null;}
  94. EventCounter++;
  95. break;
  96. case StatementType.Update:
  97. try
  98. {
  99. BeginCase("RowUpdate");
  100. Compare(drUpdate ,e.Row );
  101. }
  102. catch(Exception ex) {exp = ex;}
  103. finally {EndCase(exp); exp = null;}
  104. EventCounter++;
  105. break;
  106. }
  107. }
  108. }
  109. }