2 // Tests for System.Web.UI.WebControls.View.cs
5 // Yoni Klein (yonik@mainsoft.com)
7 // (C) 2005 Mainsoft Corporation (http://www.mainsoft.com)
9 // Permission is hereby granted, free of charge, to any person obtaining
10 // a copy of this software and associated documentation files (the
11 // "Software"), to deal in the Software without restriction, including
12 // without limitation the rights to use, copy, modify, merge, publish,
13 // distribute, sublicense, and/or sell copies of the Software, and to
14 // permit persons to whom the Software is furnished to do so, subject to
15 // the following conditions:
17 // The above copyright notice and this permission notice shall be
18 // included in all copies or substantial portions of the Software.
20 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
21 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
22 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
23 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
24 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
25 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
26 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
32 using NUnit.Framework;
35 using System.Globalization;
36 using System.Configuration;
37 using System.Collections;
38 using System.Collections.Specialized;
41 using System.Web.UI.WebControls;
42 using System.Security.Permissions;
45 namespace MonoTests.System.Web.UI.WebControls
47 class PokerSiteMapDataSource : SiteMapDataSource
49 public PokerSiteMapDataSource ()
53 public object SaveState ()
55 return SaveViewState ();
57 public void LoadState (object o)
61 public StateBag StateBag
63 get { return base.ViewState; }
65 public HierarchicalDataSourceView DoHierarchicalDataSourceView (string str)
67 return GetHierarchicalView (str);
72 public class SiteMapDataSourceTest
76 public void SiteMapDataSource_DefaultProperties ()
79 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
80 Assert.AreEqual (true, p.ShowStartingNode, "ShowStartingNode");
81 Assert.AreEqual (string.Empty, p.SiteMapProvider, "SiteMapProvider");
82 Assert.AreEqual (false, p.StartFromCurrentNode, "StartFromCurrentNode");
83 Assert.AreEqual (0, p.StartingNodeOffset, "StartingNodeOffset");
84 Assert.AreEqual (string.Empty, p.StartingNodeUrl, "StartingNodeUrl");
89 [Category ("NotWorking")] // not implemented in mono
90 public void SiteMapDataSource_NotWorkingDefaultProperties ()
92 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
93 Assert.AreEqual (true, p.ContainsListCollection, "ContainsListCollection");
97 public void SiteMapDataSource_ChangeProperties ()
99 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
100 p.ShowStartingNode = false;
101 Assert.AreEqual (false, p.ShowStartingNode, "ShowStartingNode");
102 Assert.AreEqual (1, p.StateBag.Count, "ShowStartingNode#1");
104 p.SiteMapProvider = "test";
105 Assert.AreEqual ("test", p.SiteMapProvider, "SiteMapProvider");
106 Assert.AreEqual (2, p.StateBag.Count, "SiteMapProvider#1");
107 // null properties doe's not affects on state bag count
108 p.SiteMapProvider = null;
109 Assert.AreEqual (2, p.StateBag.Count, "SiteMapProvider#2");
111 p.StartFromCurrentNode = true;
112 Assert.AreEqual (true, p.StartFromCurrentNode, "StartFromCurrentNode");
113 Assert.AreEqual (3, p.StateBag.Count, "StartFromCurrentNode#1");
115 p.StartingNodeOffset = 1;
116 Assert.AreEqual (1, p.StartingNodeOffset, "StartingNodeOffset");
117 Assert.AreEqual (4, p.StateBag.Count, "StartingNodeOffset#2");
119 p.StartingNodeUrl = "default.aspx";
120 Assert.AreEqual ("default.aspx", p.StartingNodeUrl, "StartingNodeUrl");
121 Assert.AreEqual (5, p.StateBag.Count, "StartingNodeUrl#1");
122 // null properties doe's not affects on state bag count
123 p.StartingNodeUrl = null;
124 Assert.AreEqual (5, p.StateBag.Count, "StartingNodeUrl#2");
128 [Category ("NotWorking")] // Throws NotImplementedException in mono
129 public void SiteMapDataSource_GetList ()
131 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
132 Assert.IsNotNull (p.GetList (), "GetList");
133 Assert.IsTrue (p.ContainsListCollection, "ContainsListCollection");
137 public void SiteMapDataSource_GetView ()
139 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
140 p.Provider = new mySiteMapProvider ();
141 DataSourceView V = p.GetView("");
142 Assert.IsNotNull (V, "GetView");
146 public void SiteMapDataSource_ViewState ()
148 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
149 p.SiteMapProvider = "test";
151 p.StartFromCurrentNode = false;
152 p.StartingNodeOffset = 1;
153 p.StartingNodeUrl = "default.aspx";
155 object state = p.SaveState ();
156 PokerSiteMapDataSource copy = new PokerSiteMapDataSource ();
157 copy.LoadState (state);
159 Assert.AreEqual ("test", copy.SiteMapProvider, "SiteMapProvider");
160 Assert.AreEqual (false, copy.StartFromCurrentNode, "StartFromCurrentNode");
161 Assert.AreEqual (1, copy.StartingNodeOffset, "StartingNodeOffset");
162 Assert.AreEqual ("default.aspx", copy.StartingNodeUrl, "StartingNodeUrl");
166 [Category ("NotWorking")] //throws System.IndexOutOfRangeException : Array index is out of range
167 public void SiteMapDataSource_HierarchicalDataSourceView ()
169 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
170 p.Provider = new mySiteMapProvider ();
171 HierarchicalDataSourceView h = p.DoHierarchicalDataSourceView ("1");
172 Assert.IsNotNull (h, "HierarchicalDataSourceView");
176 [Category ("NotWorking")] //must be throw ConfigurationErrorsException but was IndexOutOfRangeException
177 [ExpectedException (typeof (ConfigurationErrorsException))]
178 public void SiteMapDataSource_GetViewExeption1 ()
180 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
187 public class mySiteMapProvider : StaticSiteMapProvider
189 private SiteMapNode rootNode = null;
190 // Implement a default constructor.
191 public mySiteMapProvider ()
194 // Some basic state to help track the initialization state of the provider.
195 private bool initialized = false;
196 public virtual bool IsInitialized
198 get { return initialized; }
201 // Return the root node of the current site map.
202 public override SiteMapNode RootNode
206 SiteMapNode temp = null;
207 temp = BuildSiteMap ();
211 protected override SiteMapNode GetRootNodeCore ()
215 // Initialize is used to initialize the properties and any state that the
216 // AccessProvider holds, but is not used to build the site map.
217 // The site map is built when the BuildSiteMap method is called.
218 public override void Initialize (string name, NameValueCollection attributes)
223 base.Initialize (name, attributes);
228 /// SiteMapProvider and StaticSiteMapProvider methods that this derived class must override.
230 // Clean up any collections or other state that an instance of this may hold.
231 protected override void Clear ()
239 // Build an in-memory representation from persistent
240 // storage, and return the root node of the site map.
241 public override SiteMapNode BuildSiteMap ()
243 // Since the SiteMap class is static, make sure that it is
244 // not modified while the site map is built.
247 // If there is no root node, then there is no site map.
248 if (null == rootNode) {
249 // Start with a clean slate
252 // Select the root node of the site map .
253 rootNode = new SiteMapNode (this, "1", "default.aspx", "Default");
259 SiteMapNode childNode = null;
260 childNode = new SiteMapNode (this, "2", "catalog.aspx", "catalog");
261 AddNode (childNode, rootNode);
262 childNode = new SiteMapNode (this, "3", "aboutus.aspx", "about us");
263 AddNode (childNode, rootNode);