public string buildMergeCommand(MergeVectorLayerOperationParam json, string scriptFolder, string scriptName, string inputLayerFile) { ICommandBuilder builder = createNewCommandBuilder(); builder.AddProgramName(scriptFolder + @"\" + scriptName); builder.SignleParameter(inputLayerFile); builder.SignleParameter(json.Crs); return(builder.GetResult()); }
[Consumes("application/json")] // supports only json public IActionResult Post(MergeVectorLayerOperationParam myJson) { var pathToScriptFolder = Configuration["pathToAnalysisScriptFolder"]; var scriptName = Configuration["AnalysisScriptNames:mergeScript"]; var qgisPython = Configuration["ScriptRunners:qgisCmdPath"]; ResultObject output; using (var tempFiles = new TempFileCollection()) { string inputLayerFile = tempFiles.AddExtension("geojson"); System.IO.File.WriteAllText(inputLayerFile, myJson.InputLayers.ToString()); string args = _creator.buildMergeCommand(myJson, pathToScriptFolder, scriptName, inputLayerFile); output = _python.RunCMD(args, qgisPython); } return(_outputHandler.HandleQgisOutput(output)); }
public void Test_Validate_method(bool inputLayerValid, int expectedResultCount) { Random random = new Random(); CheckPropertyValidation checkPropertyValidation = new CheckPropertyValidation(); Mock <IValidationFunctions> mockValidationFunctions = new Mock <IValidationFunctions>(); mockValidationFunctions.Setup(x => x.IsValidGeoJsonArray(It.IsAny <string>())).Returns(inputLayerValid); MergeVectorLayerOperationParam mergeVectorLayerOperationParam = new MergeVectorLayerOperationParam() { InputLayers = "inputLayers" + random.Next(1000) }; IList <ValidationResult> result = checkPropertyValidation.myValidation(mergeVectorLayerOperationParam, mockValidationFunctions); Assert.AreEqual(expectedResultCount, result.Count); }