public string buildLandFundAnalysisCommand(LandFundAnalysisOperationParam json, string scriptFolder, string scriptName, string inputLayerFile) { ICommandBuilder builder = createNewCommandBuilder(); builder.AddProgramName(scriptFolder + @"\" + scriptName); builder.SignleParameter(inputLayerFile); string predicate = String.Join(",", json.Predicate.ToArray()); builder.SignleParameter(predicate); if (json.Distance != null) { builder.SignleParameter(json.Distance.ToString()); } return(builder.GetResult()); }
[Consumes("application/json")] // supports only json public IActionResult Post(LandFundAnalysisOperationParam myJson) { var pathToScriptFolder = Configuration["pathToLandFundScriptFolder"]; var scriptName = Configuration["LandFundScriptNames:analysisScript"]; var qgisPython = Configuration["ScriptRunners:qgisCmdPath"]; ResultObject output; using (var tempFiles = new TempFileCollection()) { string inputLayerFile = tempFiles.AddExtension("geojson"); System.IO.File.WriteAllText(inputLayerFile, myJson.InputLayer.ToString()); string args = _creator.buildLandFundAnalysisCommand(myJson, pathToScriptFolder, scriptName, inputLayerFile); output = _python.RunCMD(args, qgisPython); } return(_outputHandler.HandleQgisOutput(output)); }
public void Test_Validate_method(bool inputLayerValid, bool predicateValid, bool distanceValid, int expectedResultCount) { Random random = new Random(); CheckPropertyValidation checkPropertyValidation = new CheckPropertyValidation(); Mock <IValidationFunctions> mockValidationFunctions = new Mock <IValidationFunctions>(); mockValidationFunctions.Setup(x => x.IsValidPolygonMultiPolygon(It.IsAny <string>())).Returns(inputLayerValid); mockValidationFunctions.Setup(x => x.isPredicateValid(It.IsAny <List <int> >(), It.IsAny <int>(), It.IsAny <int>())).Returns(predicateValid); mockValidationFunctions.Setup(x => x.isDistanceValid(It.IsAny <string>())).Returns(distanceValid); LandFundAnalysisOperationParam landFundAnalysisOperationParam = new LandFundAnalysisOperationParam() { InputLayer = "inputLayer" + random.Next(1000), Predicate = new List <int>(), Distance = "distance" + random.Next(1000) }; IList <ValidationResult> result = checkPropertyValidation.myValidation(landFundAnalysisOperationParam, mockValidationFunctions); Assert.AreEqual(expectedResultCount, result.Count); }