Merge branch 'main' into bgbsww-toponamingAddFeatureRefine

This commit is contained in:
bgbsww
2024-09-27 16:26:27 -04:00
committed by GitHub
802 changed files with 43326 additions and 39055 deletions

View File

@@ -34,8 +34,10 @@ FIXTURE_PATH = pathlib.Path(__file__).parent / "Fixtures"
class TestInvoluteGear(unittest.TestCase):
def setUp(self):
self.Doc = FreeCAD.newDocument("PartDesignTestInvoluteGear")
FreeCAD.ConfigSet("SuppressRecomputeRequiredDialog", "True")
def tearDown(self):
FreeCAD.ConfigSet("SuppressRecomputeRequiredDialog", "")
FreeCAD.closeDocument(self.Doc.Name)
def testDefaultGearProfile(self):

View File

@@ -30,6 +30,7 @@ App = FreeCAD
class TestMultiTransform(unittest.TestCase):
def setUp(self):
self.Doc = FreeCAD.newDocument("PartDesignTestMultiTransform")
FreeCAD.ConfigSet("SuppressRecomputeRequiredDialog", "True")
def testMultiTransform(self):
self.Body = self.Doc.addObject('PartDesign::Body','Body')
@@ -137,5 +138,6 @@ class TestMultiTransform(unittest.TestCase):
def tearDown(self):
#closing doc
FreeCAD.closeDocument("PartDesignTestMultiTransform")
# print ("omit closing document for debugging")
FreeCAD.ConfigSet("SuppressRecomputeRequiredDialog", "")
#print ("omit closing document for debugging")

View File

@@ -22,6 +22,7 @@
import unittest
import FreeCAD
from FreeCAD import Base
import TestSketcherApp
class TestPad(unittest.TestCase):
@@ -184,6 +185,80 @@ class TestPad(unittest.TestCase):
self.Doc.recompute()
self.assertAlmostEqual(self.Pad1.Shape.Volume, 4.0)
def testPadToConcaveCase(self):
self.Body = self.Doc.addObject('PartDesign::Body','Body')
# Make a half revolution
self.RevolutionSketch = self.Doc.addObject('Sketcher::SketchObject', 'SketchPad')
self.Body.addObject(self.RevolutionSketch)
TestSketcherApp.CreateRectangleSketch(self.RevolutionSketch, (9, 0), (10, 5))
self.Doc.recompute()
self.Revolution = self.Doc.addObject("PartDesign::Revolution", "Revolution")
self.Body.addObject(self.Revolution)
self.Revolution.Profile = self.RevolutionSketch
self.Revolution.ReferenceAxis = (self.RevolutionSketch, ['V_Axis'])
self.Revolution.Angle = 180
self.Doc.recompute()
# Make a sketch and pad to first
self.PadSketch = self.Doc.addObject('Sketcher::SketchObject', 'SketchPad')
self.Body.addObject(self.PadSketch)
self.Doc.recompute()
TestSketcherApp.CreateRectangleSketch(self.PadSketch, (0, 0), (1, 1))
self.Doc.recompute()
self.Pad = self.Doc.addObject("PartDesign::Pad", "Pad")
self.Body.addObject(self.Pad)
self.Pad.Profile = self.PadSketch
self.Pad.Type = 2
self.Pad.Reversed = True
self.Doc.recompute()
self.assertAlmostEqual(self.Pad.Shape.Volume, 2208.0963, places=4)
def testPadToShapeCase(self):
self.Body = self.Doc.addObject('PartDesign::Body','Body')
# Make first offset cube Pad
self.PadSketch = self.Doc.addObject('Sketcher::SketchObject', 'SketchPad')
self.Body.addObject(self.PadSketch)
TestSketcherApp.CreateRectangleSketch(self.PadSketch, (0, 1), (1, 1))
self.Doc.recompute()
self.Pad = self.Doc.addObject("PartDesign::Pad", "Pad")
self.Body.addObject(self.Pad)
self.Pad.Profile = self.PadSketch
self.Pad.Length = 1
self.Doc.recompute()
# Make second pad on different plane and pad to first
self.PadSketch1 = self.Doc.addObject('Sketcher::SketchObject', 'SketchPad1')
self.Body.addObject(self.PadSketch1)
self.PadSketch1.MapMode = 'FlatFace'
self.PadSketch1.AttachmentSupport = (self.Doc.XZ_Plane, [''])
self.PadSketch1.AttachmentOffset.Rotation.Axis = Base.Vector(0,1,0)
self.PadSketch1.AttachmentOffset.Rotation.Angle = 0.436332 # 25°
self.PadSketch1.AttachmentOffset.Base.z = 1
self.Doc.recompute()
TestSketcherApp.CreateRectangleSketch(self.PadSketch1, (1, 0), (1, 1))
self.Doc.recompute()
self.Pad1 = self.Doc.addObject("PartDesign::Pad", "Pad1")
self.Body.addObject(self.Pad1)
self.Pad1.Profile = self.PadSketch1
self.Pad1.Type = 5
self.Doc.recompute()
self.assertAlmostEqual(self.Pad1.Shape.Volume, 2.58787, places=4)
def testPadToPlaneCustomDir(self):
self.Body = self.Doc.addObject('PartDesign::Body','Body')
# Make first offset cube Pad
self.PadSketch = self.Doc.addObject('Sketcher::SketchObject', 'SketchPad')
self.Body.addObject(self.PadSketch)
TestSketcherApp.CreateRectangleSketch(self.PadSketch, (0, 1), (1, 1))
self.Doc.recompute()
self.Pad = self.Doc.addObject("PartDesign::Pad", "Pad")
self.Body.addObject(self.Pad)
self.Pad.Profile = self.PadSketch
self.Pad.Type = 3
self.Doc.Pad.UseCustomVector = True
self.Doc.Pad.Direction = Base.Vector(0,1,1)
self.Pad.UpToFace = (self.Doc.XZ_Plane, [''])
self.Doc.recompute()
self.assertAlmostEqual(self.Pad.Shape.Volume, 1.5)
def tearDown(self):
#closing doc
FreeCAD.closeDocument("PartDesignTestPad")