From 10c9aebbef0fcffe8aaebaf336831887fa0fe108 Mon Sep 17 00:00:00 2001 From: Cristian Adrian Giagante Date: Tue, 2 Jan 2018 15:19:32 -0300 Subject: [PATCH] Fix unhandled exception to non-existent instance of MSSQL-EXPRESS installed. --- FOCA/Program.cs | 44 ++++++++++++++++++++++++++------------------ 1 file changed, 26 insertions(+), 18 deletions(-) diff --git a/FOCA/Program.cs b/FOCA/Program.cs index d588cea..6e9d225 100644 --- a/FOCA/Program.cs +++ b/FOCA/Program.cs @@ -54,26 +54,34 @@ public static void WriteErrorInLog(string strMessage) { } } - + /// /// Validate Service Sql. /// /// public static bool IsSQLServerRunning() { - var process = Process.GetProcessesByName("sqlservr"); - if (process.Length == 0) return false; + try + { + var process = Process.GetProcessesByName("sqlservr"); + if (process.Length == 0) return false; - //Validate Sql Express - var serviceController = new ServiceController("MSSQL$SQLEXPRESS", Environment.MachineName); + //Validate Sql Express + var serviceController = new ServiceController("MSSQL$SQLEXPRESS", Environment.MachineName); - if (serviceController.DisplayName != null) - return serviceController.Status != ServiceControllerStatus.Stopped; - - //Validate Sql Server - serviceController = new ServiceController("MSSQLServer", Environment.MachineName); + if (serviceController.DisplayName != null) + return serviceController.Status != ServiceControllerStatus.Stopped; + + //Validate Sql Server + serviceController = new ServiceController("MSSQLServer", Environment.MachineName); - return serviceController.Status != ServiceControllerStatus.Stopped; + return serviceController.Status != ServiceControllerStatus.Stopped; + } + catch (InvalidOperationException e) + { + //Throwed if you are not running an MSSQL EXPRESS instance on the local machine + return false; + } } /// @@ -87,9 +95,9 @@ static void Main() var fsf = new FormSplashFOCA("Open Source"); var t = new Thread(new ThreadStart(delegate - { - Application.Run(fsf); - })); + { + Application.Run(fsf); + })); t.Start(); //Load the FOCA @@ -124,10 +132,10 @@ static void Main() try { fsf.Invoke(new MethodInvoker(delegate - { - fsf.Close(); - canStart = true; - })); + { + fsf.Close(); + canStart = true; + })); } catch {