[Consumes("application/json")] // supports only json public IActionResult Post(ClipOperationParam myJson) { var pathToScriptFolder = Configuration["pathToAnalysisScriptFolder"]; var scriptName = Configuration["AnalysisScriptNames:clipScript"]; var qgisPython = Configuration["ScriptRunners:qgisCmdPath"]; ResultObject output; using (var tempCollection = new TempFileCollection()) { string inputLayerFile = tempCollection.AddExtension("geojson"); string overlayLayerFile = Path.ChangeExtension(Path.GetTempFileName(), "geojson"); tempCollection.AddFile(overlayLayerFile, false); System.IO.File.WriteAllText(inputLayerFile, myJson.InputLayer.ToString()); System.IO.File.WriteAllText(overlayLayerFile, myJson.OverlayLayer.ToString()); string args = _creator.buildClipCommand(pathToScriptFolder, scriptName, inputLayerFile, overlayLayerFile); output = _python.RunCMD(args, qgisPython); } return(_outputHandler.HandleQgisOutput(output)); }
public void Test_Validate_method(bool inputLayerValid, bool overlayLayerValid, int expectedResultCount) { Random random = new Random(); string inputLayer = "inputLayer" + random.Next(1000); string overlayLayer = "overlayLayer" + random.Next(1000); CheckPropertyValidation checkPropertyValidation = new CheckPropertyValidation(); Mock <IValidationFunctions> mockValidationFunctions = new Mock <IValidationFunctions>(); mockValidationFunctions.Setup(x => x.IsValidGeoJson(inputLayer)).Returns(inputLayerValid); mockValidationFunctions.Setup(x => x.IsValidGeoJson(overlayLayer)).Returns(overlayLayerValid); ClipOperationParam clipOperationParam = new ClipOperationParam() { InputLayer = inputLayer, OverlayLayer = overlayLayer }; IList <ValidationResult> result = checkPropertyValidation.myValidation(clipOperationParam, mockValidationFunctions); Assert.AreEqual(expectedResultCount, result.Count()); }