Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/mono/mono.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'mcs/class/Managed.Windows.Forms/Test/System.Windows.Forms/MenuItemTest.cs')
-rw-r--r--mcs/class/Managed.Windows.Forms/Test/System.Windows.Forms/MenuItemTest.cs170
1 files changed, 170 insertions, 0 deletions
diff --git a/mcs/class/Managed.Windows.Forms/Test/System.Windows.Forms/MenuItemTest.cs b/mcs/class/Managed.Windows.Forms/Test/System.Windows.Forms/MenuItemTest.cs
new file mode 100644
index 00000000000..aad692b1188
--- /dev/null
+++ b/mcs/class/Managed.Windows.Forms/Test/System.Windows.Forms/MenuItemTest.cs
@@ -0,0 +1,170 @@
+// Permission is hereby granted, free of charge, to any person obtaining
+// a copy of this software and associated documentation files (the
+// "Software"), to deal in the Software without restriction, including
+// without limitation the rights to use, copy, modify, merge, publish,
+// distribute, sublicense, and/or sell copies of the Software, and to
+// permit persons to whom the Software is furnished to do so, subject to
+// the following conditions:
+//
+// The above copyright notice and this permission notice shall be
+// included in all copies or substantial portions of the Software.
+//
+// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+//
+// Copyright (c) 2005 Novell, Inc. (http://www.novell.com)
+//
+// Author:
+// Jordi Mas i Hernandez <jordi@ximian.com>
+//
+//
+
+
+using System;
+using System.Windows.Forms;
+using System.Drawing;
+using System.Reflection;
+using NUnit.Framework;
+
+namespace MonoTests.System.Windows.Forms
+{
+ [TestFixture]
+ public class MenuItemTest
+ {
+ [Test]
+ public void MenuItemDefaultValues ()
+ {
+ MenuItem mi = new MenuItem ();
+
+ Assert.AreEqual (false, mi.BarBreak, "DefaultValues#1");
+ Assert.AreEqual (false, mi.Break, "DefaultValues#2");
+ Assert.AreEqual (false, mi.Checked, "DefaultValues#3");
+ Assert.AreEqual (false, mi.DefaultItem, "DefaultValues#4");
+ Assert.AreEqual (true, mi.Enabled, "DefaultValues#5");
+ Assert.AreEqual (-1, mi.Index, "DefaultValues#6");
+ Assert.AreEqual (false, mi.IsParent, "DefaultValues#7");
+
+ // TODO: MDI is not completed yet
+ //Assert.AreEqual (, mi.MdiList, "DefaultValues#8");
+
+ Assert.AreEqual (0, mi.MergeOrder, "DefaultValues#9");
+ Assert.AreEqual (MenuMerge.Add, mi.MergeType, "DefaultValues#10");
+ Assert.AreEqual ('\0', mi.Mnemonic, "DefaultValues#11");
+
+ Assert.AreEqual (false, mi.OwnerDraw, "DefaultValues#12");
+ Assert.AreEqual (null, mi.Parent, "DefaultValues#13");
+ Assert.AreEqual (false, mi.RadioCheck, "DefaultValues#14");
+ Assert.AreEqual (Shortcut.None, mi.Shortcut, "DefaultValues#15");
+ Assert.AreEqual (true, mi.ShowShortcut, "DefaultValues#16");
+ Assert.AreEqual (string.Empty, mi.Text, "DefaultValues#17");
+ Assert.AreEqual (true, mi.Visible, "DefaultValues#18");
+ }
+
+ [Test]
+ public void MenuItemConstructors ()
+ {
+ MenuItem mi;
+ MenuItem subitem1 = new MenuItem ("SubItem1");
+ MenuItem subitem2 = new MenuItem ("SubItem2");
+ MenuItem subitem3 = new MenuItem ("SubItem3");
+
+ {
+ mi = new MenuItem ("Item1");
+ Assert.AreEqual ("Item1", mi.Text, "Constructor#1");
+ }
+
+ {
+ mi = new MenuItem ("Item2", new MenuItem [] {subitem1,
+ subitem2, subitem3});
+
+ Assert.AreEqual ("Item2", mi.Text, "Constructor#2");
+ Assert.AreEqual (3, mi.MenuItems.Count, "Constructor#3");
+
+ Assert.AreEqual ("SubItem1", mi.MenuItems[0].Text, "Constructor#4");
+ Assert.AreEqual (mi, mi.MenuItems[0].Parent, "Constructor#5");
+
+ Assert.AreEqual ("SubItem2", mi.MenuItems[1].Text, "Constructor#6");
+ Assert.AreEqual (mi, mi.MenuItems[1].Parent, "Constructor#7");
+
+ Assert.AreEqual ("SubItem3", mi.MenuItems[2].Text, "Constructor#8");
+ Assert.AreEqual (mi, mi.MenuItems[2].Parent, "Constructor#9");
+ }
+
+ }
+
+ [Test]
+ public void MenuItemSimpleMerge ()
+ {
+ MainMenu mymainmenu1 = new MainMenu ();
+ MainMenu mymainmenu2 = new MainMenu ();
+ MenuItem mymenuitem1 = new MenuItem ();
+ MenuItem mymenuitem2 = new MenuItem ();
+ mymenuitem1.Text = "A";
+ mymenuitem2.Text = "B";
+ mymainmenu1.MenuItems.Add (mymenuitem1);
+ mymainmenu2.MenuItems.Add (mymenuitem2);
+ mymainmenu1.MergeMenu (mymainmenu2);
+ Assert.AreEqual (2, mymainmenu1.MenuItems.Count, "SimpleMerge#1");
+ }
+
+ [Test]
+ public void MenuItemMerge ()
+ {
+ MenuItem item1 = new MenuItem ("File (0)"); // Position 0
+ MenuItem item2 = new MenuItem ("Print the file (1)"); // Position 1
+ MenuItem item3 = new MenuItem ("Print Preview (2)"); // Position 2
+ MenuItem item4 = new MenuItem ("-"); // Position 3
+ MenuItem item5 = new MenuItem ("Recent files (4)"); // Position 4
+ MenuItem item6 = new MenuItem ("Exit (5)"); // Position 5
+
+ MenuItem item10 = new MenuItem ("Compare... (6)"); // Replace pos 3
+ MenuItem item11 = new MenuItem ("Sort (7)");
+ MenuItem item12 = new MenuItem ("Conversions (8)");
+ MenuItem item13 = new MenuItem ("Specials Functions (9)");
+ MenuItem item14 = new MenuItem ("Another option... (10)");
+
+ MenuItem item20 = new MenuItem ("autors.doc");
+ MenuItem item21 = new MenuItem ("testing.html");
+ MenuItem item22 = new MenuItem ("proves.txt");
+
+ MenuItem[] first_items = new MenuItem[] {item1, item2, item3, item4, item5, item6};
+ MenuItem[] second_items = new MenuItem[] {item10, item11, item12, item13, item14};
+ MenuItem[] third_items = new MenuItem[] {item20, item21, item22};
+
+ item14.MergeType = MenuMerge.Remove;
+ item10.MergeOrder = 40;
+
+ item11.MergeType = MenuMerge.Replace;
+ item11.MergeOrder = 30;
+ item12.MergeOrder = 5;
+ item10.MergeType = MenuMerge.MergeItems;
+
+ ContextMenu first_menu = new ContextMenu (first_items);
+ ContextMenu second_menu = new ContextMenu (second_items);
+ ContextMenu third_menu = new ContextMenu (third_items);
+
+ first_menu.MergeMenu (second_menu);
+ first_menu.MergeMenu (third_menu);
+
+ Assert.AreEqual ("File (0)", first_menu.MenuItems[0].Text, "ItemMerge#1");
+ Assert.AreEqual ("Print the file (1)", first_menu.MenuItems[1].Text, "ItemMerge#2");
+ Assert.AreEqual ("Print Preview (2)", first_menu.MenuItems[2].Text, "ItemMerge#3");
+ Assert.AreEqual ("-", first_menu.MenuItems[3].Text, "ItemMerge#4");
+ Assert.AreEqual ("Recent files (4)", first_menu.MenuItems[4].Text, "ItemMerge#5");
+ Assert.AreEqual ("Exit (5)", first_menu.MenuItems[5].Text, "ItemMerge#6");
+ Assert.AreEqual ("Specials Functions (9)", first_menu.MenuItems[6].Text, "ItemMerge#7");
+ Assert.AreEqual ("autors.doc", first_menu.MenuItems[7].Text, "ItemMerge#8");
+ Assert.AreEqual ("testing.html", first_menu.MenuItems[8].Text, "ItemMerge#9");
+ Assert.AreEqual ("proves.txt", first_menu.MenuItems[9].Text, "ItemMerge#10");
+ Assert.AreEqual ("Conversions (8)", first_menu.MenuItems[10].Text, "ItemMerge#11");
+ Assert.AreEqual ("Sort (7)", first_menu.MenuItems[11].Text, "ItemMerge#11");
+ Assert.AreEqual ("Compare... (6)", first_menu.MenuItems[12].Text, "ItemMerge#11");
+ }
+
+ }
+}