From aee0eae26dcaca70878a5622691d0b858263ea84 Mon Sep 17 00:00:00 2001 From: Olivier Halligon Date: Fri, 3 Apr 2020 10:42:24 +0200 Subject: [PATCH] [Danger Rules] Documentation for #11280 (#367) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * [Danger Rules] Documentation for #11280 Doc for https://github.com/babylonhealth/babylon-ios/pull/11280 * typo * Typo Co-Authored-By: João Pereira Co-authored-by: João Pereira --- Cookbook/Technical-Documents/DangerRules.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/Cookbook/Technical-Documents/DangerRules.md b/Cookbook/Technical-Documents/DangerRules.md index 8f7f65fc5..fda50a4d3 100644 --- a/Cookbook/Technical-Documents/DangerRules.md +++ b/Cookbook/Technical-Documents/DangerRules.md @@ -120,6 +120,21 @@ This rule will warn you if any part of the pbxproj references an UUID that got a When that happens, you need to figure out if the removal of the file was intended as part of your PR (and if so, fix the merge by also removing the lines pointing to that now-deleted file reference), or if the removal of the file from the pbxproj was unintented (and if so, restore it). You could do that by editing the `pbxproj` manually, but if possible it's even better if you can fix it in Xcode (e.g. by removing the offending file from the project and add it again) +## Detect Missing Feedbacks + +> * Declared in: `danger-ci/feedbacks.rb` +> * Function: `check_feedbacks_in_viewmodels` +> * Type: ⚠️ warning + +This rule analyses any `*ViewModel.swift` file created or modified in the PR, and try to determine if any `Feedback` static method was declared but not called. +This is typically to catch cases when you declare a new `Feedback` in your code but forgot to then add it to the state machine. + +This rule uses `sourcekitten` to dump the structure of the Swift code. It uses it to finds all the `static func` returning a `Feedback` declared in your code, then searches for all the method calls in your code to see if that list contains calls to all the `Feedback` methods declared. If it finds a `static func … -> Feedback<…>` method that is never called, it emits a warning. + +Note that this rule can have false positives in rare cases. Especially if you use constructs like `obj.map(Self.whenBlah)`, it doesn't detect `whenBlah` as a method call because it is encapsulated inside a `map`. This is why this rule is only a warning. + +(It still detects `Feedbacks` called conditionally though – like `if (cond) { feedbacks += Self.whenBlah() }` – and should still catch the most common cases of forgetting to add a newly-created `Feedback` to the state machine) + ## swiftlint > * Declared in: `danger-ci/swiftlint.rb`