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 #if TARGET_JVM //BUG #6489
138 [Category ("NotWorking")]
140 public void SiteMapDataSource_GetView ()
142 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
143 p.Provider = new mySiteMapProvider ();
144 DataSourceView V = p.GetView("");
145 Assert.IsNotNull (V, "GetView");
149 public void SiteMapDataSource_ViewState ()
151 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
152 p.SiteMapProvider = "test";
154 p.StartFromCurrentNode = false;
155 p.StartingNodeOffset = 1;
156 p.StartingNodeUrl = "default.aspx";
158 object state = p.SaveState ();
159 PokerSiteMapDataSource copy = new PokerSiteMapDataSource ();
160 copy.LoadState (state);
162 Assert.AreEqual ("test", copy.SiteMapProvider, "SiteMapProvider");
163 Assert.AreEqual (false, copy.StartFromCurrentNode, "StartFromCurrentNode");
164 Assert.AreEqual (1, copy.StartingNodeOffset, "StartingNodeOffset");
165 Assert.AreEqual ("default.aspx", copy.StartingNodeUrl, "StartingNodeUrl");
169 [Category ("NotWorking")] //throws System.IndexOutOfRangeException : Array index is out of range
170 public void SiteMapDataSource_HierarchicalDataSourceView ()
172 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
173 p.Provider = new mySiteMapProvider ();
174 HierarchicalDataSourceView h = p.DoHierarchicalDataSourceView ("1");
175 Assert.IsNotNull (h, "HierarchicalDataSourceView");
179 [Category ("NotWorking")] //must be throw ConfigurationErrorsException but was IndexOutOfRangeException
180 [ExpectedException (typeof (ConfigurationErrorsException))]
181 public void SiteMapDataSource_GetViewExeption1 ()
183 PokerSiteMapDataSource p = new PokerSiteMapDataSource ();
190 public class mySiteMapProvider : StaticSiteMapProvider
192 private SiteMapNode rootNode = null;
193 // Implement a default constructor.
194 public mySiteMapProvider ()
197 // Some basic state to help track the initialization state of the provider.
198 private bool initialized = false;
199 public virtual bool IsInitialized
201 get { return initialized; }
204 // Return the root node of the current site map.
205 public override SiteMapNode RootNode
209 SiteMapNode temp = null;
210 temp = BuildSiteMap ();
214 protected override SiteMapNode GetRootNodeCore ()
218 // Initialize is used to initialize the properties and any state that the
219 // AccessProvider holds, but is not used to build the site map.
220 // The site map is built when the BuildSiteMap method is called.
221 public override void Initialize (string name, NameValueCollection attributes)
226 base.Initialize (name, attributes);
231 /// SiteMapProvider and StaticSiteMapProvider methods that this derived class must override.
233 // Clean up any collections or other state that an instance of this may hold.
234 protected override void Clear ()
242 // Build an in-memory representation from persistent
243 // storage, and return the root node of the site map.
244 public override SiteMapNode BuildSiteMap ()
246 // Since the SiteMap class is static, make sure that it is
247 // not modified while the site map is built.
250 // If there is no root node, then there is no site map.
251 if (null == rootNode) {
252 // Start with a clean slate
255 // Select the root node of the site map .
256 rootNode = new SiteMapNode (this, "1", "default.aspx", "Default");
262 SiteMapNode childNode = null;
263 childNode = new SiteMapNode (this, "2", "catalog.aspx", "catalog");
264 AddNode (childNode, rootNode);
265 childNode = new SiteMapNode (this, "3", "aboutus.aspx", "about us");
266 AddNode (childNode, rootNode);