summaryrefslogtreecommitdiff
path: root/Xamarin.Forms.Core.macOS.UITests
diff options
context:
space:
mode:
authorRui Marinho <me@ruimarinho.net>2017-01-27 12:52:38 +0000
committerGitHub <noreply@github.com>2017-01-27 12:52:38 +0000
commit004197380ae45d394fcf3b0e8cc53ab840135433 (patch)
tree4445d8507e6b05db8d5d729afb8e3089002507a3 /Xamarin.Forms.Core.macOS.UITests
parentde96051a2eef9073574e0b45470b4a0feefc4930 (diff)
downloadxamarin-forms-004197380ae45d394fcf3b0e8cc53ab840135433.tar.gz
xamarin-forms-004197380ae45d394fcf3b0e8cc53ab840135433.tar.bz2
xamarin-forms-004197380ae45d394fcf3b0e8cc53ab840135433.zip
Add MacOS gallery and UITest (#721)
* [MacOS] Cleanup * [Controls] Add Header support to ListView * [MacOS] NSView reuse on NSTableView * [MacOS] Some fix on layour order * [MacOS] Add CarouselPageRenderer * [MacOS] Implement EventTracker on PageRenderer * [MacOS] Cleanup CarouselPageRenderer * [MacOS] Add MasterDetailPage renderer * [MacOS] MDP renderer don't allow drag of splitter * [MacOS] Add TabbedPage renderer * [MacOS] Initial sketch of NavigationPageRenderer * [MacOS] Send disappearing of CurrentPage on Dispose on NavigationPageRenderer * [MacOS] Add Gallery page for Mac * [MacOS] Add MacOSExpressionSearch * [MacOS] Fix ColorExtension * [MacOS] Fix MDP renderer layout * [MacOS] Implement native selection on ListViewRenderer * [MacOS] Deselect a item on NSTableView * [MacOS] Remove previous SplitViewItems * [MacOS] Fix navigationpage height * [MacOS] Add toolbar for NavigationPageRenderer * [MacOS] Don't remove selection for now (crashing) * [MacOS] Refactor page and back button title on NavigationPageRenderer * [MacOS] Fix bug when native navigate back * [MacOS] Hide layer when transition * [MacOS] ListviewRenderer fix BbackgroundColor * [MacOS] Fix background on ScrollViewRenderer * [MacOS] Fix header measure on ListViewRenderer * [MacOS] Add Mac twitter demo * [Controls] Spaces for easy reading * [MacOS] More xaml cleanup * [Core] Add Mac as aTargetPlatform * [MacOS] Add alerts and actionsheets * [MacOS] Add GestureRecognizers * [MacOS] Fix Layout issues when adding children, enable transformations * [MacOS] Fix title on tab item, move to tabbed navigation based on segmented control * [MacOS] Hide toolbar when not needed, this allows to work with tabbed page, cleanup * [MacOS] Add NativeBindings and NativeViewWrapper * [MacOS] Fix AssemblyInfo * [MacOS] FIX NRE on SetBackgroundColor BoxView * [MacOS] Fix NavigationPageRenderer * [MacOS] Fix build * [MacOS] Also update page when it resizes * [MacOS] Add LayoutRenderer for handle items position when the bounds change. * [MacOS] Refactor/Cleanup * [MacOS] Add toolbar items support to NavigationPage * [MacOS] Resize images for TabViewITems * [MacOS] Fix TabbedPage resize issues , allow users to override some features when creating TVI * [MacOS] Fix hide/show Navigation toolbar * [MacOS] Redo CarouselPageRenderer with NSPageController * [MacOS] Add support for Modal pages * [MacOS] Refactor navigation from platform * [Nuget] Add nuget for MacOS * [Nuget]Fix nuspec * [Nuget] Add variables for CI * [Controls] Remove MainMenu from MacOS * [MacOS] Add TableView renderer (no headers yet) * [MacOS] Refactoring, marking extensions as internal * [MacOS] Add group headers for TableViewRenderer * [MacOS] Workaround for updates on listview collection * [MacOS] Handle updates of rows in the ListViewRenderer properly * [MacOS] Fix navigation animation * Fix navigation header issues with modal pages * [MacOS] Fix MDP issues with resizing * [MacOS] Fix general dispose * [MacOS] Add a ViewControllerWrapper for NSSplitView * [MacOS] MDP renderer fix animation * [MacOS] Fix ListView selection bug * [MacOS] Fix rendering MDP Layout inside wrappers * [MacOS] Re write the MainToolbar handler * [MacOS] Don't use Sierra new extensions so we can run in stable channel * [MacOS] Another way to hide the toolbar (smarter i think) * [MacOS] Fix MDP bug and remove debug color * [Controls] Add HanselForms sample * [MacOS] Fix NRE WebviewRenderer * [MacOS] Fix uneven rows on ListView renderer * [MacOS] Fix NRE on load (can+t find the reason this happens) * [MacOS] Fix uneven rows * [MacOS] Fix header sizing on ListViewRenderer * [Controls] More stuff on HanselForms * [MacOS] Remove warning from ListViewRenderer * [MacOS] Fix PageRenderer bug double init * [MacOS] Don't calculate height if RowHeight is provided * [Controls] More Hanselforms stuff * [MacOS] Once again a new implementation for the NavigationBar, this time using a custom view to support BackgroundColor * [MacOS] Fix build * [MacOS] Refactoring AwesomeBar related controls * Fix build * [MacOS] NavigationBar update background and t test colors * [MacOS] Fix when we remove navigation so it works when the NavigationRenderer wasn't removed from the parent controller like in a TabbedPage * [MacOS] Add support for ListView grouping * [MacOS] Fix image extension method. * [MacOS] Add base Maps project * [MacOS] Export MapRenderer * [MacOS] Add pin click and geocoderbacked for Maps * [MacOS] Add extra binding project for API not in stable. * [MacOS] Add MacOS Maps lib * [MacOS]Fix build on alpha * [MacOS] Remove MacOS Maps extra binding * [UITest] Basic macOS setup * [UITest] Add MacOSApp wrapper implementation * [MacOS] Set AutomationID * [UITests] Add ActionSheetUITests to MacOS UITest * [MacOS] Fix bug on Picker * [UITests] Link basic uitest basefixture and related files * [MacOS] Fix pickers reuse * [UItests] Fix MacOS app path * [UITest] Ignore UItest for appearing on macOS for now * [UITest] Update macOS for 2.0.3 * [UITest] Refactor EnterText MacOS app * [UITest]Fix ViewQuery on MacOS * [UITest]Fix IsEnabled UItest on macOS * [UITest] Implement Enter, mark some tests inconclusive fix others * [MacOS] Implement Entry Completed event * [UITests] Fix UITest for IsVisible, ignore ToolbarItem test for now * [UITests] Fix ISVisible again add extra category * [Controls] Cleanup macOS gallery * [MacOS] Fix Assembly info * [Docs] Fix docs * Fix build * [Nuget] Fix nuspec * [Controls] Link files on MacOS * [Core] Update Forms stack before firing a event saying page was removed, possible breaking change * [MacOS] Implement RemovePage on NavigationPAgeRenderer * [UItest] Ignore some , implement back on MacOS UITest app * [MacOS] Add default back button name (needs to be translated) * [MacOS] Fix dispose * [UITest] Make 29257 work on MacOS * [MacOS] Rename stuff * [MacOS] More renaming and cleanup * [MacOS] Share implementations for iOS * [MacOS] Reuse more IOS extensions * [MacOS] Reuse FontExtensions * [MacOS] Share NativeViewWrapper related stuff * [MAcOS] Share event args and ExportRenderer * [MacOS] Share platform effect * [MacOS] Fix build * [Docs]Fixing docs * [MacOS] Fix ViewCell reuse * [Core] Support ListView CachingStrategy on MacOS * [MacOS] Fix issues with TextCell and ImageCell (we can’t set null to a NSControl value) * [MacOS] Fix MDP child sizing bug [UITest] Query marked by id and text * [MacOS] Comment test related with context actions * [MacOS] Implement missing stuff on ticker * [MacOS] Make sure VisualElemenTracker calls the ticker update * [UITests]Ignore context actions and not possible to test * [MacOS] Fix Grouping bug on Listview * [MacOS] Fix selection on Listview when using grouping * [MacOS] Update navbar when page is popped * [MacOS] Cleanup NavigationBar * [Controls] More info on exceptions * [MacOS] Fix bug animation pop modal * [MacOS] Bring back BackgroundColor of NavigationBar * [MacOS] Fix UITest animation delay * [MacOS] Treat warnings as errors * [MacOS] Center title on toolbar * [Core] Add Platform configuration specific for MacOS * [MacOS] Implement TabbedPage platform specific to handle TabItems on NavigationPage bar * [MacOS] Fix warning * [MacOS] Fix bug on SearchBar color * [MacOS]Fix build * [MacOS] remove extra dll from maps * [Docs] Update docs * [MacOS]Cleanup and refactoring * Revert "[MacOS] remove extra dll from maps" This reverts commit 73b948937001fea3f28449a963d0b94943e07aa0. * [MacOS] Fix wrong refactoring * [MacOS] dix formatting * [MacOS] Fix build * [MacOS] Fix bug on TabbedPageRenderer no title * [MacOS,UITest] Update packages * [MacOS ,UITest] Add delay when tapping something, and focus with double click * [MacOS,UITest] Ignore UITest, not possible to test with current version * [MacOS,UITest] Ignore test that uses Frame, UITest doesn’t return it * [MacOS] Fix bug when no title on toolbar items * [MacOS] Remove FormsNSView * [MacOS] Cleanup on dispose on MDP renderer * [MacOS] Different way to test leak of MDP, need to look at this again after * [MacOS] Update current page when source changes * [MacOS] More cleanup * [MacOS,UITest] Implement ClearText * [MacOS,UITest] ClearText doesn’t work for now on MacOS uitest * [MacOS] Make sure we show the previous page when popping a Modal * [MacOS] Fix issue with sizing the Header and visibility, remove for now header renderer reuse * [MacOS] Clean CustomNSTableView * [MacOS] Share LabelRenderer with iOS * [MacOS,UITest] Don’t try to scroll for the element * [MacOS] Share ResourcesProvider with iOS * [MAcoS] Share VisualElementPackager with iOS * [MacOS] Share ViewRenderer with iOS * [MacOS] Merge with VisualElementTracker from iOS * [MacOS] Merge with EventTracker from iOS * [MacOS] Merge with VisualElementRenderer of iOS * [MacOS] Make sure we always have a layer * [MacOS] Fix Tracker merge with iOS version * [MacOS] Fix bug with tabbed page on modal without navigation * [Core] Rever change on core * [Controls] Add missing image * [MacOS] Clear renderers before setting them MDP * [MacOS] Update tabbedPage ContainerArea * [Controls] Add Custom renderers tests * [MacOS] Fix ListViewRenderer * [MacOS,UITest] Refactoring, implement index * [MacOS] Make sure we don’t pass null to TextField string value * [MacOS] Support for multiple clicks in same selected item on NSTableView * [MacOS, UITest] Fix bug on Back because of refactoring * [MacOS,UITest] Ignore UITest because we’d-not have ScrollDownTo yet * [MacOS] Support Focus on EntryRenderer * [MacOS,UITest] Ignore more a couple of tests that we can’t test on UITest Desktop * [MacOS,UITest] MacOSApp looks for StaticText fields too * [MacOS, UITest] Fix EnterText for marked Entry * [MacOS] Fix index bug on TablevIewDataSource * [MacOS] Fix SelectedItem TableViewDataSource * [Nuget] Add Mac to Maps nuspec * [Nuget]Fix path * [Controls] Add basic FormsGallery sample * [macOS] Fixed Tab NSImage crash in TabbedPageRenderer (#705) * [macOS] Fixed Tab NSImage crash in TabbedPageRenderer * Coding Style * Coding Style * [MacOS] Fix previous merge with master * [MacOS] Possible simple fix for click on views overlapping * [UItest] Ignore this part of the test we can’t click on NSViews yet * [MacOS] Rename to IsOnViewCell * fix docs * [MacOS] Cleanup, Address feedback from Samantha’s review * [MacOS] Add ContextActions * [Controls] Remove FormsGalery for now * [Docs] Update docs * [MacOS] Implement ContextActions * [MacOS,UITests] Enable and support UITests of ContextActions
Diffstat (limited to 'Xamarin.Forms.Core.macOS.UITests')
-rw-r--r--Xamarin.Forms.Core.macOS.UITests/MacOSApp.cs702
-rw-r--r--Xamarin.Forms.Core.macOS.UITests/Properties/AssemblyInfo.cs26
-rw-r--r--Xamarin.Forms.Core.macOS.UITests/Xamarin.Forms.Core.macOS.UITests.csproj232
-rw-r--r--Xamarin.Forms.Core.macOS.UITests/packages.config10
4 files changed, 970 insertions, 0 deletions
diff --git a/Xamarin.Forms.Core.macOS.UITests/MacOSApp.cs b/Xamarin.Forms.Core.macOS.UITests/MacOSApp.cs
new file mode 100644
index 00000000..08c3118d
--- /dev/null
+++ b/Xamarin.Forms.Core.macOS.UITests/MacOSApp.cs
@@ -0,0 +1,702 @@
+using System;
+using System.IO;
+using System.Collections.Generic;
+using Xamarin.UITest;
+using Xamarin.UITest.Desktop;
+using Xamarin.UITest.Queries;
+using System.Linq;
+using System.Diagnostics;
+using System.Threading;
+using System.Drawing;
+
+namespace Xamarin.Forms.Core.macOS.UITests
+{
+ public static class MacOSAppExtensions
+ {
+ public static UITest.Queries.AppResult ToUITestResult(this UITest.Desktop.AppResult result)
+ {
+ return new UITest.Queries.AppResult
+ {
+ Id = result.Id ?? result.TestId,
+ Label = result.Label,
+ Text = result.Text ?? result.Value,
+ Enabled = result.Enabled,
+ Class = result.Class,
+ Rect = new UITest.Queries.AppRect
+ {
+ X = result.Rect.X,
+ Y = result.Rect.Y,
+ Width = result.Rect.Width,
+ Height = result.Rect.Height,
+ CenterX = result.Rect.CenterX,
+ CenterY = result.Rect.CenterY
+ }
+ };
+ }
+ }
+
+
+ public class MacOSApp : Xamarin.UITest.IApp
+ {
+ string _backButtonIdentifier = "NSBackButton";
+ static CocoaApp _cocoaApp;
+ public MacOSApp(CocoaApp app)
+ {
+ _cocoaApp = app;
+ }
+ public IDevice Device
+ {
+ get
+ {
+ return null;
+ }
+ }
+
+ public AppPrintHelper Print
+ {
+ get
+ {
+ return null;
+ }
+ }
+
+ public ITestServer TestServer
+ {
+ get
+ {
+ return null;
+ }
+ }
+
+ public void Back()
+ {
+ Tap(_backButtonIdentifier);
+ }
+
+ public void ClearText()
+ {
+ _cocoaApp.ClearText();
+ }
+
+ public void ClearText(string marked)
+ {
+ var textField = _cocoaApp.QueryById(marked).FirstOrDefault((arg) => arg.Class.Contains("SearchField") || arg.Class.Contains("TextField"));
+ ClearText(textField.Rect.CenterX, textField.Rect.CenterY);
+ }
+
+ public void ClearText(Func<AppQuery, AppWebQuery> query)
+ {
+
+ }
+
+ public void ClearText(Func<AppQuery, AppQuery> query)
+ {
+ var queryStr = query(new AppQuery(QueryPlatform.iOS)).ToString();
+
+ var isMarked = System.Text.RegularExpressions.Regex.IsMatch(queryStr, @"\bmarked\b");
+ if (isMarked)
+ {
+ var markedWord = System.Text.RegularExpressions.Regex.Split(queryStr, @"\bmarked\b:'");
+ var isAll = markedWord[0].Trim() == "*";
+ var marked = markedWord[1].Replace("'", "");
+ ClearText(marked);
+ }
+ }
+
+ public void DismissKeyboard()
+ {
+
+ }
+
+ public void DoubleTap(string marked)
+ {
+
+ }
+
+ public void DoubleTap(Func<AppQuery, AppQuery> query)
+ {
+
+ }
+
+ public void DoubleTapCoordinates(float x, float y)
+ {
+
+ }
+
+ public void DragAndDrop(string from, string to)
+ {
+
+ }
+
+ public void DragAndDrop(Func<AppQuery, AppQuery> from, Func<AppQuery, AppQuery> to)
+ {
+
+ }
+
+ public void DragCoordinates(float fromX, float fromY, float toX, float toY)
+ {
+
+ }
+
+ public void EnterText(string text)
+ {
+ var all = _cocoaApp.Query();
+ var staticText = _cocoaApp.QueryByType("StaticText");
+ var textFields = _cocoaApp.QueryByType("Textfield");
+ var textField = staticText.Union(textFields).FirstOrDefault();
+ EnterText(text, textField.Rect.CenterX, textField.Rect.CenterY);
+ }
+
+ public void EnterText(Func<AppQuery, AppWebQuery> query, string text)
+ {
+
+ }
+
+ public void EnterText(string marked, string text)
+ {
+ var textField = _cocoaApp.QueryById(marked).FirstOrDefault((arg) => arg.Class.Contains("SearchField") || arg.Class.Contains("TextField"));
+ EnterText(text, textField.Rect.CenterX, textField.Rect.CenterY);
+ }
+
+ public void EnterText(Func<AppQuery, AppQuery> query, string text)
+ {
+ string markedWord = string.Empty;
+ int indexMarked = 0;
+
+ if (ExtractInfo(query, out markedWord, out indexMarked))
+ EnterText(markedWord, indexMarked, text);
+ }
+
+ public UITest.Queries.AppResult[] Flash(string marked)
+ {
+ var resulr = new List<Xamarin.UITest.Queries.AppResult>();
+ return resulr.ToArray();
+ }
+
+ public UITest.Queries.AppResult[] Flash(Func<AppQuery, AppQuery> query = null)
+ {
+ var resulr = new List<Xamarin.UITest.Queries.AppResult>();
+ return resulr.ToArray();
+ }
+
+ public object Invoke(string methodName, object[] arguments)
+ {
+ return null;
+ }
+
+ public object Invoke(string methodName, object argument = null)
+ {
+ return null;
+ }
+
+ public void PinchToZoomIn(string marked, TimeSpan? duration = default(TimeSpan?))
+ {
+
+ }
+
+ public void PinchToZoomIn(Func<AppQuery, AppQuery> query, TimeSpan? duration = default(TimeSpan?))
+ {
+
+ }
+
+ public void PinchToZoomInCoordinates(float x, float y, TimeSpan? duration)
+ {
+
+ }
+
+ public void PinchToZoomOut(string marked, TimeSpan? duration = default(TimeSpan?))
+ {
+
+ }
+
+ public void PinchToZoomOut(Func<AppQuery, AppQuery> query, TimeSpan? duration = default(TimeSpan?))
+ {
+
+ }
+
+ public void PinchToZoomOutCoordinates(float x, float y, TimeSpan? duration)
+ {
+
+ }
+
+ public void PressEnter()
+ {
+ _cocoaApp.SendKey(13, KeyModifier.None);
+ }
+
+ public void PressVolumeDown()
+ {
+
+ }
+
+ public void PressVolumeUp()
+ {
+
+ }
+
+ public AppWebResult[] Query(Func<Xamarin.UITest.Queries.AppQuery, Xamarin.UITest.Queries.AppWebQuery> query)
+ {
+ var resulr = new List<Xamarin.UITest.Queries.AppWebResult>();
+ return resulr.ToArray();
+ }
+
+ public string[] Query(Func<Xamarin.UITest.Queries.AppQuery, Xamarin.UITest.Queries.InvokeJSAppQuery> query)
+ {
+ return new List<string>().ToArray();
+ }
+
+ public UITest.Queries.AppResult[] Query(string marked)
+ {
+ var results = new List<Xamarin.UITest.Queries.AppResult>();
+ var allResults = _cocoaApp.Query();
+ var allResultsById = _cocoaApp.QueryById(marked);
+ foreach (var result in allResultsById)
+ results.Add(result.ToUITestResult());
+ var allResultsByText = _cocoaApp.QueryByText(marked);
+ foreach (var result in allResultsByText)
+ results.Add(result.ToUITestResult());
+ return results.ToArray();
+ }
+
+ public UITest.Queries.AppResult[] Query(Func<UITest.Queries.AppQuery, UITest.Queries.AppQuery> query = null)
+ {
+ var queryStr = query(new AppQuery(QueryPlatform.iOS)).ToString();
+ var results = new List<Xamarin.UITest.Queries.AppResult>();
+ var isMarked = System.Text.RegularExpressions.Regex.IsMatch(queryStr, @"\bmarked\b");
+ var isText = System.Text.RegularExpressions.Regex.IsMatch(queryStr, @"\btext\b");
+ if (isMarked)
+ {
+ var markedWords = System.Text.RegularExpressions.Regex.Split(queryStr, @"\bmarked\b:'");
+ var isAll = markedWords[0].Trim() == "*";
+ var markedWord = markedWords[1].Remove(markedWords[1].Length - 1).Trim();
+ return Query(markedWord);
+ }
+ if (isText)
+ {
+ var textWords = System.Text.RegularExpressions.Regex.Split(queryStr, @"\btext\b:'");
+ var isAll = textWords[0].Trim() == "*";
+ var textWord = textWords[1].Remove(textWords[1].Length - 1).Trim();
+ return Query(textWord);
+ }
+ else if (queryStr.Contains("* index:0"))
+ {
+ var allREsults = _cocoaApp.Query();
+ var result = allREsults[0].Children[0];
+ results.Add(result.ToUITestResult());
+ }
+ else if (queryStr.Contains("* index:7"))
+ {
+ var allREsults = _cocoaApp.Query();
+ var result = allREsults[0].Children[0].Children[0].Children[1];
+ results.Add(result.ToUITestResult());
+ }
+
+ return results.ToArray();
+ }
+
+ public T[] Query<T>(Func<UITest.Queries.AppQuery, UITest.Queries.AppTypedSelector<T>> query)
+ {
+
+ var results = new List<T>();
+ var queryStr = query(new AppQuery(QueryPlatform.iOS)).ToString();
+ var isMarked = System.Text.RegularExpressions.Regex.IsMatch(queryStr, @"\bmarked\b");
+ if (isMarked)
+ {
+ var markedWords = System.Text.RegularExpressions.Regex.Split(queryStr, @"\bmarked\b:'");
+ var isAll = markedWords[0].Trim() == "*";
+ var markedWord = markedWords[1].Replace("'", "");
+ var ss = Query(markedWord);
+
+ }
+ else if (queryStr.Contains("* index:0"))
+ {
+
+ var allREsults = _cocoaApp.Query();
+ var result = allREsults[0].Children[0];
+ // results.Add(result.ToUITestResult());
+ }
+ else if (queryStr.Contains("* index:7"))
+ {
+ var allREsults = _cocoaApp.Query();
+ var result = allREsults[0].Children[0].Children[0].Children[1];
+ // results.Add(result.ToUITestResult());
+ }
+
+ return results.ToArray();
+ }
+
+ public void Repl()
+ {
+
+ }
+
+ public FileInfo Screenshot(string title)
+ {
+ return null;
+ }
+
+ public void ScrollDown(string withinMarked, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void ScrollDown(Func<AppQuery, AppQuery> withinQuery = null, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void ScrollDownTo(Func<AppQuery, AppQuery> toQuery, Func<AppQuery, AppQuery> withinQuery = null, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true, TimeSpan? timeout = default(TimeSpan?))
+ {
+
+ }
+
+ public void ScrollDownTo(Func<AppQuery, AppWebQuery> toQuery, Func<AppQuery, AppQuery> withinQuery = null, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true, TimeSpan? timeout = default(TimeSpan?))
+ {
+
+ }
+
+ public void ScrollDownTo(Func<AppQuery, AppWebQuery> toQuery, string withinMarked, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true, TimeSpan? timeout = default(TimeSpan?))
+ {
+
+ }
+
+ public void ScrollDownTo(string toMarked, string withinMarked = null, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true, TimeSpan? timeout = default(TimeSpan?))
+ {
+
+ }
+
+ public void ScrollTo(string toMarked, string withinMarked = null, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true, TimeSpan? timeout = default(TimeSpan?))
+ {
+
+ }
+
+ public void ScrollUp(string withinMarked, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void ScrollUp(Func<AppQuery, AppQuery> query = null, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void ScrollUpTo(Func<AppQuery, AppWebQuery> toQuery, string withinMarked, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true, TimeSpan? timeout = default(TimeSpan?))
+ {
+
+ }
+
+ public void ScrollUpTo(Func<AppQuery, AppQuery> toQuery, Func<AppQuery, AppQuery> withinQuery = null, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true, TimeSpan? timeout = default(TimeSpan?))
+ {
+
+ }
+
+ public void ScrollUpTo(Func<AppQuery, AppWebQuery> toQuery, Func<AppQuery, AppQuery> withinQuery = null, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true, TimeSpan? timeout = default(TimeSpan?))
+ {
+
+ }
+
+ public void ScrollUpTo(string toMarked, string withinMarked = null, ScrollStrategy strategy = ScrollStrategy.Auto, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true, TimeSpan? timeout = default(TimeSpan?))
+ {
+
+ }
+
+ public void SetOrientationLandscape()
+ {
+
+ }
+
+ public void SetOrientationPortrait()
+ {
+
+ }
+
+ public void SetSliderValue(Func<AppQuery, AppQuery> query, double value)
+ {
+
+ }
+
+ public void SetSliderValue(string marked, double value)
+ {
+
+ }
+
+ public void SwipeLeft()
+ {
+
+ }
+
+ public void SwipeLeftToRight(double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void SwipeLeftToRight(Func<AppQuery, AppQuery> query, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void SwipeLeftToRight(Func<AppQuery, AppWebQuery> query, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void SwipeLeftToRight(string marked, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void SwipeRight()
+ {
+
+ }
+
+ public void SwipeRightToLeft(double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void SwipeRightToLeft(Func<AppQuery, AppWebQuery> query, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+ throw new NotImplementedException();
+ }
+
+ public void SwipeRightToLeft(Func<AppQuery, AppQuery> query, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void SwipeRightToLeft(string marked, double swipePercentage = 0.67, int swipeSpeed = 500, bool withInertia = true)
+ {
+
+ }
+
+ public void Tap(Func<AppQuery, AppWebQuery> query)
+ {
+
+ }
+
+ public void Tap(string marked)
+ {
+ Tap(marked, 0);
+ }
+
+ public void Tap(Func<AppQuery, AppQuery> query)
+ {
+ string markedWord = string.Empty;
+ int indexMarked = 0;
+
+ if (ExtractInfo(query, out markedWord, out indexMarked))
+ Tap(markedWord, indexMarked);
+ }
+
+ public void TapCoordinates(float x, float y)
+ {
+
+ }
+
+ public void TouchAndHold(string marked)
+ {
+ TouchAndHold(marked, 0);
+ }
+
+ void TouchAndHold(string marked, int index)
+ {
+ var safeIndex = Math.Max(index, 0);
+ var queryById = _cocoaApp.QueryById(marked.Trim())[safeIndex];
+ TouchAndHoldCoordinates(queryById.Rect.CenterX, queryById.Rect.CenterY);
+
+ }
+
+ public void TouchAndHold(Func<AppQuery, AppQuery> query)
+ {
+ string markedWord = string.Empty;
+ int indexMarked = 0;
+
+ if (ExtractInfo(query, out markedWord, out indexMarked))
+ TouchAndHold(markedWord, indexMarked);
+ }
+
+ public void TouchAndHoldCoordinates(float x, float y)
+ {
+ _cocoaApp.RightClick(x, y);
+ Thread.Sleep(1000);
+ }
+
+ public void WaitFor(Func<bool> predicate, string timeoutMessage = "Timed out waiting...", TimeSpan? timeout = default(TimeSpan?), TimeSpan? retryFrequency = default(TimeSpan?), TimeSpan? postTimeout = default(TimeSpan?))
+ {
+
+ }
+
+ public AppWebResult[] WaitForElement(Func<AppQuery, AppWebQuery> query, string timeoutMessage = "Timed out waiting for element...", TimeSpan? timeout = default(TimeSpan?), TimeSpan? retryFrequency = default(TimeSpan?), TimeSpan? postTimeout = default(TimeSpan?))
+ {
+ var resulr = new List<Xamarin.UITest.Queries.AppWebResult>();
+ return resulr.ToArray();
+ }
+
+ public UITest.Queries.AppResult[] WaitForElement(string marked, string timeoutMessage = "Timed out waiting for element...", TimeSpan? timeout = default(TimeSpan?), TimeSpan? retryFrequency = default(TimeSpan?), TimeSpan? postTimeout = default(TimeSpan?))
+ {
+ var results = new List<Xamarin.UITest.Queries.AppResult>();
+
+ var queryById = _cocoaApp.QueryById(marked);
+ foreach (var res in queryById)
+ {
+ results.Add(res.ToUITestResult());
+ }
+ Stopwatch s = new Stopwatch();
+ s.Start();
+ bool foundElement = false;
+ while (s.Elapsed < timeout && !foundElement)
+ {
+ var allResultsById = _cocoaApp.QueryById(marked);
+ foreach (var res in queryById)
+ {
+ results.Add(res.ToUITestResult());
+ }
+ foundElement = results.Count > 0;
+ System.Diagnostics.Debug.WriteLine(foundElement);
+ }
+ s.Stop();
+
+ return results.ToArray();
+ }
+
+ public UITest.Queries.AppResult[] WaitForElement(Func<AppQuery, AppQuery> query, string timeoutMessage = "Timed out waiting for element...", TimeSpan? timeout = default(TimeSpan?), TimeSpan? retryFrequency = default(TimeSpan?), TimeSpan? postTimeout = default(TimeSpan?))
+ {
+ var queryStr = query(new AppQuery(QueryPlatform.iOS)).ToString();
+ var isMarked = System.Text.RegularExpressions.Regex.IsMatch(queryStr, @"\bmarked\b");
+ if (isMarked)
+ {
+ var markedWords = System.Text.RegularExpressions.Regex.Split(queryStr, @"\bmarked\b:'");
+ var isAll = markedWords[0].Trim() == "*";
+ var markedWord = markedWords[1].Replace("'", "").Trim();
+ return WaitForElement(markedWord, timeoutMessage, timeout, retryFrequency, postTimeout);
+ }
+ return new List<Xamarin.UITest.Queries.AppResult>().ToArray();
+ }
+
+ public void WaitForNoElement(Func<AppQuery, AppWebQuery> query, string timeoutMessage = "Timed out waiting for no element...", TimeSpan? timeout = default(TimeSpan?), TimeSpan? retryFrequency = default(TimeSpan?), TimeSpan? postTimeout = default(TimeSpan?))
+ {
+
+
+ }
+
+ public void WaitForNoElement(string marked, string timeoutMessage = "Timed out waiting for no element...", TimeSpan? timeout = default(TimeSpan?), TimeSpan? retryFrequency = default(TimeSpan?), TimeSpan? postTimeout = default(TimeSpan?))
+ {
+ Stopwatch s = new Stopwatch();
+ s.Start();
+ bool noElement = false;
+ while (s.Elapsed < timeout && !noElement)
+ {
+ var allResultsById = _cocoaApp.QueryById(marked);
+ noElement = allResultsById.Length == 0;
+ System.Diagnostics.Debug.WriteLine(noElement);
+ }
+ s.Stop();
+ if (s.Elapsed < timeout && !noElement)
+ throw (new Exception(timeoutMessage));
+
+ }
+
+ public void WaitForNoElement(Func<AppQuery, AppQuery> query, string timeoutMessage = "Timed out waiting for no element...", TimeSpan? timeout = default(TimeSpan?), TimeSpan? retryFrequency = default(TimeSpan?), TimeSpan? postTimeout = default(TimeSpan?))
+ {
+ var queryStr = query(new AppQuery(QueryPlatform.iOS)).ToString();
+ var isMarked = System.Text.RegularExpressions.Regex.IsMatch(queryStr, @"\bmarked\b");
+ if (isMarked)
+ {
+ var markedWords = System.Text.RegularExpressions.Regex.Split(queryStr, @"\bmarked\b:'");
+ var isAll = markedWords[0].Trim() == "*";
+ var markedWord = markedWords[1].Replace("'", "").Trim();
+ WaitForNoElement(markedWord, timeoutMessage, timeout, retryFrequency, postTimeout);
+ }
+ }
+
+ static bool ExtractInfo(Func<AppQuery, AppQuery> query, out string markedWord, out int indexMarked)
+ {
+ indexMarked = 0;
+ markedWord = string.Empty;
+ var isSuccess = false;
+ var queryStr = query(new AppQuery(QueryPlatform.iOS)).ToString();
+ var isIndex = System.Text.RegularExpressions.Regex.IsMatch(queryStr, @"\bindex\b");
+ if (isIndex)
+ {
+ var indexWords = System.Text.RegularExpressions.Regex.Split(queryStr, @"\bindex\b:");
+ var indexWord = indexWords[1];
+ int.TryParse(indexWord, out indexMarked);
+ queryStr = indexWords[0].Trim();
+ }
+ var isMarked = System.Text.RegularExpressions.Regex.IsMatch(queryStr, @"\bmarked\b");
+ if (isMarked)
+ {
+ var markedWords = System.Text.RegularExpressions.Regex.Split(queryStr, @"\bmarked\b:'");
+ var isAll = markedWords[0].Trim() == "*";
+ markedWord = markedWords[1].Replace("'", "").Trim();
+ isSuccess = true;
+
+ }
+ var isText = System.Text.RegularExpressions.Regex.IsMatch(queryStr, @"\btext\b");
+ if (isText)
+ {
+ var markedWords = System.Text.RegularExpressions.Regex.Split(queryStr, @"\btext\b:'");
+ var isAll = markedWords[0].Trim() == "*";
+ markedWord = markedWords[1].Replace("'", "").Trim();
+ isSuccess = true;
+ }
+ return isSuccess;
+ }
+
+ void Tap(string marked, int index)
+ {
+ var safeIndex = Math.Max(index, 0);
+ var queryById = _cocoaApp.QueryById(marked.Trim())[safeIndex];
+ _cocoaApp.Click(queryById.Rect.CenterX, queryById.Rect.CenterY);
+ Thread.Sleep(1000);
+ }
+
+ static void EnterText(string marked, int index, string text)
+ {
+ UITest.Desktop.AppResult textField = null;
+ var safeIndex = Math.Max(index, 0);
+ var textFields = _cocoaApp.QueryById(marked).Where((arg) => arg.Class.Contains("SearchField") || arg.Class.Contains("TextField"));
+ if (textFields.Count() > 0)
+ {
+ textField = textFields.ElementAt(safeIndex);
+ }
+ else
+ {
+ var markedField = _cocoaApp.QueryById(marked);
+ if (markedField.Length > 0)
+ {
+ textField = markedField[0];
+ }
+ else
+ {
+
+ var allTextFields = _cocoaApp.QueryByType("TextField");
+ textField = allTextFields[0];
+ }
+ }
+
+ if (textField != null)
+ EnterText(text, textField.Rect.CenterX, textField.Rect.CenterY);
+
+ }
+
+ static void EnterText(string text, float x, float y)
+ {
+ _cocoaApp.Click(x, y);
+ _cocoaApp.Click(x, y);
+ Thread.Sleep(500);
+ _cocoaApp.EnterText(text);
+ Thread.Sleep(500);
+ }
+
+ static void ClearText(float x, float y)
+ {
+ _cocoaApp.Click(x, y);
+ _cocoaApp.Click(x, y);
+ Thread.Sleep(500);
+ _cocoaApp.ClearText();
+ Thread.Sleep(500);
+ }
+ }
+}
diff --git a/Xamarin.Forms.Core.macOS.UITests/Properties/AssemblyInfo.cs b/Xamarin.Forms.Core.macOS.UITests/Properties/AssemblyInfo.cs
new file mode 100644
index 00000000..ae37f172
--- /dev/null
+++ b/Xamarin.Forms.Core.macOS.UITests/Properties/AssemblyInfo.cs
@@ -0,0 +1,26 @@
+using System.Reflection;
+using System.Runtime.CompilerServices;
+
+// Information about this assembly is defined by the following attributes.
+// Change them to the values specific to your project.
+
+[assembly: AssemblyTitle("Xamarin.Forms.Core.macOS.UITests")]
+[assembly: AssemblyDescription("")]
+[assembly: AssemblyConfiguration("")]
+[assembly: AssemblyCompany("")]
+[assembly: AssemblyProduct("")]
+[assembly: AssemblyCopyright("")]
+[assembly: AssemblyTrademark("")]
+[assembly: AssemblyCulture("")]
+
+// The assembly version has the format "{Major}.{Minor}.{Build}.{Revision}".
+// The form "{Major}.{Minor}.*" will automatically update the build and revision,
+// and "{Major}.{Minor}.{Build}.*" will update just the revision.
+
+[assembly: AssemblyVersion("1.0.*")]
+
+// The following attributes are used to specify the signing key for the assembly,
+// if desired. See the Mono documentation for more information about signing.
+
+//[assembly: AssemblyDelaySign(false)]
+//[assembly: AssemblyKeyFile("")]
diff --git a/Xamarin.Forms.Core.macOS.UITests/Xamarin.Forms.Core.macOS.UITests.csproj b/Xamarin.Forms.Core.macOS.UITests/Xamarin.Forms.Core.macOS.UITests.csproj
new file mode 100644
index 00000000..e70ae03b
--- /dev/null
+++ b/Xamarin.Forms.Core.macOS.UITests/Xamarin.Forms.Core.macOS.UITests.csproj
@@ -0,0 +1,232 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+ <PropertyGroup>
+ <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
+ <Platform Condition=" '$(Platform)' == '' ">AnyCPU</Platform>
+ <ProjectGuid>{9DB0CABB-24CC-4538-88EC-6E0A0FE40248}</ProjectGuid>
+ <OutputType>Library</OutputType>
+ <RootNamespace>Xamarin.Forms.Core.macOS.UITests</RootNamespace>
+ <AssemblyName>Xamarin.Forms.Core.macOS.UITests</AssemblyName>
+ <TargetFrameworkVersion>v4.5</TargetFrameworkVersion>
+ </PropertyGroup>
+ <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
+ <DebugSymbols>true</DebugSymbols>
+ <DebugType>full</DebugType>
+ <Optimize>false</Optimize>
+ <OutputPath>bin\Debug</OutputPath>
+ <DefineConstants>DEBUG;__MACOS__;UITEST</DefineConstants>
+ <ErrorReport>prompt</ErrorReport>
+ <WarningLevel>4</WarningLevel>
+ <ConsolePause>false</ConsolePause>
+ </PropertyGroup>
+ <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
+ <Optimize>true</Optimize>
+ <OutputPath>bin\Release</OutputPath>
+ <ErrorReport>prompt</ErrorReport>
+ <WarningLevel>4</WarningLevel>
+ <ConsolePause>false</ConsolePause>
+ </PropertyGroup>
+ <ItemGroup>
+ <Reference Include="System" />
+ <Reference Include="Newtonsoft.Json">
+ <HintPath>..\packages\Newtonsoft.Json.9.0.1\lib\net45\Newtonsoft.Json.dll</HintPath>
+ </Reference>
+ <Reference Include="ServiceStack.Interfaces">
+ <HintPath>..\packages\ServiceStack.Interfaces.4.5.4\lib\portable-wp80+sl5+net45+win8+wpa81+monotouch+monoandroid+xamarin.ios10\ServiceStack.Interfaces.dll</HintPath>
+ </Reference>
+ <Reference Include="ServiceStack.Text">
+ <HintPath>..\packages\ServiceStack.Text.4.5.4\lib\net45\ServiceStack.Text.dll</HintPath>
+ </Reference>
+ <Reference Include="ServiceStack.Client">
+ <HintPath>..\packages\ServiceStack.Client.4.5.4\lib\net45\ServiceStack.Client.dll</HintPath>
+ </Reference>
+ <Reference Include="Xamarin.UITest.Desktop">
+ <HintPath>..\packages\Xamarin.UITest.Desktop.0.0.7\lib\net45\Xamarin.UITest.Desktop.dll</HintPath>
+ </Reference>
+ <Reference Include="System.ComponentModel.Composition" />
+ <Reference Include="System.Core" />
+ <Reference Include="System.Drawing" />
+ <Reference Include="System.IO.Compression" />
+ <Reference Include="System.Net.Http" />
+ <Reference Include="System.Numerics" />
+ <Reference Include="System.Reactive.Core" />
+ <Reference Include="System.Reactive.Interfaces" />
+ <Reference Include="System.Reactive.Linq" />
+ <Reference Include="System.Reactive.PlatformServices" />
+ <Reference Include="System.Reactive.Windows.Threading" />
+ <Reference Include="System.Runtime.Serialization" />
+ <Reference Include="System.Windows" />
+ <Reference Include="System.Xml" />
+ <Reference Include="System.Xml.Linq" />
+ <Reference Include="WindowsBase" />
+ <Reference Include="nunit.framework">
+ <HintPath>..\packages\NUnit.2.6.4\lib\nunit.framework.dll</HintPath>
+ </Reference>
+ <Reference Include="Xamarin.UITest">
+ <HintPath>..\packages\Xamarin.UITest.2.0.5\lib\Xamarin.UITest.dll</HintPath>
+ </Reference>
+ </ItemGroup>
+ <ItemGroup>
+ <Compile Include="Properties\AssemblyInfo.cs" />
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\ActionSheetUITests.cs">
+ <Link>Tests\ActionSheetUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\BaseTestFixture.cs">
+ <Link>BaseTestFixture.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\UITestCategories.cs">
+ <Link>UITestCategories.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Queries.cs">
+ <Link>Queries.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Utilities\AppExtensions.cs">
+ <Link>Utilities\AppExtensions.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\PlatformQueries.cs">
+ <Link>PlatformQueries.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Utilities\Drag.cs">
+ <Link>Utilities\Drag.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Utilities\Gestures.cs">
+ <Link>Utilities\Gestures.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Utilities\UITestCustomExceptions.cs">
+ <Link>Utilities\UITestCustomExceptions.cs</Link>
+ </Compile>
+ <Compile Include="MacOSApp.cs" />
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\ActivityIndicatorUITests.cs">
+ <Link>Tests\ActivityIndicatorUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\ViewUITests.cs">
+ <Link>Tests\ViewUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Remotes\BaseViewContainerRemote.cs">
+ <Link>Remotes\BaseViewContainerRemote.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Remotes\EventViewContainerRemote.cs">
+ <Link>Remotes\EventViewContainerRemote.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Remotes\LayeredViewContainerRemote.cs">
+ <Link>Remotes\LayeredViewContainerRemote.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Remotes\StateViewContainerRemote.cs">
+ <Link>Remotes\StateViewContainerRemote.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Remotes\ViewContainerRemote.cs">
+ <Link>Remotes\ViewContainerRemote.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Utilities\ViewInspector.cs">
+ <Link>Utilities\ViewInspector.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Utilities\Logger.cs">
+ <Link>Utilities\Logger.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Utilities\NumericExtensions.cs">
+ <Link>Utilities\NumericExtensions.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Utilities\ParsingUtils.cs">
+ <Link>Utilities\ParsingUtils.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\AppearingUITests.cs">
+ <Link>Tests\AppearingUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\AutomationIDUITests.cs">
+ <Link>Tests\AutomationIDUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\BoxViewUITests.cs">
+ <Link>Tests\BoxViewUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\ButtonUITests.cs">
+ <Link>Tests\ButtonUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\ContextActionsUITests.cs">
+ <Link>Tests\ContextActionsUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\DatePickerUITests.cs">
+ <Link>Tests\DatePickerUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\DisplayAlertUITests.cs">
+ <Link>Tests\DisplayAlertUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\EditorUITests.cs">
+ <Link>Tests\EditorUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\EntryUITests.cs">
+ <Link>Tests\EntryUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\FrameUITests.cs">
+ <Link>Tests\FrameUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\ImageUITests.cs">
+ <Link>Tests\ImageUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\LabelUITests.cs">
+ <Link>Tests\LabelUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\Legacy-CellsUITests.cs">
+ <Link>Tests\Legacy-CellsUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\Legacy-UnevenListTests.cs">
+ <Link>Tests\Legacy-UnevenListTests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\PickerUITests.cs">
+ <Link>Tests\PickerUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\ProgressBarUITests.cs">
+ <Link>Tests\ProgressBarUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\RootGalleryUITests.cs">
+ <Link>Tests\RootGalleryUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\ScrollViewUITests.cs">
+ <Link>Tests\ScrollViewUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\SearchBarUITests.cs">
+ <Link>Tests\SearchBarUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\SliderUITests.cs">
+ <Link>Tests\SliderUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\StepperUITests.cs">
+ <Link>Tests\StepperUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\SwitchUITests.cs">
+ <Link>Tests\SwitchUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\TimePickerUITests.cs">
+ <Link>Tests\TimePickerUITests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\ToolbarItemTests.cs">
+ <Link>Tests\ToolbarItemTests.cs</Link>
+ </Compile>
+ <Compile Include="..\Xamarin.Forms.Core.iOS.UITests\Tests\WebViewUITests.cs">
+ <Link>Tests\WebViewUITests.cs</Link>
+ </Compile>
+ </ItemGroup>
+ <ItemGroup>
+ <None Include="packages.config" />
+ </ItemGroup>
+ <ItemGroup>
+ <Folder Include="Tests\" />
+ <Folder Include="Utilities\" />
+ </ItemGroup>
+ <ItemGroup>
+ <ProjectReference Include="..\Xamarin.Forms.CustomAttributes\Xamarin.Forms.CustomAttributes.csproj">
+ <Project>{4DCD0420-1168-4B77-86DB-6196EE4BD491}</Project>
+ <Name>Xamarin.Forms.CustomAttributes</Name>
+ </ProjectReference>
+ <ProjectReference Include="..\Xamarin.Forms.Core\Xamarin.Forms.Core.csproj">
+ <Project>{57B8B73D-C3B5-4C42-869E-7B2F17D354AC}</Project>
+ <Name>Xamarin.Forms.Core</Name>
+ </ProjectReference>
+ <ProjectReference Include="..\Xamarin.Forms.Maps\Xamarin.Forms.Maps.csproj">
+ <Project>{7D13BAC2-C6A4-416A-B07E-C169B199E52B}</Project>
+ <Name>Xamarin.Forms.Maps</Name>
+ </ProjectReference>
+ </ItemGroup>
+ <Import Project="..\Xamarin.Forms.Controls.Issues\Xamarin.Forms.Controls.Issues.Shared\Xamarin.Forms.Controls.Issues.Shared.projitems" Label="Shared" Condition="Exists('..\Xamarin.Forms.Controls.Issues\Xamarin.Forms.Controls.Issues.Shared\Xamarin.Forms.Controls.Issues.Shared.projitems')" />
+ <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
+ <Import Project="..\packages\Xamarin.UITest.Desktop.0.0.7\build\Xamarin.UITest.Desktop.targets" Condition="Exists('..\packages\Xamarin.UITest.Desktop.0.0.7\build\Xamarin.UITest.Desktop.targets')" />
+</Project> \ No newline at end of file
diff --git a/Xamarin.Forms.Core.macOS.UITests/packages.config b/Xamarin.Forms.Core.macOS.UITests/packages.config
new file mode 100644
index 00000000..49c66041
--- /dev/null
+++ b/Xamarin.Forms.Core.macOS.UITests/packages.config
@@ -0,0 +1,10 @@
+<?xml version="1.0" encoding="utf-8"?>
+<packages>
+ <package id="Newtonsoft.Json" version="9.0.1" targetFramework="net45" />
+ <package id="NUnit" version="2.6.4" targetFramework="net45" />
+ <package id="ServiceStack.Client" version="4.5.4" targetFramework="net45" />
+ <package id="ServiceStack.Interfaces" version="4.5.4" targetFramework="net45" />
+ <package id="ServiceStack.Text" version="4.5.4" targetFramework="net45" />
+ <package id="Xamarin.UITest" version="2.0.5" targetFramework="net45" />
+ <package id="Xamarin.UITest.Desktop" version="0.0.7" targetFramework="net45" />
+</packages> \ No newline at end of file