-
Notifications
You must be signed in to change notification settings - Fork 12
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
feat!: correct configuration params, stream reconnects, add tests #104
base: main
Are you sure you want to change the base?
feat!: correct configuration params, stream reconnects, add tests #104
Conversation
2db5904
to
e826b3d
Compare
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## main #104 +/- ##
==========================================
- Coverage 94.36% 88.00% -6.37%
==========================================
Files 14 3 -11
Lines 746 150 -596
==========================================
- Hits 704 132 -572
+ Misses 42 18 -24 ☔ View full report in Codecov by Sentry. |
e826b3d
to
96ecdc1
Compare
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
Signed-off-by: Cole Bailey <[email protected]>
96ecdc1
to
8a15f87
Compare
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
8a15f87
to
36269b5
Compare
return | ||
except grpc.RpcError as e: | ||
logger.error(f"SyncFlags stream error, {e.code()=} {e.details()=}") | ||
if e.code() == grpc.StatusCode.UNAVAILABLE: |
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.
destroying the existing channel, and creating a new one, actually fixed the reconnect issue. i am not sure, if this is best practice, or should be avoided.
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 wonder if we need to handle more cases than this? UNKNOWN
perhaps? Just wondering if other sorts of network errors that result in the same bad state might not be handled because they return a different status.
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.
For me it is really hard to judge, my grpc knowledge is Limited, and I would fully rely on your opinion. If you do think it make sense let's go for it.
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.
My gut says since we don't 100% understand why we observe this behavior, we should play it safe and recreate the stub on any grpc.RpcError
; in particular I'm worried that if we don't, the stream deadline functionality might not work reliably.
I think there's not much risk here since this is only for the stream call and if we're having a problem with that, pretty much nothing else in this resolver mode is working anyway.
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.
Done here: f91dd5c
Signed-off-by: Simon Schrottner <[email protected]>
@gruebel I am with you that this PR is quite large and is much work to review and that each PR should in the best case be tackling one thing. But I would like to be sure that we look for a way forward instead of "just rejecting". We should be sure that the change can even be untangled before saying that we are not accepting anything because of size or multiple solved issues. Maybe @aepfli can tell if these are separable or we just accept this once and review this large PR, while keeping on to try to do PRs as small as possible. |
I can, and gladly will split it up into 4 parts again:
The config adaptations (Ms and seconds) also make sense because this syncs the behavior of environment flags for all providers. Java is in MS and is, IMHO, the most advanced provider for flags; hence, we should adhere to its environment variables usage and values, or else we have way more things to change. We use the same environment variables to make it easy to configure multiple providers with the same environment variables. This provider did not reach version 1, making it a better target than Java. The same applies to the resolver's name. Everywhere else, it is named RPC; here, we do have GRPC. We should normalize this for consistency and easier maintenance in the long run. A good thing is that all the features implemented fulfill the test-harness gherkin files. We're compliant with the expectations of flagd for a provider - confidence we did not have before. I also suggest not looking for perfect code; this confidence allows us to iterate faster and ship improvements confidently. |
Thanks @aepfli! That should make it easier to review and make our release notes more accurate. |
Besides the fact this is what Java does, these are actually in the spec for flagd providers, and are important for interop with the Operator. But it sounds like we have a plan for moving forward! Feel free to link your other PRs to this one and close this one whenever @aepfli |
this one is the last in the chain, i will update it and mark it as soon as we are ready |
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
Signed-off-by: Simon Schrottner <[email protected]>
28914fa
to
6b21f96
Compare
Signed-off-by: Simon Schrottner <[email protected]>
6b21f96
to
a37e5a3
Compare
4db7a48
to
cda7342
Compare
I merged all the previous work, and updated the implementation to match our latest findings regarding grpc. - there is room for improvements, eg. removing duplication between rpc and in-process for grpc connection etc. but i do think, this is something we can do in another step. should i open a new pull request, or will we continue from here? |
c9bab7f
to
8945ff2
Compare
…tion Signed-off-by: Simon Schrottner <[email protected]>
8945ff2
to
77b9eb8
Compare
This pull request contains all my previous changes. and it has all the configuration properties maintained for everything.
I changed the times for the initialization to ms - to be in sync configuration-wise with the Java application (which might not be a good idea)
I removed
timeout
and replaced it withdeadline
; additionally, I added a deprecation note.Every Implementation does not take all the corresponding configurations into account.
Resolves: #57
Resolves: #56
Resolves: #55