GeolocationClientMock.cpp [plain text]
#include "config.h"
#include "GeolocationClientMock.h"
#if ENABLE(GEOLOCATION)
#include "GeolocationController.h"
#include "GeolocationError.h"
#include "GeolocationPosition.h"
namespace WebCore {
GeolocationClientMock::GeolocationClientMock()
: m_controller(0)
, m_hasError(false)
, m_controllerTimer(*this, &GeolocationClientMock::controllerTimerFired)
, m_permissionTimer(*this, &GeolocationClientMock::permissionTimerFired)
, m_isActive(false)
, m_permissionState(PermissionStateUnset)
{
}
GeolocationClientMock::~GeolocationClientMock()
{
ASSERT(!m_isActive);
}
void GeolocationClientMock::setController(GeolocationController *controller)
{
ASSERT(controller && !m_controller);
m_controller = controller;
}
void GeolocationClientMock::setPosition(GeolocationPosition&& position)
{
m_lastPosition = WTFMove(position);
clearError();
asyncUpdateController();
}
void GeolocationClientMock::setPositionUnavailableError(const String& errorMessage)
{
m_hasError = true;
m_errorMessage = errorMessage;
m_lastPosition = std::nullopt;
asyncUpdateController();
}
void GeolocationClientMock::setPermission(bool allowed)
{
m_permissionState = allowed ? PermissionStateAllowed : PermissionStateDenied;
asyncUpdatePermission();
}
int GeolocationClientMock::numberOfPendingPermissionRequests() const
{
return m_pendingPermission.size();
}
void GeolocationClientMock::requestPermission(Geolocation& geolocation)
{
m_pendingPermission.add(&geolocation);
if (m_permissionState != PermissionStateUnset)
asyncUpdatePermission();
}
void GeolocationClientMock::cancelPermissionRequest(Geolocation& geolocation)
{
m_pendingPermission.remove(&geolocation);
if (m_pendingPermission.isEmpty() && m_permissionTimer.isActive())
m_permissionTimer.stop();
}
void GeolocationClientMock::asyncUpdatePermission()
{
ASSERT(m_permissionState != PermissionStateUnset);
if (!m_permissionTimer.isActive())
m_permissionTimer.startOneShot(0_s);
}
void GeolocationClientMock::permissionTimerFired()
{
ASSERT(m_permissionState != PermissionStateUnset);
bool allowed = m_permissionState == PermissionStateAllowed;
GeolocationSet::iterator end = m_pendingPermission.end();
for (GeolocationSet::iterator it = m_pendingPermission.begin(); it != end; ++it)
(*it)->setIsAllowed(allowed);
m_pendingPermission.clear();
}
void GeolocationClientMock::reset()
{
m_lastPosition = std::nullopt;
clearError();
m_permissionState = PermissionStateUnset;
}
void GeolocationClientMock::geolocationDestroyed()
{
ASSERT(!m_isActive);
}
void GeolocationClientMock::startUpdating()
{
ASSERT(!m_isActive);
m_isActive = true;
asyncUpdateController();
}
void GeolocationClientMock::stopUpdating()
{
ASSERT(m_isActive);
m_isActive = false;
m_controllerTimer.stop();
}
void GeolocationClientMock::setEnableHighAccuracy(bool)
{
}
std::optional<GeolocationPosition> GeolocationClientMock::lastPosition()
{
return m_lastPosition;
}
void GeolocationClientMock::asyncUpdateController()
{
ASSERT(m_controller);
if (m_isActive && !m_controllerTimer.isActive())
m_controllerTimer.startOneShot(0_s);
}
void GeolocationClientMock::controllerTimerFired()
{
ASSERT(m_controller);
if (m_lastPosition) {
ASSERT(!m_hasError);
m_controller->positionChanged(*m_lastPosition);
} else if (m_hasError) {
auto geolocatioError = GeolocationError::create(GeolocationError::PositionUnavailable, m_errorMessage);
m_controller->errorOccurred(geolocatioError.get());
}
}
void GeolocationClientMock::clearError()
{
m_hasError = false;
m_errorMessage = String();
}
}
#endif // ENABLE(GEOLOCATION)