def test_geo_to_msh_py_2(self): step_file_path = os.path.join(os.path.dirname(__file__), 'test_data', 'baseketball_part_colored_partly.step') workflow = workflowBuilder.createWorkflow('MeshingTestWorkflow') stepStep = workflowBuilder.createStep(name='stepAnalyze', parent=workflow, process=StepAnalyzer()) meshGeoStep = workflowBuilder.createStep(name='geoStep', parent=workflow, process=SurfaceGroupsToGeo()) meshStep = workflowBuilder.createStep(name='meshStep', parent=workflow, process=MeshGeoGmsh()) stepStep.inputPorts['input_step'].fixed_value = step_file_path meshStep.inputPorts['mergedFile'].fixed_value = step_file_path meshStep.inputPorts['clscale'].fixed_value = 1. workflowBuilder.connectPorts(stepStep.outputPorts['step'], meshGeoStep.inputPorts['geom_desc']) workflowBuilder.connectPorts(meshGeoStep.outputPorts['geo_file'], meshStep.inputPorts['geo']) aWorkflowState = workflowRunner.executeAsync(workflow) vertsCount = aWorkflowState.findPortState( meshStep.outputPorts['vertCount']).getValue() elemCount = aWorkflowState.findPortState( meshStep.outputPorts['elemCount']).getValue() self.assertGreater(vertsCount, 0, "No Vertices after meshing") self.assertGreater(elemCount, 0, "No Elements after meshing")
def AddDyn_WorkflowAttributes_NoAPI(something): something.workflow = workflowBuilder.createWorkflow('TestWorkflow') something.sumStep1 = workflowBuilder.createStep(name='step1', parent=something.workflow, process=getCmdTool('add')) something.sumStep2 = workflowBuilder.createStep(name='step2', parent=something.workflow, process=getCmdTool('add')) something.multiplyStep1 = workflowBuilder.createStep( name='step3', parent=something.workflow, process=getCmdTool('multiply')) something.sumListStep1 = workflowBuilder.createStep( name='step10', parent=something.workflow, process=getCmdTool('addList')) # set constants something.sumListStep1.inputPorts['addends'].fixed_value = [ 1, 2, 3, 4, 5, 6 ] something.sumStep1.inputPorts['addend1'].fixed_value = 2 something.sumStep2.inputPorts['addend1'].fixed_value = 100 something.multiplyStep1.inputPorts['factor2'].fixed_value = 23 # connect input/output workflowBuilder.connectPorts(something.sumListStep1.outputPorts['sum'], something.sumStep1.inputPorts['addend2']) workflowBuilder.connectPorts(something.sumStep1.outputPorts['sum'], something.sumStep2.inputPorts['addend2']) workflowBuilder.connectPorts(something.sumStep2.outputPorts['sum'], something.multiplyStep1.inputPorts['factor1']) something.exp = 2829
def test2_WorkflowPythonTool(self): # new workflow aWorkflow = caeml.common.workflow.Workflow() # add new workflow steps # aCmdAddTool = caeml.tools.generated_tools.add() aStatsTool = caeml.tools.statsFilePython.statsFileTool() aStats = workflowBuilder.createStep(name='step1', process=aStatsTool, parent=aWorkflow) aSum = workflowBuilder.createToolStep('add', aWorkflow) # set values aStats.inputPorts['data'].fixed_value = [1, 2, 3, 4, 5, 6, 7] # connect workflowBuilder.connectPorts(aStats.outputPorts['max'], aSum.inputPorts['addend1']) workflowBuilder.connectPorts(aStats.outputPorts['min'], aSum.inputPorts['addend2']) # print(yaml.dump(aWorkflow)) state = workflowRunner.executeAsync(aWorkflow) x = state.findPortState(aSum.outputPorts['sum']).getEvaluation() self.assertEqual(x, 8)
def AddDyn_WorkflowAttributes_simple(something): something.workflow = workflowBuilder.createWorkflow('TestSimpleWorkflow') something.sumStep = workflowBuilder.createStep(parent=something.workflow, process=getCmdTool('add')) something.multiplyStep = workflowBuilder.createStep(name='multiplyStep', parent=something.workflow, process=getCmdTool('multiply')) # set constants something.sumStep.inputPorts['addend1'].fixed_value = 2 something.sumStep.inputPorts['addend2'].fixed_value = 3 something.multiplyStep.inputPorts['factor2'].fixed_value = 4 # connect input/output workflowBuilder.connectPorts(something.sumStep.outputPorts['sum'], something.multiplyStep.inputPorts['factor1']) something.float = float(20) something.exp = something.float
def test_workflow_in_workflow(self): """Test workflow: add(1, 2) => (( add(x, 3) => multi(x, 4) => )) add(x, 5) 3 => add(3,3)=6 => multi(6,4)=24 => add(24,5)=29""" # create nested workflow with one input and one output parameter aWorkflowABC = workflowBuilder.createWorkflow( 'ArtificialDemoTestCase-aWorkflowABC') sumStepA = workflowBuilder.createToolStep(toolId='caeml.tools.add.add', parent=aWorkflowABC) sumStepA.inputPorts['addend1'].fixed_value = 3 sumStepA.inputPorts['addend2'].exposed_as = 'IN' multiStepB = workflowBuilder.createToolStep(toolId='multiply', parent=aWorkflowABC) multiStepB.inputPorts['factor2'].fixed_value = 4 workflowBuilder.connectPorts(sumStepA.outputPorts['sum'], multiStepB.inputPorts['factor1']) workflowBuilder.connectPorts(sumStepA.outputPorts['sum'], multiStepB.inputPorts['factor1']) multiStepB.outputPorts['product'].exposed_as = 'OUT' # add basic workflow steps, assign values and connect parameters aWorkflow = workflowBuilder.createWorkflow( 'ArtificialDemoTestCase-aWorkflow') sumStep1 = workflowBuilder.createToolStep(toolId='add', parent=aWorkflow) sumStep3 = workflowBuilder.createToolStep(toolId='add', parent=aWorkflow) aWorkflowABCStep = workflowBuilder.createStep(process=aWorkflowABC, parent=aWorkflow, name='aWorkflowABCStep') # assign input values sumStep1.inputPorts['addend1'].fixed_value = 1 sumStep1.inputPorts['addend2'].fixed_value = 2 sumStep3.inputPorts['addend1'].fixed_value = 5 # plug workflowABC into aWorkflow inPorts = aWorkflowABCStep.inputPorts workflowBuilder.connectPorts(sumStep1.outputPorts['sum'], inPorts['IN']) exPorts = aWorkflowABCStep.outputPorts workflowBuilder.connectPorts(exPorts['OUT'], sumStep3.inputPorts['addend2']) res = workflowRunner.executeAsync(aWorkflow) result = res.findPortState(sumStep3.outputPorts['sum']).getValue() exp = float(29) self.assertEqual( result, exp, "Error! Wrong Result expected {:.2f} got {:.2f}".format( exp, result))
def setUp(self): wf = workflowBuilder.createWorkflow('dummyWorkflow') self.sumStep1 = workflowBuilder.createStep( name='aStep', process=getCmdTool('multiply'), parent=wf) assert (isinstance(self.sumStep1, caeml.common.workflow.Step))
def setUp(self): self.workflow = workflowBuilder.createWorkflow('StepLoadingWorkflow') self.stepStep = workflowBuilder.createStep(name='stepAnalyze', parent=self.workflow, process=StepAnalyzer())