Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit fca4de4e authored by Treehugger Robot's avatar Treehugger Robot Committed by Automerger Merge Worker
Browse files

Merge "Trigger reevaluation of all requests when mobile data state changes"...

Merge "Trigger reevaluation of all requests when mobile data state changes" am: 5a2abf13 am: aa5e3e21 am: 0ad647a6 am: 36c49f6d

Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/1692660

Change-Id: I039a1f8d94c587f03c335a1808679b4349db0375
parents 4ef70b94 36c49f6d
Loading
Loading
Loading
Loading
+12 −0
Original line number Diff line number Diff line
@@ -396,6 +396,15 @@ public class Vcn extends Handler {
                    continue;
                }

                // This should never happen, by virtue of checking for the above check for
                // pre-existing VcnGatewayConnections that satisfy a given request, but if state
                // that affects the satsifying of requests changes, this is theoretically possible.
                if (mVcnGatewayConnections.containsKey(gatewayConnectionConfig)) {
                    Slog.wtf(getLogTag(), "Attempted to bring up VcnGatewayConnection for config "
                            + "with existing VcnGatewayConnection");
                    return;
                }

                final VcnGatewayConnection vcnGatewayConnection =
                        mDeps.newVcnGatewayConnection(
                                mVcnContext,
@@ -467,6 +476,9 @@ public class Vcn extends Handler {
                    }
                }
            }

            // Trigger re-evaluation of all requests; mobile data state impacts supported caps.
            mVcnContext.getVcnNetworkProvider().resendAllRequests(mRequestListener);
        }
    }

+5 −1
Original line number Diff line number Diff line
@@ -388,8 +388,9 @@ public class VcnTest {
        final ContentObserver contentObserver = captor.getValue();

        // Start VcnGatewayConnections
        final NetworkRequestListener requestListener = verifyAndGetRequestListener();
        mVcn.setMobileDataEnabled(startingToggleState);
        triggerVcnRequestListeners(verifyAndGetRequestListener());
        triggerVcnRequestListeners(requestListener);
        final Map<VcnGatewayConnectionConfig, VcnGatewayConnection> gateways =
                mVcn.getVcnGatewayConnectionConfigMap();

@@ -411,6 +412,9 @@ public class VcnTest {
            }
        }

        if (startingToggleState != endingToggleState) {
            verify(mVcnNetworkProvider).resendAllRequests(requestListener);
        }
        assertEquals(endingToggleState, mVcn.isMobileDataEnabled());
    }