diff options
author | Tom Cherry <tomcherry@google.com> | 2017-12-11 23:31:33 -0800 |
---|---|---|
committer | Tom Cherry <tomcherry@google.com> | 2017-12-18 15:17:55 -0800 |
commit | e275d6d72db1868056a204e8483a7346a28cb8d6 (patch) | |
tree | 3191e33ca242518f7d486c6b37212c7f682498b0 /benchmarks | |
parent | 721a5305e24b69b68ecc9431526f32131abc8f6c (diff) | |
download | android_bionic-e275d6d72db1868056a204e8483a7346a28cb8d6.tar.gz android_bionic-e275d6d72db1868056a204e8483a7346a28cb8d6.tar.bz2 android_bionic-e275d6d72db1868056a204e8483a7346a28cb8d6.zip |
Split properties into their own class to make testing better
Reinitializing system properties can result in crashes later in the
program, and is generally not recommended or even supported. This
change moves the actual logic for system properties into a class that
can be tested in isolation, without reinitializing the actual system
property area used in libc.
Bug: 62197783
Test: boot devices, ensure properties work
Test: system property unit tests and benchmarks
Change-Id: I9ae6e1b56c62f51a4d3fdb5b62b8926cef545649
Diffstat (limited to 'benchmarks')
-rw-r--r-- | benchmarks/Android.bp | 5 | ||||
-rw-r--r-- | benchmarks/property_benchmark.cpp | 57 |
2 files changed, 30 insertions, 32 deletions
diff --git a/benchmarks/Android.bp b/benchmarks/Android.bp index c7c8a29e8..be61eda4c 100644 --- a/benchmarks/Android.bp +++ b/benchmarks/Android.bp @@ -61,6 +61,11 @@ cc_benchmark { name: "bionic-benchmarks", defaults: ["bionic-benchmarks-defaults"], data: ["suites/*"], + static_libs: [ + "libsystemproperties", + "libasync_safe", + ], + include_dirs: ["bionic/libc",], } // We don't build a static benchmark executable because it's not usually diff --git a/benchmarks/property_benchmark.cpp b/benchmarks/property_benchmark.cpp index 5760bf109..98687657e 100644 --- a/benchmarks/property_benchmark.cpp +++ b/benchmarks/property_benchmark.cpp @@ -21,37 +21,28 @@ #include <string> +#include <android-base/test_utils.h> + +using namespace std::literals; + #if defined(__BIONIC__) #define _REALLY_INCLUDE_SYS__SYSTEM_PROPERTIES_H_ #include <sys/_system_properties.h> #include <benchmark/benchmark.h> +#include <system_properties/system_properties.h> #include "util.h" struct LocalPropertyTestState { - explicit LocalPropertyTestState(int nprops) : nprops(nprops), valid(false) { + explicit LocalPropertyTestState(int nprops) + : nprops(nprops), valid(false), system_properties_(false) { static const char prop_name_chars[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ-_."; - const char* android_data = getenv("ANDROID_DATA"); - if (android_data == NULL) { - printf("ANDROID_DATA environment variable not set\n"); + valid = system_properties_.AreaInit(dir_.path, nullptr); + if (!valid) { return; } - char dir_template[PATH_MAX]; - snprintf(dir_template, sizeof(dir_template), "%s/local/tmp/prop-XXXXXX", android_data); - char* dirname = mkdtemp(dir_template); - if (!dirname) { - printf("making temp file for test state failed (is %s/local/tmp writable?): %s\n", - android_data, strerror(errno)); - return; - } - - pa_dirname = dirname; - pa_filename = pa_dirname + "/__properties__"; - - __system_property_set_filename(pa_filename.c_str()); - __system_property_area_init(); names = new char* [nprops]; name_lens = new int[nprops]; @@ -88,7 +79,7 @@ struct LocalPropertyTestState { values[i][j] = prop_name_chars[random() % (sizeof(prop_name_chars) - 1)]; } - if (__system_property_add(names[i], name_lens[i], values[i], value_lens[i]) < 0) { + if (system_properties_.Add(names[i], name_lens[i], values[i], value_lens[i]) < 0) { printf("Failed to add a property, terminating...\n"); printf("%s = %.*s\n", names[i], value_lens[i], values[i]); exit(1); @@ -98,14 +89,16 @@ struct LocalPropertyTestState { valid = true; } + SystemProperties& system_properties() { + return system_properties_; + } + ~LocalPropertyTestState() { - if (!valid) + if (!valid) { return; + } - __system_property_set_filename(PROP_FILENAME); - __system_property_area_init(); - unlink(pa_filename.c_str()); - rmdir(pa_dirname.c_str()); + system_properties_.contexts()->FreeAndUnmap(); for (int i = 0; i < nprops; i++) { delete names[i]; @@ -126,8 +119,8 @@ struct LocalPropertyTestState { bool valid; private: - std::string pa_dirname; - std::string pa_filename; + SystemProperties system_properties_; + TemporaryDir dir_; }; static void BM_property_get(benchmark::State& state) { @@ -138,7 +131,7 @@ static void BM_property_get(benchmark::State& state) { while (state.KeepRunning()) { char value[PROP_VALUE_MAX]; - __system_property_get(pa.names[random() % nprops], value); + pa.system_properties().Get(pa.names[random() % nprops], value); } } BIONIC_BENCHMARK_WITH_ARG(BM_property_get, "NUM_PROPS"); @@ -150,7 +143,7 @@ static void BM_property_find(benchmark::State& state) { if (!pa.valid) return; while (state.KeepRunning()) { - __system_property_find(pa.names[random() % nprops]); + pa.system_properties().Find(pa.names[random() % nprops]); } } BIONIC_BENCHMARK_WITH_ARG(BM_property_find, "NUM_PROPS"); @@ -165,12 +158,12 @@ static void BM_property_read(benchmark::State& state) { char propvalue[PROP_VALUE_MAX]; for (size_t i = 0; i < nprops; ++i) { - pinfo[i] = __system_property_find(pa.names[random() % nprops]); + pinfo[i] = pa.system_properties().Find(pa.names[random() % nprops]); } size_t i = 0; while (state.KeepRunning()) { - __system_property_read(pinfo[i], 0, propvalue); + pa.system_properties().Read(pinfo[i], 0, propvalue); i = (i + 1) % nprops; } @@ -186,12 +179,12 @@ static void BM_property_serial(benchmark::State& state) { const prop_info** pinfo = new const prop_info*[nprops]; for (size_t i = 0; i < nprops; ++i) { - pinfo[i] = __system_property_find(pa.names[random() % nprops]); + pinfo[i] = pa.system_properties().Find(pa.names[random() % nprops]); } size_t i = 0; while (state.KeepRunning()) { - __system_property_serial(pinfo[i]); + pa.system_properties().Serial(pinfo[i]); i = (i + 1) % nprops; } |