Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Made Lofting algorithm throw Exception when side caps are invalid #999

Merged
merged 9 commits into from
Aug 30, 2024

Conversation

merakulix
Copy link
Contributor

Description

Throwing an exception while building the shells, using invalid side caps, prevents TiGL to build invalid solid shapes.

How Has This Been Tested?

Added test in testFuselageStandardProfileRectangle.cpp that checks for exception if side caps are invalid. If rectangular profile wires are built that cannot be used to create valid side caps, the exception is thrown.

Screenshots, that help to understand the changes(if applicable):

This solid (created by a rectangle profile with too large corner radius) is not valid. Building side caps from its closed, but entangled profile wire is not possible. Solids like this will not be built and used mistakenly, if exception is thrown.

grafik

Checklist:

  • A test for the new functionality was added.
  • [x ] All tests run without failure.
  • The new code complies with the TiGL style guide.
  • New classes have been added to the Python interface.
  • API changes were documented properly in tigl.h.

Copy link
Contributor

@joergbrech joergbrech left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Looks good in principle. One unit tests triggers the new exception, see here. We should investigate and make sure that all unit tests succeed before we merge.

@joergbrech
Copy link
Contributor

As per our chat on MM: Let's make sure that this doesn't affect the TiGL performance too much. One option could be to activate the test only in debug mode (and optionally: If we have the check in debug mode only, we could use simple assertions rather than exceptions. I believe this is common for checks that are only performed in debug mode)

Copy link
Contributor

@joergbrech joergbrech left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we add a simple test where this exception is thrown? We can use the same preprocessor directive in the test that only checks if the lofter throws in debug mode.

src/geometry/CTiglPatchShell.cpp Outdated Show resolved Hide resolved
@merakulix merakulix closed this Jul 9, 2024
@merakulix merakulix reopened this Jul 9, 2024
Copy link

codecov bot commented Aug 29, 2024

Codecov Report

Attention: Patch coverage is 50.00000% with 2 lines in your changes missing coverage. Please review.

Project coverage is 70.02%. Comparing base (a334bd3) to head (6c4fd02).
Report is 14 commits behind head on master.

Files with missing lines Patch % Lines
src/geometry/CTiglPatchShell.cpp 50.00% 2 Missing ⚠️
Additional details and impacted files

Impacted file tree graph

@@            Coverage Diff             @@
##           master     #999      +/-   ##
==========================================
- Coverage   70.03%   70.02%   -0.01%     
==========================================
  Files         301      301              
  Lines       24312    24316       +4     
==========================================
+ Hits        17026    17028       +2     
- Misses       7286     7288       +2     
Flag Coverage Δ
unittests 70.02% <50.00%> (-0.01%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

Files with missing lines Coverage Δ
src/logging/CTiglLogging.cpp 80.39% <ø> (ø)
src/geometry/CTiglPatchShell.cpp 91.25% <50.00%> (-2.18%) ⬇️

@joergbrech
Copy link
Contributor

I am sorry, could you please have another look at the coverage report?

@joergbrech
Copy link
Contributor

I am sorry, could you please have another look at the coverage report?

NVM, the uncovered lines are in a fallback implementation for non-planar profiles, which are not supported by TiGL anyway. Constructing a unit test for this exotic case just for the sake of code coverage seems like too much work. Let's merge

@joergbrech joergbrech merged commit 28b2dc3 into master Aug 30, 2024
16 of 17 checks passed
@joergbrech joergbrech deleted the MakeAddSideCapsThrowException branch August 30, 2024 07:59
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants