Files
iOS/Tests/App/WebView/Mocks/MockWebViewController.swift
Bruno Pantaleão Gonçalves 65316f2602 Check connection state before auto reload webview (#4364)
<!-- Thank you for submitting a Pull Request and helping to improve Home
Assistant. Please complete the following sections to help the processing
and review of your changes. Please do not delete anything from this
template. -->

## Summary
<!-- Provide a brief summary of the changes you have made and most
importantly what they aim to achieve -->
Recently it was introduced a feature to reload webview when app has been
backgrounded for more than 5 minutes, this PR adds a layer on top of it
that only reloads if the webview frontend connection state is not
connected.


## Screenshots
<!-- If this is a user-facing change not in the frontend, please include
screenshots in light and dark mode. -->

## Link to pull request in Documentation repository
<!-- Pull requests that add, change or remove functionality must have a
corresponding pull request in the Companion App Documentation repository
(https://github.com/home-assistant/companion.home-assistant). Please add
the number of this pull request after the "#" -->
Documentation: home-assistant/companion.home-assistant#

## Any other notes
<!-- If there is any other information of note, like if this Pull
Request is part of a bigger change, please include it here. -->

---------

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
2026-02-18 11:13:20 +01:00

109 lines
3.2 KiB
Swift

import Foundation
@testable import HomeAssistant
import Shared
import UIKit
final class MockWebViewController: WebViewControllerProtocol {
var webViewExternalMessageHandler: WebViewExternalMessageHandlerProtocol
var canGoBack: Bool = false
var canGoForward: Bool = false
var traitCollection: UITraitCollection = .init()
var server: Server = ServerFixture.standard
var connectionState: FrontEndConnectionState = .connected
var overlayedController: UIViewController?
var presentOverlayControllerCalled = false
var presentControllerCalled = false
var evaluateJavaScriptCalled = false
var lastEvaluatedJavaScriptScript: String?
var lastEvaluatedJavaScriptCompletion: ((Any?, (any Error)?) -> Void)?
var dismissControllerAboveOverlayControllerCalled = false
var dismissOverlayControllerCalled = false
var dismissOverlayControllerLastAnimated = false
var dismissOverlayControllerLastCompletion: (() -> Void)?
var updateSettingsButtonCalled = false
var lastSettingButtonState: String?
var navigateToPathCalled = false
var lastNavigateToPathPath: String?
var updateImprovEntryViewCalled = false
var lastUpdateImprovEntryViewState = false
var refreshCalled = false
var presentAlertControllerCalled = false
init() {
self.webViewExternalMessageHandler = MockWebViewExternalMessageHandler()
}
func load(request: URLRequest) {
// Simulate loading a request
}
func showSettingsViewController() {
// Simulate showing settings
}
func openDebug() {
// Simulate opening debug view
}
func goBack() {
// Simulate going back
}
func goForward() {
// Simulate going forward
}
func styleUI() {
// Simulate styling UI
}
func presentOverlayController(controller: UIViewController, animated: Bool) {
presentOverlayControllerCalled = true
overlayedController = controller
}
func evaluateJavaScript(_ script: String, completion: ((Any?, (any Error)?) -> Void)?) {
evaluateJavaScriptCalled = true
lastEvaluatedJavaScriptScript = script
lastEvaluatedJavaScriptCompletion = completion
}
func dismissOverlayController(animated: Bool, completion: (() -> Void)?) {
dismissOverlayControllerCalled = true
dismissOverlayControllerLastAnimated = animated
dismissOverlayControllerLastCompletion = completion
}
func dismissControllerAboveOverlayController() {
dismissControllerAboveOverlayControllerCalled = true
}
func updateFrontendConnectionState(state: String) {
updateSettingsButtonCalled = true
lastSettingButtonState = state
}
func updateImprovEntryView(show: Bool) {
updateImprovEntryViewCalled = true
lastUpdateImprovEntryViewState = show
}
func navigateToPath(path: String) {
navigateToPathCalled = true
lastNavigateToPathPath = path
}
func refresh() {
refreshCalled = true
}
func refreshIfDisconnected() {
// Simulate conditional refresh
}
func presentAlertController(controller: UIViewController, animated: Bool) {
presentAlertControllerCalled = true
}
}