Beispiel #1
0
        private int HandleFileOptions(string fileType, string fileName, eVerboseLevel verboseLevel)
        {
            SetVerboseLevel(verboseLevel);
            Reporter.ToLog(eLogLevel.DEBUG, string.Format("Running with " + fileType + " file = '{0}'", fileName));
            switch (fileType)
            {
            case "config":
                mCLIHandler = new CLIConfigFile();
                break;

            case "dynamic":
                mCLIHandler = new CLIDynamicXML();
                // CLILoadAndPrepare();
                break;

            case "script":
                mCLIHandler = new CLIScriptFile();
                break;
            }
            mCLIHandler.LoadContent(ReadFile(fileName), mCLIHelper, WorkSpace.Instance.RunsetExecutor);
            if (fileType == "config" || fileType == "dynamic")  // not needed for script
            {
                CLILoadAndPrepare();
            }
            ExecuteRunSet();

            return(Environment.ExitCode);
        }
Beispiel #2
0
        private int HandleFileOptions(string fileType, string fileName, eVerboseLevel verboseLevel)
        {
            try
            {
                SetVerboseLevel(verboseLevel);
                Reporter.ToLog(eLogLevel.INFO, string.Format("Running with " + fileType + " file = '{0}'", fileName));
                switch (fileType)
                {
                case "config":
                    mCLIHandler = new CLIConfigFile();
                    break;

                case "dynamic":
                    if (Path.GetExtension(fileName).ToLower() == ".xml")
                    {
                        mCLIHandler = new CLIDynamicFile(CLIDynamicFile.eFileType.XML);
                    }
                    else if (Path.GetExtension(fileName).ToLower() == ".json")
                    {
                        mCLIHandler = new CLIDynamicFile(CLIDynamicFile.eFileType.JSON);
                    }
                    else
                    {
                        Reporter.ToLog(eLogLevel.ERROR, string.Format("Dynamic file type is not supported, file path: '{0}'", fileName));
                        Environment.ExitCode = 1;     //failure
                        return(Environment.ExitCode);
                    }
                    break;

                case "script":
                    mCLIHandler = new CLIScriptFile();
                    break;
                }

                string fileContent = ReadFile(fileName);
                mCLIHandler.LoadGeneralConfigurations(fileContent, mCLIHelper);

                if (fileType == "config" || fileType == "dynamic")  // not needed for script
                {
                    if (!CLILoadAndPrepare(runsetConfigs: fileContent))
                    {
                        Reporter.ToLog(eLogLevel.WARN, "Issue occured while doing CLI Load and Prepare so aborting execution");
                        Environment.ExitCode = 1;
                        return(Environment.ExitCode);
                    }
                }

                ExecuteRunSet();

                return(Environment.ExitCode);
            }
            catch (Exception ex)
            {
                Reporter.ToLog(eLogLevel.ERROR, "Exception occured while Handling File Option", ex);
                Environment.ExitCode = 1;
                return(1);//error
            }
        }