From 3809dd0f538000e549d97efcfce4fbfb9a393bb3 Mon Sep 17 00:00:00 2001 From: Roemer Date: Tue, 12 Jan 2016 16:00:43 +0100 Subject: [PATCH 1/3] Reworked Configuration --- .../Wpf/WpfTodo.UITests/TodoAppTests.cs | 2 +- .../ReportingAppXmlConfiguration.cs | 32 --- .../Configuration/ReportingConfiguration.cs | 24 +- .../Domain/SubFlow.cs | 2 +- .../Domain/SubFlows.cs | 2 +- .../TestStack.White.Reporting.csproj | 5 +- .../AppScreen.cs | 2 +- .../RepositoryAppXmlConfiguration.cs | 48 ---- .../Configuration/RepositoryConfiguration.cs | 43 +++- .../EntityMapping/Entity.cs | 2 +- .../ScreenFlow/WorkFlow.cs | 2 +- .../Services/ExecutionHistory.cs | 2 +- .../Services/ServiceExecution.cs | 2 +- .../Services/WhiteExecution.cs | 2 +- .../Sessions/WorkConfiguration.cs | 2 +- .../TestStack.White.ScreenObjects.csproj | 2 +- .../RawAutomationElementFinderTests.cs | 2 +- .../ControlTests/ButtonTests.cs | 2 +- .../ListControls/ComboBoxTests.cs | 6 +- .../ListControls/DataBoundComboBoxTests.cs | 4 +- .../ListControls/ListBoxWithScrollBarTests.cs | 2 +- .../ControlTests/PropertyGridTests.cs | 6 +- .../WindowStripControls/StatusStripTests.cs | 2 +- .../SilverlightTestConfiguration.cs | 2 +- .../MessageBoxTests.cs | 2 +- .../ModalWindowTests.cs | 2 +- .../WhiteUITestBase.cs | 4 +- src/TestStack.White.UITests/WindowTests.cs | 8 +- .../SilverlightTestFixture.cs | 2 +- .../BrowserWindow.cs | 5 +- .../Config/WebBrowserAppXmlConfiguration.cs | 31 --- .../Config/WebBrowserConfiguration.cs | 7 - src/TestStack.White.WebBrowser/Firefox.cs | 4 +- .../TestStack.White.WebBrowser.csproj | 4 +- src/TestStack.White/Application.cs | 6 +- .../DescendantFinderFactory.cs | 2 +- .../RawAutomationElementFinder.cs | 6 +- .../Configuration/ConfigurationExtensions.cs | 40 ---- .../Configuration/CoreAppXmlConfiguration.cs | 206 ------------------ .../Configuration/ICoreConfiguration.cs | 47 ---- .../Configuration/IUIItemIdConfiguration.cs | 27 --- .../UIItemIdAppXmlConfiguration.cs | 133 ----------- src/TestStack.White/Constants.cs | 2 +- src/TestStack.White/Debug.cs | 2 +- .../Drawing/ScreenRectangle.cs | 2 +- .../Factory/ChildWindowFactory.cs | 3 +- .../Factory/PrimaryUIItemFactory.cs | 3 +- src/TestStack.White/Factory/ToolTipFinder.cs | 3 +- src/TestStack.White/Factory/WindowFactory.cs | 7 +- src/TestStack.White/InputDevices/Keyboard.cs | 4 +- src/TestStack.White/InputDevices/Mouse.cs | 8 +- .../Interceptors/CoreInterceptor.cs | 4 +- .../Recording/SafeAutomationEventHandler.cs | 2 +- .../ScreenMap/WindowItemsMap.cs | 4 +- src/TestStack.White/Sessions/WindowSession.cs | 2 +- .../SystemExtensions/IntExtensions.cs | 12 + src/TestStack.White/TestStack.White.csproj | 14 +- src/TestStack.White/UIA/AutomationElementX.cs | 2 +- .../UIItems/Actions/ProcessActionListener.cs | 2 +- src/TestStack.White/UIItems/DateTimePicker.cs | 2 +- .../UIItems/ListBoxItems/ComboBox.cs | 2 +- .../UIItems/ListBoxItems/ListItem.cs | 2 +- ...lverlightComboBoxVerticalSpanCalculator.cs | 2 +- .../WPFComboBoxVerticalSpanCalculator.cs | 2 +- .../ListViewItems/SuggestionListView.cs | 3 +- .../UIItems/MenuItems/Menus.cs | 3 +- .../UIItems/Scrolling/ScreenItem.cs | 7 +- .../UIItems/Scrolling/ScrollBar.cs | 3 +- .../UIItems/Scrolling/ScrollBars.cs | 4 +- .../UIItems/TableItems/Table.cs | 2 +- .../UIItems/TableItems/TableCell.cs | 2 +- .../UIItems/TableItems/TableColumns.cs | 2 +- .../UIItems/TableItems/TableHeader.cs | 2 +- .../UIItems/TableItems/TableScrollBars.cs | 4 +- .../UIItems/TooltipSafeMouse.cs | 4 +- src/TestStack.White/UIItems/UIItem.cs | 4 +- .../UIItems/UIItemCollection.cs | 2 +- .../UIItems/UIItemContainer.cs | 30 +-- .../UIItems/WindowItems/Window.cs | 13 +- src/TestStack.White/Utility/Retry.cs | 9 +- 80 files changed, 213 insertions(+), 703 deletions(-) delete mode 100644 src/TestStack.White.Reporting/Configuration/ReportingAppXmlConfiguration.cs delete mode 100644 src/TestStack.White.ScreenObjects/Configuration/RepositoryAppXmlConfiguration.cs delete mode 100644 src/TestStack.White.WebBrowser/Config/WebBrowserAppXmlConfiguration.cs delete mode 100644 src/TestStack.White.WebBrowser/Config/WebBrowserConfiguration.cs delete mode 100644 src/TestStack.White/Configuration/ConfigurationExtensions.cs delete mode 100644 src/TestStack.White/Configuration/CoreAppXmlConfiguration.cs delete mode 100644 src/TestStack.White/Configuration/ICoreConfiguration.cs delete mode 100644 src/TestStack.White/Configuration/IUIItemIdConfiguration.cs delete mode 100644 src/TestStack.White/Configuration/UIItemIdAppXmlConfiguration.cs create mode 100644 src/TestStack.White/SystemExtensions/IntExtensions.cs diff --git a/src/Samples/Wpf/WpfTodo.UITests/TodoAppTests.cs b/src/Samples/Wpf/WpfTodo.UITests/TodoAppTests.cs index 6889da44..cdc38f0d 100644 --- a/src/Samples/Wpf/WpfTodo.UITests/TodoAppTests.cs +++ b/src/Samples/Wpf/WpfTodo.UITests/TodoAppTests.cs @@ -24,7 +24,7 @@ public void AutomateTest() Name = "WpfTodo" }; - CoreAppXmlConfiguration.Instance.WorkSessionLocation = new DirectoryInfo(workPath); + CoreConfigurationLocator.Get().WorkSessionLocation = new DirectoryInfo(workPath); using (var workSession = new WorkSession(workConfiguration, new NullWorkEnvironment())) { var screenRepository = workSession.Attach(Application); diff --git a/src/TestStack.White.Reporting/Configuration/ReportingAppXmlConfiguration.cs b/src/TestStack.White.Reporting/Configuration/ReportingAppXmlConfiguration.cs deleted file mode 100644 index 88847497..00000000 --- a/src/TestStack.White.Reporting/Configuration/ReportingAppXmlConfiguration.cs +++ /dev/null @@ -1,32 +0,0 @@ -using System; -using System.Collections.Generic; -using TestStack.White.Bricks; -using TestStack.White.Configuration; - -namespace TestStack.White.Reporting.Configuration -{ - public class ReportingAppXmlConfiguration : AssemblyConfiguration, ReportingConfiguration - { - private static ReportingConfiguration instance; - - private static readonly Dictionary DefaultValues = new Dictionary(); - - static ReportingAppXmlConfiguration() - { - DefaultValues.Add("PublishTestReports", true); - } - - private ReportingAppXmlConfiguration() : base("White", "Reporting", DefaultValues, - CoreAppXmlConfiguration.Instance.LoggerFactory.Create(typeof(ReportingAppXmlConfiguration))) {} - - public static ReportingConfiguration Instance - { - get { return instance ?? (instance = new ReportingAppXmlConfiguration()); } - } - - public virtual bool PublishTestReports - { - get { return Convert.ToBoolean(UsedValues["PublishTestReports"]); } - } - } -} \ No newline at end of file diff --git a/src/TestStack.White.Reporting/Configuration/ReportingConfiguration.cs b/src/TestStack.White.Reporting/Configuration/ReportingConfiguration.cs index 74a0cc36..b434fbd0 100644 --- a/src/TestStack.White.Reporting/Configuration/ReportingConfiguration.cs +++ b/src/TestStack.White.Reporting/Configuration/ReportingConfiguration.cs @@ -1,7 +1,27 @@ +using System.Collections.Generic; +using TestStack.White.Configuration; + namespace TestStack.White.Reporting.Configuration { - public interface ReportingConfiguration + public class ReportingConfiguration : ConfigurationBase { - bool PublishTestReports { get; } + private const string PublishTestReportsKey = "PublishTestReports"; + + public override Dictionary DefaultValues + { + get + { + return new Dictionary + { + {PublishTestReportsKey, true} + }; + } + } + + public virtual bool PublishTestReports + { + get { return GetValueBoolean(PublishTestReportsKey); } + set { SetValue(PublishTestReportsKey, value); } + } } } \ No newline at end of file diff --git a/src/TestStack.White.Reporting/Domain/SubFlow.cs b/src/TestStack.White.Reporting/Domain/SubFlow.cs index d99a0a4d..f30b12c1 100644 --- a/src/TestStack.White.Reporting/Domain/SubFlow.cs +++ b/src/TestStack.White.Reporting/Domain/SubFlow.cs @@ -18,7 +18,7 @@ public class SubFlow private readonly string directory; private DateTime screenCreationTime; private readonly string name; - private static readonly ILogger Logger = CoreAppXmlConfiguration.Instance.LoggerFactory.Create(typeof(SubFlow)); + private static readonly ILogger Logger = CoreConfigurationLocator.Get().LoggerFactory.Create(typeof(SubFlow)); public SubFlow(string subFlowName, string flowName, string archiveLocation) { diff --git a/src/TestStack.White.Reporting/Domain/SubFlows.cs b/src/TestStack.White.Reporting/Domain/SubFlows.cs index 1e52240f..f38d49cc 100644 --- a/src/TestStack.White.Reporting/Domain/SubFlows.cs +++ b/src/TestStack.White.Reporting/Domain/SubFlows.cs @@ -11,7 +11,7 @@ public class SubFlows : List private readonly string archiveLocation; private readonly string flowName; private int currentSubFlowIndex = -1; - private readonly ILogger logger = CoreAppXmlConfiguration.Instance.LoggerFactory.Create(typeof(SubFlow)); + private readonly ILogger logger = CoreConfigurationLocator.Get().LoggerFactory.Create(typeof(SubFlow)); public SubFlows(string archiveLocation, string flowName) { diff --git a/src/TestStack.White.Reporting/TestStack.White.Reporting.csproj b/src/TestStack.White.Reporting/TestStack.White.Reporting.csproj index ede5ba94..55b252ef 100644 --- a/src/TestStack.White.Reporting/TestStack.White.Reporting.csproj +++ b/src/TestStack.White.Reporting/TestStack.White.Reporting.csproj @@ -71,8 +71,8 @@ + - @@ -113,5 +113,4 @@ --> - - + \ No newline at end of file diff --git a/src/TestStack.White.ScreenObjects/AppScreen.cs b/src/TestStack.White.ScreenObjects/AppScreen.cs index 84eee408..6460a7e2 100644 --- a/src/TestStack.White.ScreenObjects/AppScreen.cs +++ b/src/TestStack.White.ScreenObjects/AppScreen.cs @@ -13,7 +13,7 @@ namespace TestStack.White.ScreenObjects //TODO: Take care of act kind of stuff by putting attribute public class AppScreen : RepositoryComponent { - private readonly ILogger logger = CoreAppXmlConfiguration.Instance.LoggerFactory.Create(typeof(AppScreen)); + private readonly ILogger logger = CoreConfigurationLocator.Get().LoggerFactory.Create(typeof(AppScreen)); public AppScreen(Window window, ScreenRepository screenRepository) : base(window, screenRepository) {} diff --git a/src/TestStack.White.ScreenObjects/Configuration/RepositoryAppXmlConfiguration.cs b/src/TestStack.White.ScreenObjects/Configuration/RepositoryAppXmlConfiguration.cs deleted file mode 100644 index 14e66f1a..00000000 --- a/src/TestStack.White.ScreenObjects/Configuration/RepositoryAppXmlConfiguration.cs +++ /dev/null @@ -1,48 +0,0 @@ -using System; -using System.Collections.Generic; -using System.IO; -using TestStack.White.Bricks; -using TestStack.White.Configuration; - -namespace TestStack.White.ScreenObjects.Configuration -{ - public class RepositoryAppXmlConfiguration : AssemblyConfiguration, RepositoryConfiguration - { - public static RepositoryConfiguration instance; - - private static readonly Dictionary DefaultValues = new Dictionary(); - private const string UseHistoryKey = "UseHistory"; - private const string ServiceCallHistoryLocationKey = "ServiceCallHistoryLocation"; - private const string RecordFlowKey = "RecordFlow"; - - static RepositoryAppXmlConfiguration() - { - DefaultValues[RecordFlowKey] = false; - DefaultValues[ServiceCallHistoryLocationKey] = "."; - DefaultValues[UseHistoryKey] = false; - } - - public static RepositoryConfiguration Instance - { - get { return instance ?? (instance = new RepositoryAppXmlConfiguration()); } - } - - private RepositoryAppXmlConfiguration() : base("White", "Repository", DefaultValues, - CoreAppXmlConfiguration.Instance.LoggerFactory.Create(typeof(RepositoryAppXmlConfiguration))) {} - - public virtual bool RecordFlow - { - get { return Convert.ToBoolean(UsedValues[RecordFlowKey]); } - } - - public virtual DirectoryInfo ServiceCallHistoryLocation - { - get { return new DirectoryInfo(UsedValues[ServiceCallHistoryLocationKey]); } - } - - public virtual bool UseHistory - { - get { return Convert.ToBoolean(UsedValues[UseHistoryKey]); } - } - } -} \ No newline at end of file diff --git a/src/TestStack.White.ScreenObjects/Configuration/RepositoryConfiguration.cs b/src/TestStack.White.ScreenObjects/Configuration/RepositoryConfiguration.cs index 28e6f549..98f76621 100644 --- a/src/TestStack.White.ScreenObjects/Configuration/RepositoryConfiguration.cs +++ b/src/TestStack.White.ScreenObjects/Configuration/RepositoryConfiguration.cs @@ -1,12 +1,45 @@ +using System.Collections.Generic; using System.IO; +using TestStack.White.Configuration; namespace TestStack.White.ScreenObjects.Configuration { - //TODO: Power management - public interface RepositoryConfiguration + // TODO: Power management + public class RepositoryConfiguration : ConfigurationBase { - bool RecordFlow { get; } - DirectoryInfo ServiceCallHistoryLocation { get; } - bool UseHistory { get; } + private const string RecordFlowKey = "RecordFlow"; + private const string ServiceCallHistoryLocationKey = "ServiceCallHistoryLocation"; + private const string UseHistoryKey = "UseHistory"; + + public override Dictionary DefaultValues + { + get + { + return new Dictionary + { + {RecordFlowKey, false}, + {ServiceCallHistoryLocationKey, "."}, + {UseHistoryKey, false} + }; + } + } + + public virtual bool RecordFlow + { + get { return GetValueBoolean(RecordFlowKey); } + set { SetValue(RecordFlowKey, value); } + } + + public virtual DirectoryInfo ServiceCallHistoryLocation + { + get { return new DirectoryInfo(GetValue(ServiceCallHistoryLocationKey)); } + set { SetValue(ServiceCallHistoryLocationKey, value); } + } + + public virtual bool UseHistory + { + get { return GetValueBoolean(UseHistoryKey); } + set { SetValue(UseHistoryKey, value); } + } } } \ No newline at end of file diff --git a/src/TestStack.White.ScreenObjects/EntityMapping/Entity.cs b/src/TestStack.White.ScreenObjects/EntityMapping/Entity.cs index f5eb8fd6..6a9ce153 100644 --- a/src/TestStack.White.ScreenObjects/EntityMapping/Entity.cs +++ b/src/TestStack.White.ScreenObjects/EntityMapping/Entity.cs @@ -18,7 +18,7 @@ namespace TestStack.White.ScreenObjects.EntityMapping public class Entity { [ScreenIgnore, XmlIgnore] private NestedEntities nestedEntities; - private readonly ILogger logger = CoreAppXmlConfiguration.Instance.LoggerFactory.Create(typeof(Entity)); + private readonly ILogger logger = CoreConfigurationLocator.Get().LoggerFactory.Create(typeof(Entity)); internal const BindingFlags BindingFlag = BindingFlags.Public | BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.DeclaredOnly | BindingFlags.IgnoreCase; protected Entity() {} diff --git a/src/TestStack.White.ScreenObjects/ScreenFlow/WorkFlow.cs b/src/TestStack.White.ScreenObjects/ScreenFlow/WorkFlow.cs index f93d4240..a4d075e8 100644 --- a/src/TestStack.White.ScreenObjects/ScreenFlow/WorkFlow.cs +++ b/src/TestStack.White.ScreenObjects/ScreenFlow/WorkFlow.cs @@ -20,7 +20,7 @@ public class WorkFlow private readonly GraphWriter graph; private readonly FlowWriter flow; private readonly string directory; - private static readonly ILogger Logger = CoreAppXmlConfiguration.Instance.LoggerFactory.Create(typeof(WorkFlow)); + private static readonly ILogger Logger = CoreConfigurationLocator.Get().LoggerFactory.Create(typeof(WorkFlow)); public WorkFlow(string name, string archiveLocation) { diff --git a/src/TestStack.White.ScreenObjects/Services/ExecutionHistory.cs b/src/TestStack.White.ScreenObjects/Services/ExecutionHistory.cs index eeb84851..4fee6792 100644 --- a/src/TestStack.White.ScreenObjects/Services/ExecutionHistory.cs +++ b/src/TestStack.White.ScreenObjects/Services/ExecutionHistory.cs @@ -13,7 +13,7 @@ public class ExecutionHistory private bool hasError; private static readonly string ExecutionHistoryFile = - string.Format(@"{0}\{1}.xml", CoreAppXmlConfiguration.Instance.WorkSessionLocation, "ExecutionHistory"); + string.Format(@"{0}\{1}.xml", CoreConfigurationLocator.Get().WorkSessionLocation, "ExecutionHistory"); public ExecutionHistory() { diff --git a/src/TestStack.White.ScreenObjects/Services/ServiceExecution.cs b/src/TestStack.White.ScreenObjects/Services/ServiceExecution.cs index 17a59b0e..871acfbe 100644 --- a/src/TestStack.White.ScreenObjects/Services/ServiceExecution.cs +++ b/src/TestStack.White.ScreenObjects/Services/ServiceExecution.cs @@ -91,7 +91,7 @@ public virtual void RevertToSnapshot() public static ServiceExecution Create(IWorkEnvironment workEnvironment) { - if (!RepositoryAppXmlConfiguration.Instance.UseHistory) + if (!RepositoryConfigurationLocator.Get().UseHistory) return new NullServiceExecution(); ExecutionHistory executionHistory = ExecutionHistory.Create(); return new ServiceExecution(executionHistory, workEnvironment ?? new NullWorkEnvironment()); diff --git a/src/TestStack.White.ScreenObjects/Services/WhiteExecution.cs b/src/TestStack.White.ScreenObjects/Services/WhiteExecution.cs index 88f0db16..0819a5b8 100644 --- a/src/TestStack.White.ScreenObjects/Services/WhiteExecution.cs +++ b/src/TestStack.White.ScreenObjects/Services/WhiteExecution.cs @@ -37,7 +37,7 @@ public virtual T GetService(params object[] objs) where T : Service if (services.TryGetValue(typeof (T), out service)) return (T) service; service = (T) Activator.CreateInstance(typeof(T), objs); - if (RepositoryAppXmlConfiguration.Instance.UseHistory || ReportingAppXmlConfiguration.Instance.PublishTestReports) + if (RepositoryConfigurationLocator.Get().UseHistory || ReportingConfigurationLocator.Get().PublishTestReports) { service = (Service) DynamicProxyGenerator.Instance.CreateProxy(typeof (T), new ServiceInterceptor(service, serviceExecution, sessionReport)); services.Add(typeof (T), service); diff --git a/src/TestStack.White.ScreenObjects/Sessions/WorkConfiguration.cs b/src/TestStack.White.ScreenObjects/Sessions/WorkConfiguration.cs index 591a899f..a05d770f 100644 --- a/src/TestStack.White.ScreenObjects/Sessions/WorkConfiguration.cs +++ b/src/TestStack.White.ScreenObjects/Sessions/WorkConfiguration.cs @@ -22,7 +22,7 @@ public virtual string Name public virtual IReport CreateSessionReport() { - if (ReportingAppXmlConfiguration.Instance.PublishTestReports) + if (ReportingConfigurationLocator.Get().PublishTestReports) return new SessionReport(archiveLocation, name); return new NullSessionReport(); } diff --git a/src/TestStack.White.ScreenObjects/TestStack.White.ScreenObjects.csproj b/src/TestStack.White.ScreenObjects/TestStack.White.ScreenObjects.csproj index f86f229f..2b40f14c 100644 --- a/src/TestStack.White.ScreenObjects/TestStack.White.ScreenObjects.csproj +++ b/src/TestStack.White.ScreenObjects/TestStack.White.ScreenObjects.csproj @@ -83,11 +83,11 @@ + - diff --git a/src/TestStack.White.UITests/AutomationElementSearch/RawAutomationElementFinderTests.cs b/src/TestStack.White.UITests/AutomationElementSearch/RawAutomationElementFinderTests.cs index 8ec3d2ac..3ea840b3 100644 --- a/src/TestStack.White.UITests/AutomationElementSearch/RawAutomationElementFinderTests.cs +++ b/src/TestStack.White.UITests/AutomationElementSearch/RawAutomationElementFinderTests.cs @@ -21,7 +21,7 @@ public RawAutomationElementFinderTests(WindowsFramework framework) [OneTimeSetUp] public void Setup() { - cleanup = CoreAppXmlConfiguration.Instance.ApplyTemporarySetting(c => + cleanup = CoreConfigurationLocator.Get().ApplyTemporarySettings(c => { c.RawElementBasedSearch = true; c.MaxElementSearchDepth = 2; diff --git a/src/TestStack.White.UITests/ControlTests/ButtonTests.cs b/src/TestStack.White.UITests/ControlTests/ButtonTests.cs index 5652325b..48a11f03 100644 --- a/src/TestStack.White.UITests/ControlTests/ButtonTests.cs +++ b/src/TestStack.White.UITests/ControlTests/ButtonTests.cs @@ -25,7 +25,7 @@ public void Click() [Test] public void ThrowsWhenNotFound() { - using (CoreAppXmlConfiguration.Instance.ApplyTemporarySetting(c => c.FindWindowTimeout = 500)) + using (CoreConfigurationLocator.Get().ApplyTemporarySettings(c => c.FindWindowTimeout = 500)) { Assert.That(() => { MainWindow.Get