コード例 #1
0
        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());
        }
コード例 #2
0
        [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);
        }