// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "ash/system/geolocation/test_geolocation_url_loader_factory.h"
#include <memory>
#include "base/json/json_string_value_serializer.h"
namespace ash {
namespace {
// Creates a serialized dictionary string of the geoposition.
std::string CreateResponseBody(const Geoposition& position) {
base::Value::Dict value;
value.Set("accuracy", position.accuracy);
base::Value::Dict location;
location.Set("lat", position.latitude);
location.Set("lng", position.longitude);
value.Set("location", std::move(location));
if (position.error_code) {
base::Value::Dict error;
error.Set("error_code", position.error_code);
value.Set("error", std::move(error));
}
std::string serialized_response;
JSONStringValueSerializer serializer(&serialized_response);
serializer.Serialize(value);
return serialized_response;
}
} // namespace
TestGeolocationUrlLoaderFactory::TestGeolocationUrlLoaderFactory() = default;
void TestGeolocationUrlLoaderFactory::CreateLoaderAndStart(
mojo::PendingReceiver<network::mojom::URLLoader> receiver,
int32_t request_id,
uint32_t options,
const network::ResourceRequest& url_request,
mojo::PendingRemote<network::mojom::URLLoaderClient> client,
const net::MutableNetworkTrafficAnnotationTag& traffic_annotation) {
// Response must be added before `CreateLoaderAndStart()` to ensure the latest
// `position_` is reflected in the incoming request.
test_url_loader_factory_.AddResponse(url_request.url.spec(),
CreateResponseBody(position_));
test_url_loader_factory_.CreateLoaderAndStart(
std::move(receiver), request_id, options, url_request, std::move(client),
traffic_annotation);
}
void TestGeolocationUrlLoaderFactory::Clone(
mojo::PendingReceiver<network::mojom::URLLoaderFactory> receiver) {
NOTREACHED();
}
std::unique_ptr<network::PendingSharedURLLoaderFactory>
TestGeolocationUrlLoaderFactory::Clone() {
NOTREACHED();
}
void TestGeolocationUrlLoaderFactory::SetValidPosition(double latitude,
double longitude,
base::Time timestamp) {
position_ = Geoposition();
position_.latitude = latitude;
position_.longitude = longitude;
position_.status = Geoposition::STATUS_OK;
position_.accuracy = 10;
position_.timestamp = timestamp;
CHECK(position_.Valid());
}
void TestGeolocationUrlLoaderFactory::ClearResponses() {
test_url_loader_factory_.ClearResponses();
}
TestGeolocationUrlLoaderFactory::~TestGeolocationUrlLoaderFactory() = default;
} // namespace ash