[Consumes("application/json")] // supports only json public IActionResult Post(InersectionOperationParam myJson) { var pathToScriptFolder = Configuration["pathToAnalysisScriptFolder"]; var scriptName = Configuration["AnalysisScriptNames:intersectScript"]; var qgisPython = Configuration["ScriptRunners:qgisCmdPath"]; ResultObject output; using (var tempFiles1 = new TempFileCollection()) { string inputLayerFile = tempFiles1.AddExtension("geojson"); string overlayLayerFile = Path.ChangeExtension(Path.GetTempFileName(), "geojson"); tempFiles1.AddFile(overlayLayerFile, false); System.IO.File.WriteAllText(inputLayerFile, myJson.InputLayer.ToString()); System.IO.File.WriteAllText(overlayLayerFile, myJson.OverlayLayer.ToString()); string args = _creator.buildIntersectionCommand(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); InersectionOperationParam inersectionOperationParam = new InersectionOperationParam() { InputLayer = inputLayer, OverlayLayer = overlayLayer }; IList <ValidationResult> result = checkPropertyValidation.myValidation(inersectionOperationParam, mockValidationFunctions); Assert.AreEqual(expectedResultCount, result.Count()); }