I have several assert(condition, "message")
statements in my project.
They are used to check invariant conditions during development. I thought they would be ignored in production/release build (as stated in this answer). They are not. Instead they cause crashes during TestFlight testing. When I comment asserts the app does not crash. Something usually gets wrong a bit but it does not crash.
Can it be something with my build settings?
All my archive schemes use release configuration:
The asserts are in Cocoa Touch Framework project, that is used from custom keyboard extension.
All the targets in all projects (Cocoa Touch Framework, and the main project with keyboard extension target) have these Build Settings:
Enable Foundation Assertions
Debug YES
Release NO
Disable Safety Checks NO
What's wrong?
EDIT:
Sulthan's answer shows how to disable asserts globally for both debug and relase builds. That is not what I need. I want it to work as expected - asserts should be enabled in debug but disabled in release builds.
By default it works that way - and it also works that way in my main project. But it does not work for asserts located in Framework project that is linked from that main project (details in this question). Why? How to fix it?
The options you have tried:
Enable Foundation Assertions
is in the preprocessing section (Macros). Swift is not preprocessed and does not use macros. This option disablesNSAssert
,NSParameterAssert
and similar macros commonly used in Objective-C.Disable Safety Checks
is a performance option:(Swift Library Reference)
You should probably try my answer here (use
-assert-config Release
inOther Swift Flags
).Or just keep the asserts in production builds. Every failing assert is a bug and in general it's better to know about a bug as soon as possible.