From 249de1fa80155d72a557fb0d27318224d0ee93ac Mon Sep 17 00:00:00 2001 From: Dulma Churchill Date: Wed, 30 Oct 2024 04:30:33 -0700 Subject: [PATCH] [self-in-block] Add example of when we report two instances of strongSelf Not Checked Summary: We want to report only once per strongSelf variable, otherwise the autofix will create two separate if conditions in codemods. Adding a test that shows when we are reporting twice now, when each usage is in a different if branch. Reviewed By: skcho Differential Revision: D65156544 fbshipit-source-id: 6469285de66e2c81026f41edbf14230fe373cbb5 --- .../objc/self-in-block/StrongSelf.m | 24 +++++++++++++++++++ .../objc/self-in-block/issues.exp | 3 +++ 2 files changed, 27 insertions(+) diff --git a/infer/tests/codetoanalyze/objc/self-in-block/StrongSelf.m b/infer/tests/codetoanalyze/objc/self-in-block/StrongSelf.m index be6499092c..8b8f7b4150 100644 --- a/infer/tests/codetoanalyze/objc/self-in-block/StrongSelf.m +++ b/infer/tests/codetoanalyze/objc/self-in-block/StrongSelf.m @@ -388,4 +388,28 @@ - (void)mixSelfWeakSelf_bad_no_autofix_super_property { }; } +- (void)strongSelfNoCheck2Instances_bad { + __weak __typeof(self) weakSelf = self; + int (^my_block)(BOOL) = ^(BOOL isTapped) { + __strong __typeof(weakSelf) strongSelf = weakSelf; + if (isTapped) { + strongSelf->_name = @"Dulma"; + } else { + strongSelf->_name = @"Alice"; + } + return 0; + }; +} + +- (void)strongSelfNoCheck2InstancesNoIf_bad { + __weak __typeof(self) weakSelf = self; + int (^my_block)(BOOL) = ^(BOOL isTapped) { + __strong __typeof(weakSelf) strongSelf = weakSelf; + if (isTapped) { + strongSelf->_name = @"Dulma"; + strongSelf->_name = @"Alice"; + } + return 0; + }; +} @end diff --git a/infer/tests/codetoanalyze/objc/self-in-block/issues.exp b/infer/tests/codetoanalyze/objc/self-in-block/issues.exp index f50ed05a4c..662de53eaa 100644 --- a/infer/tests/codetoanalyze/objc/self-in-block/issues.exp +++ b/infer/tests/codetoanalyze/objc/self-in-block/issues.exp @@ -24,3 +24,6 @@ codetoanalyze/objc/self-in-block/StrongSelf.m, objc_block_StrongSelf.m:353, 4, M codetoanalyze/objc/self-in-block/StrongSelf.m, objc_block_StrongSelf.m:365, 4, MIXED_SELF_WEAKSELF, no_bucket, ERROR, [Using &weakSelf,Using &self,Using &self], ""=>"strongSelf->"@369:7 codetoanalyze/objc/self-in-block/StrongSelf.m, objc_block_StrongSelf.m:365, 5, MIXED_SELF_WEAKSELF, no_bucket, ERROR, [Using &weakSelf,Using &self,Using &self], ""=>"strongSelf->"@370:7 codetoanalyze/objc/self-in-block/StrongSelf.m, objc_block_StrongSelf.m:381, 4, MIXED_SELF_WEAKSELF, no_bucket, ERROR, [Using &weakSelf,Using &self] +codetoanalyze/objc/self-in-block/StrongSelf.m, objc_block_StrongSelf.m:393, 3, STRONG_SELF_NOT_CHECKED, no_bucket, ERROR, [&strongSelf assigned here,Using &strongSelf not checked for null] +codetoanalyze/objc/self-in-block/StrongSelf.m, objc_block_StrongSelf.m:393, 5, STRONG_SELF_NOT_CHECKED, no_bucket, ERROR, [&strongSelf assigned here,Using &strongSelf not checked for null] +codetoanalyze/objc/self-in-block/StrongSelf.m, objc_block_StrongSelf.m:406, 3, STRONG_SELF_NOT_CHECKED, no_bucket, ERROR, [&strongSelf assigned here,Using &strongSelf not checked for null]