diff options
author | Thiago Marcos P. Santos <tmpsantos@gmail.com> | 2019-05-20 14:23:39 +0300 |
---|---|---|
committer | Thiago Marcos P. Santos <tmpsantos@gmail.com> | 2019-05-21 01:04:01 +0300 |
commit | 88ef7d89c46b4c4e6e8ad84a5c8e9f410ef6d3cb (patch) | |
tree | eebed2cf856394181e164c15b7421f22a0fc8c99 /benchmark | |
parent | 19f5686eb21c9499e5cc34d217308aa99f31c666 (diff) | |
download | qtlocation-mapboxgl-88ef7d89c46b4c4e6e8ad84a5c8e9f410ef6d3cb.tar.gz |
[benchmark] Add benchmark for tile invalidation
Diffstat (limited to 'benchmark')
-rw-r--r-- | benchmark/benchmark-files.json | 1 | ||||
-rw-r--r-- | benchmark/storage/offline_database.benchmark.cpp | 54 |
2 files changed, 55 insertions, 0 deletions
diff --git a/benchmark/benchmark-files.json b/benchmark/benchmark-files.json index e3ad80072b..a05fdfc4c2 100644 --- a/benchmark/benchmark-files.json +++ b/benchmark/benchmark-files.json @@ -10,6 +10,7 @@ "benchmark/parse/tile_mask.benchmark.cpp", "benchmark/parse/vector_tile.benchmark.cpp", "benchmark/src/mbgl/benchmark/benchmark.cpp", + "benchmark/storage/offline_database.benchmark.cpp", "benchmark/util/dtoa.benchmark.cpp", "benchmark/util/tilecover.benchmark.cpp" ], diff --git a/benchmark/storage/offline_database.benchmark.cpp b/benchmark/storage/offline_database.benchmark.cpp new file mode 100644 index 0000000000..2adce537f0 --- /dev/null +++ b/benchmark/storage/offline_database.benchmark.cpp @@ -0,0 +1,54 @@ +#include <benchmark/benchmark.h> + +#include <mbgl/storage/offline_database.hpp> +#include <mbgl/storage/resource.hpp> +#include <mbgl/storage/response.hpp> +#include <mbgl/storage/sqlite3.hpp> +#include <mbgl/util/string.hpp> + +class OfflineDatabase : public benchmark::Fixture { +public: + void SetUp(const ::benchmark::State&) override { + using namespace mbgl; + using namespace std::chrono_literals; + + const unsigned tileCount = 10000; + db.setOfflineMapboxTileCountLimit(tileCount * 2); + + Response response; + response.noContent = true; + response.mustRevalidate = false; + response.expires = util::now() + 1h; + + for (unsigned i = 0; i < tileCount; ++i) { + const Resource ambient = Resource::tile("mapbox://tile_ambient" + util::toString(i), 1, 0, 0, 0, Tileset::Scheme::XYZ); + db.put(ambient, response); + } + + OfflineTilePyramidRegionDefinition definition{ "mapbox://style", LatLngBounds::hull({1, 2}, {3, 4}), 5, 6, 2.0, true }; + OfflineRegionMetadata metadata{{ 1, 2, 3 }}; + + auto region = db.createRegion(definition, metadata); + regionID = region->getID(); + + for (unsigned i = 0; i < tileCount; ++i) { + const Resource offline = Resource::tile("mapbox://tile_offline_region" + util::toString(i), 1.0, 0, 0, 0, Tileset::Scheme::XYZ); + db.putRegionResource(regionID, offline, response); + } + } + + mbgl::OfflineDatabase db{":memory:"}; + int64_t regionID; +}; + +BENCHMARK_F(OfflineDatabase, InvalidateRegion)(benchmark::State& state) { + for (auto _ : state) { + db.invalidateRegion(regionID); + } +} + +BENCHMARK_F(OfflineDatabase, InvalidateTileCache)(benchmark::State& state) { + for (auto _ : state) { + db.invalidateTileCache(); + } +} |