diff --git a/docs/adr/memory_leak_tracking/0001-dispose-valuenotifier-when-not-used.md b/docs/adr/memory_leak_tracking/0001-dispose-valuenotifier-when-not-used.md new file mode 100644 index 0000000000..8e5a6806c3 --- /dev/null +++ b/docs/adr/memory_leak_tracking/0001-dispose-valuenotifier-when-not-used.md @@ -0,0 +1,24 @@ +# 1. Dispose ValueNotifier when not used anymore + +Date: 2024-03-05 + +## Status + +Accepted + +## Context + +In our UI code, ValueNotifier is frequently used for its simplicity and robustness in rebuilding widgets. However, post-utilization management of ValueNotifier is often neglected. Proper handling of ValueNotifier is crucial for stabilizing memory usage and enhancing app performance. + +## Decision + +Typically, ValueNotifiers are disposed of in the `dispose()` method within widget lifecycles. However, exceptions occur in scenarios involving interactors. Some interactors continue to use ValueNotifier even after yielding a state, due to their singleton nature. Disposing of ValueNotifier immediately after widget disposal can lead to exceptions because the interactor may still be active. To address this, we propose two solutions: +1. Dispose of the ValueNotifier when the interactor's activity concludes. +2. Refrain from using ValueNotifier in conjunction with interactors. + +- Tickets references: +1. TW-1650: dispose ValueNotifier when not use anymore in video player +2. About the VideoPlayer (there are still some leakings, but its not critical right now - we wait for the owner's response - (here)[https://github.com/media-kit/media-kit/issues/776]) +## Consequences + +Implementing these practices ensures that ValueNotifiers are properly collected by the garbage collector, eliminating memory leaks associated with their misuse. This decision fosters more reliable and efficient memory management within our applications. \ No newline at end of file diff --git a/docs/adr/memory_leak_tracking/0002-cancel-stream-subscription-when-not-used.md b/docs/adr/memory_leak_tracking/0002-cancel-stream-subscription-when-not-used.md new file mode 100644 index 0000000000..fa4e70d28b --- /dev/null +++ b/docs/adr/memory_leak_tracking/0002-cancel-stream-subscription-when-not-used.md @@ -0,0 +1,22 @@ +# 2. Cancel the stream subscription when not listen to its anymore + +Date: 2024-03-05 + +## Status + +Accepted + +## Context + +Our application extensively utilizes Streams for data handling. Given that some of these Streams are singleton and others are not, managing StreamSubscriptions is crucial. For instance, each Timeline object initiates three StreamSubscriptions. Without proper cancellation of these subscriptions, memory leaks occur. + +## Decision + +Specifically, within the `getTimeline()` method, Timeline objects are generated primarily for their callbacks, leading to the neglect of the actual objects. This oversight results in the leakage of three StreamSubscriptions per Timeline. Notably, during the initialization of the chat screen, `getTimeline()` is invoked multiple times, significantly increasing the risk of memory leaks. The resolved approach is to actively manage Timeline objects and ensure all associated StreamSubscriptions are canceled when they are no longer needed. + +- Tickets references: +1. TW-1650: cancel StreamSubscription of timeline when not used anymore + +## Consequences + +By implementing this strategy, we substantially free up memory resources. Additionally, since some StreamSubscriptions are linked to substantial objects, managing these subscriptions effectively also releases these heavy objects from memory, enhancing overall application performance. diff --git a/docs/adr/memory_leak_tracking/0003-do-not-set-null-to-variable-after-cancel.md b/docs/adr/memory_leak_tracking/0003-do-not-set-null-to-variable-after-cancel.md new file mode 100644 index 0000000000..b2eff79b0b --- /dev/null +++ b/docs/adr/memory_leak_tracking/0003-do-not-set-null-to-variable-after-cancel.md @@ -0,0 +1,23 @@ +# 3. Handling Stream Subscriptions Without Nullifying Variables Post-Cancellation + +Date: 2024-03-05 + +## Status + +Accepted + +## Context + +The `cancel()` method for StreamSubscriptions is asynchronous. A common mistake is to set the variable holding the StreamSubscription to null immediately after calling `cancel()`. Doing so can render the cancellation ineffective, as the nullification may lead to the garbage collector prematurely collecting the subscription before the cancellation has completed. + +## Decision + +We will revise our approach to handling cancellations of StreamSubscriptions. Instead of nullifying the variable immediately, we will retain the reference until the cancellation has fully processed. This ensures the `cancel()` operation can complete effectively. Where possible, it is advisable to await the completion of `cancel()` to ensure proper resource management. + +Ticket References: +1. TW-1650: remove the streamSubcription, listener in chat controller when not used any more +2. TW-1650: must await on cancel before remove item in list + +## Consequences + +By adopting this practice, we prevent potential memory leaks and ensure that StreamSubscriptions are properly disposed of. This adjustment in handling ensures more robust and reliable resource management within our applications.