-
-
Notifications
You must be signed in to change notification settings - Fork 668
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
Add feature flag concept and screen #4760
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please take a look at the requested changes, and use the Ready for review button when you are done, thanks 👍 |
<string name="feature_flag">Feature flag</string> | ||
<string name="feature_flag_summary">Manage feature flags for the app (advanced users only). Proceed with caution, as this area contains experimental features that may affect stability.</string> | ||
<string name="string_feature_flag_update">Update</string> | ||
<string name="string_feature_flag_cancel">Cancel</string> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think I can add this new keys myself in Lokalise.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If your PR is accepted and merged, Lokalise will pick up the new strings automatically
@@ -67,6 +67,28 @@ jobs: | |||
- name: Validate Lint | |||
run: ./gradlew lint | |||
|
|||
unit_tests: |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is a very basic job, that most probably should evolve over time.
4f49787
to
921506a
Compare
Could you bring some examples where you see this feature flag engine relevant for future HA features? Also have in mind the open source contributors and their interact with it. On the iOS side I haven't felt the need for feature flags yet (even though I worked with a similar approach in past companies I worked on), so I am curious about your perspective. |
A bit of background about why I brought this to the project: initially, I was annoyed with the dialog in the Launcher when my connection was off, and I thought I could make it nicer with a proper screen and a nice icon. But while looking at the code, I found some complex code that could be simplified. I then told myself that I could bring this feature toggle capacity to the project without breaking everything so that later, in a second PR, I can use it to bring this new screen while keeping the other one until we agree if it is the way to go. Generally speaking, I think that large-scale refactors can sometimes be challenging for reviewers/writers, and breaking them down into smaller, manageable PRs that are feature-flagged would allow changes to go through CI and get faster feadback on the design without impacting the main application. This approach keeps PRs digestible while making continuous improvements possible and avoids long-lived branches. Another potential use is A/B testing. While this PR doesn’t enable A/B testing directly, the design is extensible for that purpose. Testing features selectively before a full release would allow us to gather valuable feedback from the community and validate changes. Considering I’m still getting familiar with the codebase, these examples may not be the most precise, but here are some potential areas that could benefit from feature flags:
I might be biased by my past experiences, and I would happily discuss it if you think it won't bring value to HA. |
I see the value on it and I apretiate you sharing your past experience, I'd say this becomes interesting as soon as we have a real need for it, for now we focus on small PRs, with single purpose, that can be merged without breaking the rest of the code, for a big refacture, perhaps a feature flag engine could be helpful, on the other hand it's usually possible to breakdown refactors as well. About A/B testing, we don't collect user data, as one of our privacy principles from the Open Home Foundation/Home Assistant. We have a call today and we can discuss this more in depth, meanwhile @jpelgrom @dshokouhi are the right people to decide if this can be helpful for android right now or perhaps hold for future use cases. |
While I do see the value of such a feature in general and for the developer while working on PR, I still don't fully see how it would benefit Home Assistant.
At a quick glance, the code looks fine. Did you also write/contribute to the blog post you've linked as it is from your current company? |
I was more thinking about the case where the refactoring is done partially. Imagine that we redo a big Activity with multiple fragments to Compose with the navigation library. In that case, I would expect to have a first PR with a feature flag defined, and then subsequent PRs for each fragment transition to the new system. Finally, one last PR would remove the flag and the old code. With this approach, everything can be merged quickly to main without losing any features. I don't know the code base well enough to say that this case will happen. When it comes to the A/B testing, I'm fully aligned with the privacy concern, and I wouldn't want my data collected. I was more thinking about getting feedback on GitHub or Discord from the users about, let's say, a new UI that we want to test. I guess that there is inside the community users that would be ok testing new things and give us feedbacks.
I'm not sure I follow. Are you referring to my point on Gemini? If so, I was thinking about the local usage of LLM models. Today, I'm experimenting with running "small" LLMs locally, as the latest flagship devices come with significant power and dedicated hardware. It could be nice to leverage that. Again, I'm aligned with the privacy concerns, which is why I would prefer to keep the LLM running locally on open source libraries that is not collecting data. I fully agree that forcing people to use this framework can be too complex. It probably shouldn't be forced. Maybe sometimes the reviewers could suggest splitting the PR if it's too big using feature flags or if the feature needs testing before broader deployment. When it comes to the blog post, in my current position, I'm supervising the writing in the blog, contribute through reviews and approve the publications. |
Summary
This PR introduces a feature management system to streamline future development, laying a flexible foundation designed to adapt as needs evolve. A new UI for managing feature toggles is available in the troubleshooting menu, allowing features to be controlled directly from the app.
Additionally, this update includes unit tests for feature-related functionality and a CI job to execute them automatically on each PR.
This design takes inspiration from Baracoda’s blog on trunk-based development.
Screenshots
dark.mp4
Any other notes
This is my first contribution to Home Assistant, and I tried to keep the existing structure and conventions.