X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FConstructionPlugin%2FTest%2FTestAxisCreation.py;h=a645c548e03fff88011f13993285b2e4e50b1485;hb=08f1aef6629e6a63cc4671d271ded4de6e826948;hp=35885a872134c6090ef1e64ff3ee1cc1f68319f4;hpb=b6a827b5f2b1c61957dc2b22bfa11eba72175413;p=modules%2Fshaper.git diff --git a/src/ConstructionPlugin/Test/TestAxisCreation.py b/src/ConstructionPlugin/Test/TestAxisCreation.py index 35885a872..a645c548e 100644 --- a/src/ConstructionPlugin/Test/TestAxisCreation.py +++ b/src/ConstructionPlugin/Test/TestAxisCreation.py @@ -1,3 +1,23 @@ +## Copyright (C) 2014-2017 CEA/DEN, EDF R&D +## +## This library is free software; you can redistribute it and/or +## modify it under the terms of the GNU Lesser General Public +## License as published by the Free Software Foundation; either +## version 2.1 of the License, or (at your option) any later version. +## +## This library is distributed in the hope that it will be useful, +## but WITHOUT ANY WARRANTY; without even the implied warranty of +## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +## Lesser General Public License for more details. +## +## You should have received a copy of the GNU Lesser General Public +## License along with this library; if not, write to the Free Software +## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +## +## See http:##www.salome-platform.org/ or +## email : webmaster.salome@opencascade.com +## + #========================================================================= # Initialization of the test #========================================================================= @@ -8,6 +28,8 @@ from GeomAPI import * import math from ModelAPI import * +from salome.shaper import model + aSession = ModelAPI_Session.get() aDocument = aSession.moduleDocument() @@ -26,10 +48,11 @@ aSession.startOperation() aPointFeature = aPart.addFeature("Point") aPointFeatureData = aPointFeature.data() assert(aPointFeatureData is not None) -aPointFeatureData.string("creation_method").setValue("by_xyz") +# aPointFeatureData.string("creation_method").setValue("by_xyz") aPointFeatureData.real("x").setValue(0.) aPointFeatureData.real("y").setValue(0.) aPointFeatureData.real("z").setValue(0.) +aPointFeatureData.string("creation_method").setValue("by_xyz") aPointFeature.execute() aSession.finishOperation() aPoint1Result = aPointFeature.firstResult(); @@ -41,10 +64,11 @@ aSession.startOperation() aPointFeature = aPart.addFeature("Point") aPointFeatureData = aPointFeature.data() assert(aPointFeatureData is not None) -aPointFeatureData.string("creation_method").setValue("by_xyz") +# aPointFeatureData.string("creation_method").setValue("by_xyz") aPointFeatureData.real("x").setValue(0.) aPointFeatureData.real("y").setValue(0.) aPointFeatureData.real("z").setValue(100.) +aPointFeatureData.string("creation_method").setValue("by_xyz") aPointFeature.execute() aSession.finishOperation() aPoint2Result = aPointFeature.firstResult(); @@ -79,8 +103,8 @@ norm = geomDataAPI_Dir(aCircleSketchFeature.attribute("Norm")) norm.setValue(0, 0, 1) # Create circle aSketchCircle = aCircleSketchFeature.addFeature("SketchCircle") -anCircleCentr = geomDataAPI_Point2D(aSketchCircle.attribute("CircleCenter")) -aCircleRadius = aSketchCircle.real("CircleRadius") +anCircleCentr = geomDataAPI_Point2D(aSketchCircle.attribute("circle_center")) +aCircleRadius = aSketchCircle.real("circle_radius") anCircleCentr.setValue(0, 0) aCircleRadius.setValue(50) aSession.finishOperation() @@ -134,3 +158,57 @@ aSession.finishOperation() assert (len(anAxisFeature.results()) > 0) anAxisResult = modelAPI_ResultConstruction(anAxisFeature.firstResult()) assert (anAxisResult is not None) + +# Create a sketch with line +aSession.startOperation() +anOrigin = GeomAPI_Pnt(0, 0, 0) +aDirX = GeomAPI_Dir(1, 0, 0) +aNorm = GeomAPI_Dir(0, 0, 1) +aSketch = model.addSketch(aPart, GeomAPI_Ax3(anOrigin, aDirX, aNorm)) +aSketchLine = aSketch.addLine(0, 0, 100, 100) +aSession.finishOperation() + +# Test an axis by line +aSession.startOperation() +anAxis = model.addAxis(aPart, aSketchLine.result()) +aSession.finishOperation() +assert (len(anAxis.results()) > 0) + +# Create plane +aSession.startOperation() +aPlane1 = model.addPlane(aPart, 1, 1, 1, 0) +aSession.finishOperation() + +# Create a sketch with point +aSession.startOperation() +anOrigin = GeomAPI_Pnt(0, 0, 0) +aDirX = GeomAPI_Dir(1, 0, 0) +aNorm = GeomAPI_Dir(0, 0, 1) +aSketch = model.addSketch(aPart, GeomAPI_Ax3(anOrigin, aDirX, aNorm)) +aSketchPoint = aSketch.addPoint(50, 50) +aSession.finishOperation() + +# Test an axis by plane and point +aSession.startOperation() +anAxis = model.addAxis(aPart, aPlane1.result(), aSketchPoint.result()) +aSession.finishOperation() +assert (len(anAxis.results()) > 0) + +# Create plane +aSession.startOperation() +aPlane2 = model.addPlane(aPart, 0, 1, 1, 0) +aSession.finishOperation() + +# Test an axis by two planes +aSession.startOperation() +anAxis = model.addAxis(aPart, aPlane1.result(), aPlane2.result()) +aSession.finishOperation() +assert (len(anAxis.results()) > 0) + +# Test an axis by two planes and offsets +aSession.startOperation() +anAxis = model.addAxis(aPart, aPlane1.result(), 50, False, aPlane2.result(), 100, True) +aSession.finishOperation() +assert (len(anAxis.results()) > 0) + +assert(model.checkPythonDump())