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(PassRefPtr<GeolocationPosition> position)
{
m_lastPosition = position;
clearError();
asyncUpdateController();
}
void GeolocationClientMock::setPositionUnavailableError(const String& errorMessage)
{
m_hasError = true;
m_errorMessage = errorMessage;
m_lastPosition = nullptr;
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);
}
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 = nullptr;
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)
{
}
GeolocationPosition* GeolocationClientMock::lastPosition()
{
return m_lastPosition.get();
}
void GeolocationClientMock::asyncUpdateController()
{
ASSERT(m_controller);
if (m_isActive && !m_controllerTimer.isActive())
m_controllerTimer.startOneShot(0);
}
void GeolocationClientMock::controllerTimerFired()
{
ASSERT(m_controller);
if (m_lastPosition.get()) {
ASSERT(!m_hasError);
m_controller->positionChanged(m_lastPosition.get());
} else if (m_hasError) {
RefPtr<GeolocationError> geolocatioError = GeolocationError::create(GeolocationError::PositionUnavailable, m_errorMessage);
m_controller->errorOccurred(geolocatioError.get());
}
}
void GeolocationClientMock::clearError()
{
m_hasError = false;
m_errorMessage = String();
}
}
#endif // ENABLE(GEOLOCATION)