ObjectDataSourceViewTest.cs 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941
  1. //
  2. // Tests for System.Web.UI.WebControls.ObjectDataSourceView
  3. //
  4. // Author:
  5. // Chris Toshok ([email protected])
  6. // Konstantin Triger ([email protected])
  7. // Yoni Klain ([email protected])
  8. //
  9. //
  10. // Copyright (C) 2006 Novell, Inc (http://www.novell.com)
  11. //
  12. // Permission is hereby granted, free of charge, to any person obtaining
  13. // a copy of this software and associated documentation files (the
  14. // "Software"), to deal in the Software without restriction, including
  15. // without limitation the rights to use, copy, modify, merge, publish,
  16. // distribute, sublicense, and/or sell copies of the Software, and to
  17. // permit persons to whom the Software is furnished to do so, subject to
  18. // the following conditions:
  19. //
  20. // The above copyright notice and this permission notice shall be
  21. // included in all copies or substantial portions of the Software.
  22. //
  23. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  24. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  25. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  26. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  27. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  28. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  29. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  30. //
  31. // WARNING NOTES : ALL NUNITWEB TESTS DOING UNLOAD BETWEEN TESTS FOR RELOAD
  32. // OBJECT DATA SOURCE DEFAULT DATA
  33. #if NET_2_0
  34. using NUnit.Framework;
  35. using System;
  36. using System.Configuration;
  37. using System.Data.Common;
  38. using System.IO;
  39. using System.Globalization;
  40. using System.Web;
  41. using System.Web.UI;
  42. using System.Web.UI.WebControls;
  43. using System.Data;
  44. using System.Collections;
  45. using MonoTests.SystemWeb.Framework;
  46. using MonoTests.stand_alone.WebHarness;
  47. using System.Threading;
  48. namespace MonoTests.System.Web.UI.WebControls
  49. {
  50. class ObjectViewPoker : ObjectDataSourceView
  51. {
  52. public ObjectViewPoker (ObjectDataSource ds, string name, HttpContext context)
  53. : base (ds, name, context)
  54. {
  55. TrackViewState ();
  56. }
  57. public bool IsTrackingViewState ()
  58. {
  59. return base.IsTrackingViewState;
  60. }
  61. public object SaveToViewState ()
  62. {
  63. return SaveViewState ();
  64. }
  65. public void LoadFromViewState (object savedState)
  66. {
  67. LoadViewState (savedState);
  68. }
  69. public void DoOnDeleting (ObjectDataSourceMethodEventArgs e)
  70. {
  71. base.OnDeleting (e);
  72. }
  73. public void DoOnInserting (ObjectDataSourceMethodEventArgs e)
  74. {
  75. base.OnInserting (e);
  76. }
  77. public void DoOnFiltering (ObjectDataSourceFilteringEventArgs e)
  78. {
  79. base.OnFiltering (e);
  80. }
  81. public void DoOnObjectCreating (ObjectDataSourceEventArgs e)
  82. {
  83. base.OnObjectCreating (e);
  84. }
  85. public void DoOnObjectCreated (ObjectDataSourceEventArgs e)
  86. {
  87. base.OnObjectCreated (e);
  88. }
  89. public void DoOnObjectDisposing (ObjectDataSourceDisposingEventArgs e)
  90. {
  91. base.OnObjectDisposing (e);
  92. }
  93. public void DoOnSelecting (ObjectDataSourceSelectingEventArgs e)
  94. {
  95. base.OnSelecting (e);
  96. }
  97. public void DoOnUpdating (ObjectDataSourceMethodEventArgs e)
  98. {
  99. base.OnUpdating (e);
  100. }
  101. public void DoOnUpdated (ObjectDataSourceStatusEventArgs e)
  102. {
  103. base.OnUpdated (e);
  104. }
  105. public void DoOnDeleted (ObjectDataSourceStatusEventArgs e)
  106. {
  107. base.OnDeleted (e);
  108. }
  109. public void DoOnInserted (ObjectDataSourceStatusEventArgs e)
  110. {
  111. base.OnInserted (e);
  112. }
  113. public void DoOnSelected (ObjectDataSourceStatusEventArgs e)
  114. {
  115. base.OnSelected (e);
  116. }
  117. public int DoExecuteDelete (IDictionary keys, IDictionary oldValues)
  118. {
  119. return base.ExecuteDelete (keys, oldValues);
  120. }
  121. }
  122. [TestFixture]
  123. public class ObjectDataSourceViewTest
  124. {
  125. [SetUp]
  126. public void SetupTestCase ()
  127. {
  128. Thread.Sleep (100);
  129. }
  130. [Test]
  131. public void Defaults ()
  132. {
  133. ObjectDataSource ds = new ObjectDataSource ();
  134. ObjectViewPoker sql = new ObjectViewPoker (ds, "DefaultView", null);
  135. Assert.IsFalse (sql.CanDelete, "CanDelete");
  136. Assert.IsFalse (sql.CanInsert, "CanInsert");
  137. Assert.IsFalse (sql.CanPage, "CanPage");
  138. Assert.IsTrue (sql.CanSort, "CanSort");
  139. Assert.IsFalse (sql.CanUpdate, "CanUpdate");
  140. Assert.AreEqual (ConflictOptions.OverwriteChanges, sql.ConflictDetection, "ConflictDetection");
  141. Assert.IsFalse (sql.ConvertNullToDBNull, "ConvertNullToDBNull");
  142. Assert.AreEqual ("", sql.DataObjectTypeName, "DataObjectTypeName");
  143. Assert.AreEqual ("", sql.DeleteMethod, "DeleteMethod");
  144. Assert.IsNotNull (sql.DeleteParameters, "DeleteParameters");
  145. Assert.AreEqual (0, sql.DeleteParameters.Count, "DeleteParameters.Count");
  146. Assert.IsFalse (sql.EnablePaging, "EnablePaging");
  147. Assert.AreEqual ("", sql.InsertMethod, "InsertMethod");
  148. Assert.IsNotNull (sql.InsertParameters, "InsertParameters");
  149. Assert.AreEqual (0, sql.InsertParameters.Count, "InsertParameters.Count");
  150. Assert.AreEqual ("", sql.FilterExpression, "FilterExpression");
  151. Assert.IsNotNull (sql.FilterParameters, "FilterParameters");
  152. Assert.AreEqual (0, sql.FilterParameters.Count, "FilterParameters.Count");
  153. Assert.AreEqual ("maximumRows", sql.MaximumRowsParameterName, "MaximumRowsParameterName");
  154. Assert.AreEqual ("", sql.SelectCountMethod, "SelectCountMethod");
  155. Assert.AreEqual ("", sql.SelectMethod, "SelectMethod");
  156. Assert.AreEqual ("{0}", sql.OldValuesParameterFormatString, "OldValuesParameterFormatString");
  157. Assert.IsNotNull (sql.SelectParameters, "SelectParameters");
  158. Assert.AreEqual (0, sql.SelectParameters.Count, "SelectParameters.Count");
  159. Assert.AreEqual ("", sql.SortParameterName, "SortParameterName");
  160. Assert.IsNotNull (sql.UpdateParameters, "UpdateParameters");
  161. Assert.AreEqual (0, sql.UpdateParameters.Count, "UpdateParameters.Count");
  162. Assert.AreEqual ("startRowIndex", sql.StartRowIndexParameterName, "StartRowIndexParameterName");
  163. Assert.AreEqual ("", sql.TypeName, "TypeName");
  164. Assert.AreEqual ("", sql.UpdateMethod, "UpdateMethod");
  165. Assert.AreEqual (true, sql.IsTrackingViewState (), "IsTrackingViewState");
  166. }
  167. [Test]
  168. public void DefaultsNotWorking ()
  169. {
  170. ObjectDataSource ds = new ObjectDataSource ();
  171. ObjectViewPoker sql = new ObjectViewPoker (ds, "DefaultView", null);
  172. Assert.IsTrue (sql.CanRetrieveTotalRowCount, "CanRetrieveTotalRowCount");
  173. }
  174. [Test]
  175. public void DefaultsAssignProperties ()
  176. {
  177. ObjectDataSource ds = new ObjectDataSource ();
  178. ObjectViewPoker sql = new ObjectViewPoker (ds, "DefaultView", null);
  179. sql.ConflictDetection = ConflictOptions.CompareAllValues;
  180. Assert.AreEqual (ConflictOptions.CompareAllValues, sql.ConflictDetection, "ConflictDetection");
  181. sql.ConvertNullToDBNull = true;
  182. Assert.IsTrue (sql.ConvertNullToDBNull, "ConvertNullToDBNull");
  183. sql.DataObjectTypeName = "test";
  184. Assert.AreEqual ("test", sql.DataObjectTypeName, "DataObjectTypeName");
  185. sql.DeleteMethod = "test";
  186. Assert.AreEqual ("test", sql.DeleteMethod, "DeleteMethod");
  187. sql.EnablePaging = true;
  188. Assert.IsTrue (sql.EnablePaging, "EnablePaging");
  189. sql.InsertMethod = "test";
  190. Assert.AreEqual ("test", sql.InsertMethod, "InsertMethod");
  191. sql.FilterExpression = "test";
  192. Assert.AreEqual ("test", sql.FilterExpression, "FilterExpression");
  193. sql.MaximumRowsParameterName = "test";
  194. Assert.AreEqual ("test", sql.MaximumRowsParameterName, "MaximumRowsParameterName");
  195. sql.SelectCountMethod = "test";
  196. Assert.AreEqual ("test", sql.SelectCountMethod, "SelectCountMethod");
  197. sql.SelectMethod = "test";
  198. Assert.AreEqual ("test", sql.SelectMethod, "SelectMethod");
  199. sql.OldValuesParameterFormatString = "test";
  200. Assert.AreEqual ("test", sql.OldValuesParameterFormatString, "OldValuesParameterFormatString");
  201. sql.StartRowIndexParameterName = "test";
  202. Assert.AreEqual ("test", sql.StartRowIndexParameterName, "StartRowIndexParameterName");
  203. sql.TypeName = "test";
  204. Assert.AreEqual ("test", sql.TypeName, "TypeName");
  205. sql.UpdateMethod = "test";
  206. Assert.AreEqual ("test", sql.UpdateMethod, "UpdateMethod");
  207. Assert.AreEqual ("DefaultView", sql.Name, "Name");
  208. }
  209. [Test]
  210. public void ViewState ()
  211. {
  212. // Note :
  213. // IStateManager implementation allows public access to control state
  214. // Nothing added to viewstate
  215. ObjectDataSourceView view;
  216. MyDataSource ds = new MyDataSource ();
  217. ds.ID = "ObjectDataSource2";
  218. ds.TypeName = "MonoTests.System.Web.UI.WebControls.DataSourceObject";
  219. ds.SelectMethod = "Select";
  220. ds.SelectCountMethod = "SelectCount";
  221. Parameter p1 = new Parameter ("test", TypeCode.String);
  222. ds.SelectParameters.Add (p1);
  223. ds.FilterParameters.Add (p1);
  224. view = (ObjectDataSourceView) ds.DoGetView ("DefaultView");
  225. view.ConflictDetection = ConflictOptions.CompareAllValues;
  226. view.ConvertNullToDBNull = true;
  227. view.DataObjectTypeName = "test";
  228. view.DeleteMethod = "test";
  229. view.EnablePaging = true;
  230. view.InsertMethod = "test";
  231. view.FilterExpression = "test";
  232. view.MaximumRowsParameterName = "test";
  233. view.SelectCountMethod = "test";
  234. view.SelectMethod = "test";
  235. view.OldValuesParameterFormatString = "test";
  236. view.StartRowIndexParameterName = "test";
  237. view.TypeName = "test";
  238. view.UpdateMethod = "test";
  239. ((IStateManager) view).TrackViewState ();
  240. object state = ((IStateManager) view).SaveViewState ();
  241. ObjectDataSourceView copy = new ObjectDataSourceView (ds, "DefaultView", null);
  242. ((IStateManager) copy).LoadViewState (state);
  243. Assert.AreEqual (null, state, "ViewState#1");
  244. }
  245. [Test]
  246. public void CanDelete ()
  247. {
  248. ObjectDataSource ds = new ObjectDataSource ();
  249. ObjectViewPoker sql = new ObjectViewPoker (ds, "DefaultView", null);
  250. sql.DeleteMethod = "DeleteMethod";
  251. Assert.IsTrue (sql.CanDelete, "A1");
  252. sql.DeleteMethod = "";
  253. Assert.IsFalse (sql.CanDelete, "A2");
  254. sql.DeleteMethod = null;
  255. Assert.IsFalse (sql.CanDelete, "A3");
  256. }
  257. [Test]
  258. public void CanInsert ()
  259. {
  260. ObjectDataSource ds = new ObjectDataSource ();
  261. ObjectViewPoker sql = new ObjectViewPoker (ds, "DefaultView", null);
  262. sql.InsertMethod = "InsertMethod";
  263. Assert.IsTrue (sql.CanInsert, "A1");
  264. sql.InsertMethod = "";
  265. Assert.IsFalse (sql.CanInsert, "A2");
  266. sql.InsertMethod = null;
  267. Assert.IsFalse (sql.CanInsert, "A3");
  268. }
  269. [Test]
  270. public void CanUpdate ()
  271. {
  272. ObjectDataSource ds = new ObjectDataSource ();
  273. ObjectViewPoker sql = new ObjectViewPoker (ds, "DefaultView", null);
  274. sql.UpdateMethod = "UpdateMethod";
  275. Assert.IsTrue (sql.CanUpdate, "A1");
  276. sql.UpdateMethod = "";
  277. Assert.IsFalse (sql.CanUpdate, "A2");
  278. sql.UpdateMethod = null;
  279. Assert.IsFalse (sql.CanUpdate, "A3");
  280. }
  281. [Test]
  282. public void CanRetrieveTotalRowCount () {
  283. ObjectDataSource ds = new ObjectDataSource ();
  284. ObjectDataSourceView view = new ObjectDataSourceView (ds, "DefaultView", null);
  285. Assert.IsFalse (view.CanPage, "CanPage#1");
  286. Assert.IsTrue (view.CanRetrieveTotalRowCount, "CanRetrieveTotalRowCount#1");
  287. view.EnablePaging = true;
  288. Assert.IsTrue (view.CanPage, "CanPage#2");
  289. Assert.IsFalse (view.CanRetrieveTotalRowCount, "CanRetrieveTotalRowCount#2");
  290. view.SelectCountMethod = "SelectCountMethod";
  291. Assert.IsTrue (view.CanPage, "CanPage#3");
  292. Assert.IsTrue (view.CanRetrieveTotalRowCount, "CanRetrieveTotalRowCount#3");
  293. view.EnablePaging = false;
  294. Assert.IsFalse (view.CanPage, "CanPage#4");
  295. Assert.IsTrue (view.CanRetrieveTotalRowCount, "CanRetrieveTotalRowCount#4");
  296. }
  297. [Test]
  298. public void OldValuesParameterFormatString ()
  299. {
  300. ObjectDataSource ds = new ObjectDataSource ();
  301. Assert.AreEqual ("{0}", ds.OldValuesParameterFormatString, "A1");
  302. ds.OldValuesParameterFormatString = "hi {0}";
  303. ObjectViewPoker sql = new ObjectViewPoker (ds, "DefaultView", null);
  304. Assert.AreEqual ("{0}", sql.OldValuesParameterFormatString, "A2");
  305. ds.OldValuesParameterFormatString = "hi {0}";
  306. Assert.AreEqual ("{0}", sql.OldValuesParameterFormatString, "A3");
  307. ds.OldValuesParameterFormatString = "{0}";
  308. sql.OldValuesParameterFormatString = "hi {0}";
  309. Assert.AreEqual ("{0}", ds.OldValuesParameterFormatString, "A4");
  310. }
  311. [Test]
  312. [Category("NunitWeb")]
  313. public void DeleteMethod ()
  314. {
  315. WebTest t = new WebTest (PageInvoker.CreateOnLoad (delete));
  316. string html = t.Run ();
  317. Assert.AreEqual (-1, html.IndexOf("Yonik"), "ObjectDataSourceViewDelete");
  318. WebTest.Unload ();
  319. }
  320. public static void delete (Page p)
  321. {
  322. LiteralControl lcb = new LiteralControl (HtmlDiff.BEGIN_TAG);
  323. LiteralControl lce = new LiteralControl (HtmlDiff.END_TAG);
  324. ObjectDataSourceView view;
  325. GridView grid = new GridView ();
  326. MyDataSource ds = new MyDataSource ();
  327. ds.ID = "ObjectDataSource2";
  328. ds.TypeName = "MonoTests.System.Web.UI.WebControls.DataSourceObject";
  329. ds.SelectMethod = "Select";
  330. ds.DeleteMethod = "Delete";
  331. ds.InsertMethod = "Insert";
  332. ds.UpdateMethod = "Update";
  333. Parameter p1 = new Parameter ("ID", TypeCode.String);
  334. Parameter p2 = new Parameter ("FName", TypeCode.String);
  335. Parameter p3 = new Parameter ("LName", TypeCode.String);
  336. ds.DeleteParameters.Add (p1);
  337. ds.DeleteParameters.Add (p2);
  338. ds.DeleteParameters.Add (p3);
  339. grid.ID = "Grid";
  340. grid.DataKeyNames = new string[] { "ID", "FName", "LName" };
  341. grid.DataSourceID = "ObjectDataSource2";
  342. p.Form.Controls.Add (lcb);
  343. p.Form.Controls.Add (ds);
  344. p.Form.Controls.Add (grid);
  345. p.Form.Controls.Add (lce);
  346. view = (ObjectDataSourceView) ds.DoGetView ("DefaultView");
  347. view.Deleting += new ObjectDataSourceMethodEventHandler (Event);
  348. DataSourceObject.InitDS ();
  349. Hashtable table = new Hashtable ();
  350. table.Add ("ID", "1001");
  351. table.Add ("FName", "Yonik");
  352. table.Add ("LName", "Laim");
  353. view.Delete (table, null);
  354. Assert.AreEqual (true, view.CanDelete, "CanDelete");
  355. Assert.AreEqual ("Delete", view.DeleteMethod, "DeleteMethod");
  356. Assert.AreEqual (3, view.DeleteParameters.Count, "DeleteParameters.Count");
  357. Assert.AreEqual ("ID", view.DeleteParameters[0].Name, "DeleteParametersName#1");
  358. Assert.AreEqual ("FName", view.DeleteParameters[1].Name, "DeleteParametersName#2");
  359. Assert.AreEqual ("LName", view.DeleteParameters[2].Name, "DeleteParametersName#3");
  360. ObjectDataSourceViewTest.Eventassert ("Delete event has not fired");
  361. }
  362. [Test]
  363. [Category ("NunitWeb")]
  364. public void SelectMethod ()
  365. {
  366. WebTest t = new WebTest (PageInvoker.CreateOnLoad (select));
  367. string html = t.Run ();
  368. string origin = @"<div>
  369. <table cellspacing=""0"" rules=""all"" border=""1"" id=""Grid"" style=""border-collapse:collapse;"">
  370. <tr>
  371. <th scope=""col"">ID</th><th scope=""col"">FName</th><th scope=""col"">LName</th>
  372. </tr><tr>
  373. <td>1001</td><td>Mahesh</td><td>Chand</td>
  374. </tr>
  375. </table>
  376. </div>";
  377. HtmlDiff.AssertAreEqual (origin, HtmlDiff.GetControlFromPageHtml (html), "ObjectDataSourceViewSelect");
  378. WebTest.Unload ();
  379. }
  380. public static void select (Page p)
  381. {
  382. LiteralControl lcb = new LiteralControl (HtmlDiff.BEGIN_TAG);
  383. LiteralControl lce = new LiteralControl (HtmlDiff.END_TAG);
  384. ObjectDataSourceView view;
  385. GridView grid = new GridView ();
  386. MyDataSource ds = new MyDataSource ();
  387. ds.ID = "ObjectDataSource2";
  388. ds.TypeName = "MonoTests.System.Web.UI.WebControls.DataSourceObject";
  389. ds.SelectMethod = "Select";
  390. grid.ID = "Grid";
  391. grid.DataKeyNames = new string[] { "ID" };
  392. grid.DataSourceID = "ObjectDataSource2";
  393. p.Form.Controls.Add (lcb);
  394. p.Form.Controls.Add (ds);
  395. p.Form.Controls.Add (grid);
  396. p.Form.Controls.Add (lce);
  397. view = (ObjectDataSourceView) ds.DoGetView ("DefaultView");
  398. view.Selecting += new ObjectDataSourceSelectingEventHandler (view_Selecting);
  399. DataSourceObject.InitDS ();
  400. DataView view1 = (DataView) view.Select (new DataSourceSelectArguments ());
  401. Assert.AreEqual (1, view1.Count, "SelectedRowsCount");
  402. Assert.AreEqual (1001, view1[0].Row["ID"], "SelectedRowsValue#1");
  403. Assert.AreEqual ("Mahesh", view1[0].Row["FName"], "SelectedRowsValue#2");
  404. Assert.AreEqual ("Chand", view1[0].Row["LName"], "SelectedRowsValue#3");
  405. ObjectDataSourceViewTest.Eventassert ("Select event has not fired");
  406. }
  407. [Test]
  408. [Category ("NunitWeb")]
  409. public void SelectCountMethod ()
  410. {
  411. // This method will render grid view with paging
  412. // Note : ObjectDataSource will return page counter 5 hard coded
  413. WebTest t = new WebTest (PageInvoker.CreateOnLoad (selectcount));
  414. string html = t.Run ();
  415. string origin = @"<div>
  416. <table cellspacing=""0"" rules=""all"" border=""1"" id=""Grid"" style=""border-collapse:collapse;"">
  417. <tr>
  418. <th scope=""col"">ID</th><th scope=""col"">FName</th><th scope=""col"">LName</th>
  419. </tr><tr>
  420. <td>1001</td><td>Mahesh</td><td>Chand</td>
  421. </tr><tr>
  422. <td colspan=""3""><table border=""0"">
  423. <tr>
  424. <td><span>1</span></td><td><a href=""javascript:__doPostBack('Grid','Page$2')"">2</a></td><td><a href=""javascript:__doPostBack('Grid','Page$3')"">3</a></td><td><a href=""javascript:__doPostBack('Grid','Page$4')"">4</a></td><td><a href=""javascript:__doPostBack('Grid','Page$5')"">5</a></td>
  425. </tr>
  426. </table></td>
  427. </tr>
  428. </table>
  429. </div>";
  430. HtmlDiff.AssertAreEqual (origin, HtmlDiff.GetControlFromPageHtml (html), "ObjectDataSourceViewSelectCount");
  431. WebTest.Unload ();
  432. }
  433. public static void selectcount (Page p)
  434. {
  435. // This method will render grid view with paging
  436. // Note : ObjectDataSource will return page counter 5 hard coded
  437. LiteralControl lcb = new LiteralControl (HtmlDiff.BEGIN_TAG);
  438. LiteralControl lce = new LiteralControl (HtmlDiff.END_TAG);
  439. ObjectDataSourceView view;
  440. GridView grid = new GridView ();
  441. MyDataSource ds = new MyDataSource ();
  442. ds.ID = "ObjectDataSource2";
  443. ds.TypeName = "MonoTests.System.Web.UI.WebControls.DataSourceObject";
  444. ds.SelectMethod = "Select";
  445. ds.SelectCountMethod = "SelectCount";
  446. grid.ID = "Grid";
  447. grid.DataKeyNames = new string[] { "ID" };
  448. grid.DataSourceID = "ObjectDataSource2";
  449. grid.AllowPaging = true;
  450. grid.PageSize = 1;
  451. p.Form.Controls.Add (lcb);
  452. p.Form.Controls.Add (ds);
  453. p.Form.Controls.Add (grid);
  454. p.Form.Controls.Add (lce);
  455. view = (ObjectDataSourceView) ds.DoGetView ("DefaultView");
  456. Assert.IsTrue (view.CanRetrieveTotalRowCount, "CanRetrieveTotalRowCount");
  457. }
  458. [Test]
  459. [Category ("NunitWeb")]
  460. public void InsertMethod ()
  461. {
  462. WebTest t = new WebTest (PageInvoker.CreateOnLoad (insert));
  463. string html = t.Run ();
  464. string origin = @"<div>
  465. <table cellspacing=""0"" rules=""all"" border=""1"" id=""Grid"" style=""border-collapse:collapse;"">
  466. <tr>
  467. <th scope=""col"">ID</th><th scope=""col"">FName</th><th scope=""col"">LName</th>
  468. </tr><tr>
  469. <td>1001</td><td>Mahesh</td><td>Chand</td>
  470. </tr><tr>
  471. <td>1000</td><td>Yonik</td><td>Laim</td>
  472. </tr>
  473. </table>
  474. </div>";
  475. HtmlDiff.AssertAreEqual (origin, HtmlDiff.GetControlFromPageHtml (html), "ObjectDataSourceViewInsert");
  476. WebTest.Unload ();
  477. }
  478. public static void insert (Page p)
  479. {
  480. LiteralControl lcb = new LiteralControl (HtmlDiff.BEGIN_TAG);
  481. LiteralControl lce = new LiteralControl (HtmlDiff.END_TAG);
  482. ObjectDataSourceView view;
  483. GridView grid = new GridView ();
  484. MyDataSource ds = new MyDataSource ();
  485. ds.ID = "ObjectDataSource1";
  486. ds.TypeName = "MonoTests.System.Web.UI.WebControls.DataSourceObject";
  487. ds.SelectMethod = "Select";
  488. ds.InsertMethod = "Insert";
  489. Parameter p1 = new Parameter ("ID", TypeCode.String);
  490. Parameter p2 = new Parameter ("FName", TypeCode.String);
  491. Parameter p3 = new Parameter ("LName", TypeCode.String);
  492. ds.InsertParameters.Add (p1);
  493. ds.InsertParameters.Add (p2);
  494. ds.InsertParameters.Add (p3);
  495. grid.ID = "Grid";
  496. grid.DataSourceID = "ObjectDataSource1";
  497. p.Form.Controls.Add (lcb);
  498. p.Form.Controls.Add (ds);
  499. p.Form.Controls.Add (grid);
  500. p.Form.Controls.Add (lce);
  501. view = (ObjectDataSourceView) ds.DoGetView ("DefaultView");
  502. view.Inserting += new ObjectDataSourceMethodEventHandler (Event);
  503. Hashtable table = new Hashtable ();
  504. table.Add ("ID", "1000");
  505. table.Add ("FName", "Yonik");
  506. table.Add ("LName", "Laim");
  507. view.Insert (table);
  508. Assert.AreEqual (true, view.CanInsert, "CanInsert");
  509. Assert.AreEqual ("Insert", view.InsertMethod, "InsertMethod");
  510. Assert.AreEqual (3, view.InsertParameters.Count, "InsertParameters.Count");
  511. Assert.AreEqual ("ID", view.InsertParameters[0].Name, "InsertParametersName#1");
  512. Assert.AreEqual ("FName", view.InsertParameters[1].Name, "InsertParametersName#2");
  513. Assert.AreEqual ("LName", view.InsertParameters[2].Name, "InsertParametersName#3");
  514. ObjectDataSourceViewTest.Eventassert ("Insert event has not fired");
  515. }
  516. [Test]
  517. [Category ("NunitWeb")]
  518. public void UpdateMethod ()
  519. {
  520. WebTest t = new WebTest (PageInvoker.CreateOnLoad (update));
  521. string html = t.Run ();
  522. string origin = @"<div>
  523. <table cellspacing=""0"" rules=""all"" border=""1"" id=""Grid"" style=""border-collapse:collapse;"">
  524. <tr>
  525. <th scope=""col"">ID</th><th scope=""col"">FName</th><th scope=""col"">LName</th>
  526. </tr><tr>
  527. <td>1001</td><td>Yonik</td><td>Laim</td>
  528. </tr>
  529. </table>
  530. </div>";
  531. HtmlDiff.AssertAreEqual (origin, HtmlDiff.GetControlFromPageHtml (html), "ObjectDataSourceViewUpdate");
  532. WebTest.Unload ();
  533. }
  534. public static void update (Page p)
  535. {
  536. LiteralControl lcb = new LiteralControl (HtmlDiff.BEGIN_TAG);
  537. LiteralControl lce = new LiteralControl (HtmlDiff.END_TAG);
  538. ObjectDataSourceView view;
  539. GridView grid = new GridView ();
  540. MyDataSource ds = new MyDataSource ();
  541. ds.ID = "ObjectDataSource1";
  542. ds.TypeName = "MonoTests.System.Web.UI.WebControls.DataSourceObject";
  543. ds.SelectMethod = "Select";
  544. ds.DeleteMethod = "Delete";
  545. ds.InsertMethod = "Insert";
  546. ds.UpdateMethod = "Update";
  547. Parameter p1 = new Parameter ("ID", TypeCode.String);
  548. Parameter p2 = new Parameter ("FName", TypeCode.String);
  549. Parameter p3 = new Parameter ("LName", TypeCode.String);
  550. ds.UpdateParameters.Add (p1);
  551. ds.UpdateParameters.Add (p2);
  552. ds.UpdateParameters.Add (p3);
  553. grid.ID = "Grid";
  554. grid.DataSourceID = "ObjectDataSource1";
  555. p.Form.Controls.Add (lcb);
  556. p.Form.Controls.Add (ds);
  557. p.Form.Controls.Add (grid);
  558. p.Form.Controls.Add (lce);
  559. view = (ObjectDataSourceView) ds.DoGetView ("defaultView");
  560. view.Updating += new ObjectDataSourceMethodEventHandler (Event);
  561. DataSourceObject.InitDS ();
  562. Hashtable table = new Hashtable ();
  563. table.Add ("ID", "1001");
  564. table.Add ("FName", "Yonik");
  565. table.Add ("LName", "Laim");
  566. view.Update (null, table, null);
  567. Assert.AreEqual (true, view.CanUpdate, "CanUpdate");
  568. Assert.AreEqual ("Update", view.UpdateMethod, "UpdateMethod");
  569. Assert.AreEqual (3, view.UpdateParameters.Count, "UpdateParameters.Count");
  570. Assert.AreEqual ("ID", view.UpdateParameters[0].Name, "UpdateParametersName#1");
  571. Assert.AreEqual ("FName", view.UpdateParameters[1].Name, "UpdateParametersName#2");
  572. Assert.AreEqual ("LName", view.UpdateParameters[2].Name, "UpdateParametersName#3");
  573. ObjectDataSourceViewTest.Eventassert ("Update event has not fired");
  574. }
  575. //Events
  576. [Test]
  577. public void UpdateEvent ()
  578. {
  579. ObjectViewPoker view = new ObjectViewPoker (new ObjectDataSource (), "", null);
  580. view.Updating += new ObjectDataSourceMethodEventHandler (Event);
  581. view.DoOnUpdating (new ObjectDataSourceMethodEventArgs (null));
  582. Eventassert ("UpdateEvent");
  583. view.Updated += new ObjectDataSourceStatusEventHandler (view_Status);
  584. view.DoOnUpdated (new ObjectDataSourceStatusEventArgs (null, null));
  585. Eventassert ("UpdateEvent");
  586. }
  587. [Test]
  588. public void SelectEvent ()
  589. {
  590. ObjectViewPoker view = new ObjectViewPoker (new ObjectDataSource (), "", null);
  591. view.Selecting += new ObjectDataSourceSelectingEventHandler (view_Selecting);
  592. view.DoOnSelecting (new ObjectDataSourceSelectingEventArgs (null, new DataSourceSelectArguments (), false));
  593. Eventassert ("SelectingEvent");
  594. view.Selected += new ObjectDataSourceStatusEventHandler (view_Status);
  595. view.DoOnSelected (new ObjectDataSourceStatusEventArgs (null, null));
  596. Eventassert ("SelectedEvent");
  597. }
  598. [Test]
  599. public void InsertEvent ()
  600. {
  601. ObjectViewPoker view = new ObjectViewPoker (new ObjectDataSource (), "", null);
  602. view.Inserting += new ObjectDataSourceMethodEventHandler (Event);
  603. view.DoOnInserting (new ObjectDataSourceMethodEventArgs (null));
  604. Eventassert ("InsertingEvent");
  605. view.Inserted += new ObjectDataSourceStatusEventHandler (view_Status);
  606. view.DoOnInserted (new ObjectDataSourceStatusEventArgs (null, null));
  607. Eventassert ("InsertedEvent");
  608. }
  609. [Test]
  610. public void DeleteEvent ()
  611. {
  612. ObjectViewPoker view = new ObjectViewPoker (new ObjectDataSource (), "", null);
  613. view.Deleting += new ObjectDataSourceMethodEventHandler (Event);
  614. view.DoOnDeleting (new ObjectDataSourceMethodEventArgs (null));
  615. Eventassert ("DeletingEvent");
  616. view.Deleted += new ObjectDataSourceStatusEventHandler (view_Status);
  617. view.DoOnDeleted (new ObjectDataSourceStatusEventArgs (null, null));
  618. Eventassert ("DeletedEvent");
  619. }
  620. [Test]
  621. public void FilterEvent ()
  622. {
  623. ObjectViewPoker view = new ObjectViewPoker (new ObjectDataSource (), "", null);
  624. view.Filtering += new ObjectDataSourceFilteringEventHandler (view_Filtering);
  625. view.DoOnFiltering (new ObjectDataSourceFilteringEventArgs (null));
  626. Eventassert ("FilterEvent");
  627. }
  628. [Test]
  629. public void ObjectCreatingEvent ()
  630. {
  631. ObjectViewPoker view = new ObjectViewPoker (new ObjectDataSource (), "", null);
  632. view.ObjectCreating += new ObjectDataSourceObjectEventHandler (view_ObjectCreate);
  633. view.DoOnObjectCreating (new ObjectDataSourceEventArgs (null));
  634. Eventassert ("ObjectCreatingEvent");
  635. view.ObjectCreated += new ObjectDataSourceObjectEventHandler (view_ObjectCreate);
  636. view.DoOnObjectCreated (new ObjectDataSourceEventArgs (null));
  637. Eventassert ("ObjectCreatedEvent");
  638. view.ObjectDisposing += new ObjectDataSourceDisposingEventHandler (view_ObjectDisposing);
  639. }
  640. [Test]
  641. public void ObjectDisposing ()
  642. {
  643. ObjectViewPoker view = new ObjectViewPoker (new ObjectDataSource (), "", null);
  644. view.ObjectDisposing += new ObjectDataSourceDisposingEventHandler (view_ObjectDisposing);
  645. view.DoOnObjectDisposing (new ObjectDataSourceDisposingEventArgs (null));
  646. Eventassert ("ObjectDisposing");
  647. }
  648. /// <summary>
  649. /// Helper methods
  650. /// </summary>
  651. private static bool event_checker;
  652. private static void Eventassert (string message)
  653. {
  654. Assert.IsTrue (ObjectDataSourceViewTest.event_checker, message);
  655. ObjectDataSourceViewTest.event_checker = false;
  656. }
  657. static void Event (object sender, ObjectDataSourceMethodEventArgs e)
  658. {
  659. ObjectDataSourceViewTest.event_checker = true;
  660. }
  661. static void view_Selecting (object sender, ObjectDataSourceSelectingEventArgs e)
  662. {
  663. event_checker = true;
  664. }
  665. void view_Filtering (object sender, ObjectDataSourceFilteringEventArgs e)
  666. {
  667. event_checker = true;
  668. }
  669. void view_ObjectCreate (object sender, ObjectDataSourceEventArgs e)
  670. {
  671. event_checker = true;
  672. }
  673. void view_Status (object sender, ObjectDataSourceStatusEventArgs e)
  674. {
  675. event_checker = true;
  676. }
  677. void view_ObjectDisposing (object sender, ObjectDataSourceDisposingEventArgs e)
  678. {
  679. event_checker = true;
  680. }
  681. private class MyDataSource : ObjectDataSource
  682. {
  683. public DataSourceView DoGetView (string viewName)
  684. {
  685. return base.GetView (viewName);
  686. }
  687. public void DoTrackViewState ()
  688. {
  689. base.TrackViewState ();
  690. }
  691. }
  692. }
  693. public class DataSourceObject
  694. {
  695. private static int maximumRows;
  696. public static DataTable ds = CreateDataTable ();
  697. public static void InitDS ()
  698. {
  699. ds = CreateDataTable ();
  700. }
  701. public static DataTable Select ()
  702. {
  703. return ds;
  704. }
  705. public static DataTable Select (int maximumRows, int startRowIndex)
  706. {
  707. DataSourceObject.maximumRows = maximumRows;
  708. if (ds.Rows.Count > maximumRows) {
  709. DataTable temp = ds.Clone ();
  710. int i = 0;
  711. while (i < maximumRows && startRowIndex <= ds.Rows.Count) {
  712. object[] o = ds.Rows[startRowIndex].ItemArray;
  713. temp.Rows.Add (o);
  714. i++;
  715. startRowIndex++;
  716. }
  717. return temp;
  718. }
  719. return ds;
  720. }
  721. public static DataTable Delete (string ID, string FName, string LName)
  722. {
  723. DataRow dr = ds.Rows.Find (ID);
  724. if (dr != null) {
  725. ds.Rows.Remove (dr);
  726. }
  727. return ds;
  728. }
  729. public static DataTable Insert (string ID, string FName, string LName)
  730. {
  731. DataRow dr = ds.NewRow ();
  732. dr["ID"] = ID;
  733. dr["FName"] = FName;
  734. dr["LName"] = LName;
  735. ds.Rows.Add (dr);
  736. return ds;
  737. }
  738. public static DataTable Update (string ID, string FName, string LName)
  739. {
  740. foreach (DataRow row in ds.Rows) {
  741. if (row["ID"].ToString () == ID) {
  742. row["FName"] = FName;
  743. row["LName"] = LName;
  744. }
  745. }
  746. return ds;
  747. }
  748. public static int SelectCount ()
  749. {
  750. //Note: This is return 5 only for test goal
  751. return 5;
  752. }
  753. public static DataTable CreateDataTable ()
  754. {
  755. DataTable aTable = new DataTable ("A");
  756. DataColumn dtCol;
  757. DataRow dtRow;
  758. // Create ID column and add to the DataTable.
  759. dtCol = new DataColumn ();
  760. dtCol.DataType = Type.GetType ("System.Int32");
  761. dtCol.ColumnName = "ID";
  762. dtCol.AutoIncrement = true;
  763. dtCol.Caption = "ID";
  764. dtCol.ReadOnly = true;
  765. dtCol.Unique = true;
  766. aTable.Columns.Add (dtCol);
  767. // Create Name column and add to the table
  768. dtCol = new DataColumn ();
  769. dtCol.DataType = Type.GetType ("System.String");
  770. dtCol.ColumnName = "FName";
  771. dtCol.AutoIncrement = false;
  772. dtCol.Caption = "First Name";
  773. dtCol.ReadOnly = false;
  774. dtCol.Unique = false;
  775. aTable.Columns.Add (dtCol);
  776. // Create Last Name column and add to the table.
  777. dtCol = new DataColumn ();
  778. dtCol.DataType = Type.GetType ("System.String");
  779. dtCol.ColumnName = "LName";
  780. dtCol.AutoIncrement = false;
  781. dtCol.Caption = "Last Name";
  782. dtCol.ReadOnly = false;
  783. dtCol.Unique = false;
  784. aTable.Columns.Add (dtCol);
  785. // Create three rows to the table
  786. dtRow = aTable.NewRow ();
  787. dtRow["ID"] = 1001;
  788. dtRow["FName"] = "Mahesh";
  789. dtRow["LName"] = "Chand";
  790. aTable.Rows.Add (dtRow);
  791. aTable.PrimaryKey = new DataColumn[] { aTable.Columns["ID"] };
  792. return aTable;
  793. }
  794. }
  795. }
  796. #endif