mirror of
https://github.com/VCMP-SqMod/SqMod.git
synced 2025-01-18 19:47:15 +01:00
Update MaxmindDB to current git.
This commit is contained in:
parent
0008869ddd
commit
69a4d305a5
2
vendor/MaxmindDB/.github/workflows/test.yml
vendored
2
vendor/MaxmindDB/.github/workflows/test.yml
vendored
@ -41,6 +41,6 @@ jobs:
|
|||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
with:
|
with:
|
||||||
submodules: true
|
submodules: true
|
||||||
- run: cmake -DBUILD_TESTING=ON -V .
|
- run: cmake -DBUILD_TESTING=ON .
|
||||||
- run: cmake --build .
|
- run: cmake --build .
|
||||||
- run: ctest -V .
|
- run: ctest -V .
|
||||||
|
3
vendor/MaxmindDB/.gitignore
vendored
3
vendor/MaxmindDB/.gitignore
vendored
@ -1,3 +1,4 @@
|
|||||||
|
*.a
|
||||||
*.la
|
*.la
|
||||||
*.lo
|
*.lo
|
||||||
*.o
|
*.o
|
||||||
@ -25,13 +26,11 @@
|
|||||||
/man
|
/man
|
||||||
/missing
|
/missing
|
||||||
/src/libmaxminddb.pc
|
/src/libmaxminddb.pc
|
||||||
/src/libmaxminddb.a
|
|
||||||
/src/test-data-pool
|
/src/test-data-pool
|
||||||
/t/*.log
|
/t/*.log
|
||||||
/t/*.trs
|
/t/*.trs
|
||||||
/t/*_t
|
/t/*_t
|
||||||
/t/*-t
|
/t/*-t
|
||||||
/t/libtap.a
|
|
||||||
/test-driver
|
/test-driver
|
||||||
\#*\#
|
\#*\#
|
||||||
aclocal.m4
|
aclocal.m4
|
||||||
|
78
vendor/MaxmindDB/.uncrustify.cfg
vendored
78
vendor/MaxmindDB/.uncrustify.cfg
vendored
@ -1,78 +0,0 @@
|
|||||||
#
|
|
||||||
# based on uncrustify config file for the linux kernel
|
|
||||||
#
|
|
||||||
|
|
||||||
code_width = 80
|
|
||||||
indent_case_brace = 4
|
|
||||||
indent_columns = 4
|
|
||||||
indent_label = 2 # pos: absolute col, neg: relative column
|
|
||||||
indent_with_tabs = 0
|
|
||||||
|
|
||||||
#
|
|
||||||
# inter-symbol newlines
|
|
||||||
#
|
|
||||||
nl_brace_else = remove # "} else" vs "} \n else" - cuddle else
|
|
||||||
nl_brace_while = remove # "} while" vs "} \n while" - cuddle while
|
|
||||||
nl_do_brace = remove # "do {" vs "do \n {"
|
|
||||||
nl_else_brace = remove # "else {" vs "else \n {"
|
|
||||||
nl_enum_brace = remove # "enum {" vs "enum \n {"
|
|
||||||
nl_fcall_brace = remove # "list_for_each() {" vs "list_for_each()\n{"
|
|
||||||
nl_fdef_brace = force # "int foo() {" vs "int foo()\n{"
|
|
||||||
nl_for_brace = remove # "for () {" vs "for () \n {"
|
|
||||||
nl_func_var_def_blk = 0 # don't add newlines after a block of var declarations
|
|
||||||
nl_if_brace = remove # "if () {" vs "if () \n {"
|
|
||||||
nl_multi_line_define = true
|
|
||||||
nl_struct_brace = remove # "struct {" vs "struct \n {"
|
|
||||||
nl_switch_brace = remove # "switch () {" vs "switch () \n {"
|
|
||||||
nl_union_brace = remove # "union {" vs "union \n {"
|
|
||||||
nl_while_brace = remove # "while () {" vs "while () \n {"
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# Source code modifications
|
|
||||||
#
|
|
||||||
mod_full_brace_do = force # "do a--; while ();" vs "do { a--; } while ();"
|
|
||||||
mod_full_brace_for = force # "for () a--;" vs "for () { a--; }"
|
|
||||||
mod_full_brace_if = force # "if (a) a--;" vs "if (a) { a--; }"
|
|
||||||
mod_full_brace_nl = 3 # don't remove if more than 3 newlines
|
|
||||||
mod_full_brace_while = force # "while (a) a--;" vs "while (a) { a--; }"
|
|
||||||
mod_paren_on_return = remove # "return 1;" vs "return (1);"
|
|
||||||
|
|
||||||
|
|
||||||
#
|
|
||||||
# inter-character spacing options
|
|
||||||
#
|
|
||||||
sp_after_cast = remove # "(int) a" vs "(int)a"
|
|
||||||
sp_after_comma = force
|
|
||||||
sp_after_sparen = force # "if () {" vs "if (){"
|
|
||||||
sp_arith = force
|
|
||||||
sp_assign = force
|
|
||||||
sp_assign = force
|
|
||||||
sp_before_comma = remove
|
|
||||||
sp_before_ptr_star = force # "char *foo" vs "char* foo
|
|
||||||
sp_before_sparen = force # "if (" vs "if("
|
|
||||||
sp_between_ptr_star = remove # "char * *foo" vs "char **foo"
|
|
||||||
sp_bool = force
|
|
||||||
sp_compare = force
|
|
||||||
sp_func_call_paren = remove # "foo (" vs "foo("
|
|
||||||
sp_func_def_paren = remove # "int foo (){" vs "int foo(){"
|
|
||||||
sp_func_proto_paren = remove # "int foo ();" vs "int foo();"
|
|
||||||
sp_inside_braces = force # "{ 1 }" vs "{1}"
|
|
||||||
sp_inside_braces_enum = force # "{ 1 }" vs "{1}"
|
|
||||||
sp_inside_braces_struct = force # "{ 1 }" vs "{1}"
|
|
||||||
sp_inside_sparen = remove
|
|
||||||
sp_paren_brace = force
|
|
||||||
sp_sizeof_paren = remove # "sizeof (int)" vs "sizeof(int)"
|
|
||||||
|
|
||||||
#
|
|
||||||
# Aligning stuff
|
|
||||||
#
|
|
||||||
align_enum_equ_span = 4 # '=' in enum definition
|
|
||||||
align_nl_cont = true
|
|
||||||
align_on_tabstop = FALSE # align on tabstops
|
|
||||||
align_right_cmt_span = 3
|
|
||||||
align_struct_init_span = 1
|
|
||||||
align_struct_init_span = 3 # align stuff in a structure init '= { }'
|
|
||||||
align_var_def_star_style = 2 # void *foo;
|
|
||||||
align_var_struct_span = 0
|
|
||||||
align_with_tabs = FALSE # use tabs to align
|
|
53
vendor/MaxmindDB/CMakeLists.txt
vendored
53
vendor/MaxmindDB/CMakeLists.txt
vendored
@ -1,12 +1,18 @@
|
|||||||
cmake_minimum_required (VERSION 3.7)
|
cmake_minimum_required (VERSION 3.9)
|
||||||
|
|
||||||
project(maxminddb
|
project(maxminddb
|
||||||
LANGUAGES C
|
LANGUAGES C
|
||||||
VERSION 1.5.0
|
VERSION 1.6.0
|
||||||
)
|
)
|
||||||
set(MAXMINDDB_SOVERSION 0.0.7)
|
set(MAXMINDDB_SOVERSION 0.0.7)
|
||||||
|
set(CMAKE_C_STANDARD 99)
|
||||||
|
set(CMAKE_C_EXTENSIONS OFF)
|
||||||
|
|
||||||
|
if (WIN32)
|
||||||
|
option(MSVC_STATIC_RUNTIME "When ON the library will be built by using MT/MTd run-time libraries" OFF)
|
||||||
|
endif()
|
||||||
option(BUILD_SHARED_LIBS "Build shared libraries (.dll/.so) instead of static ones (.lib/.a)" OFF)
|
option(BUILD_SHARED_LIBS "Build shared libraries (.dll/.so) instead of static ones (.lib/.a)" OFF)
|
||||||
option(BUILD_TESTING "Build test programs" OFF)
|
option(BUILD_TESTING "Build test programs" ON)
|
||||||
|
|
||||||
include(CheckTypeSize)
|
include(CheckTypeSize)
|
||||||
check_type_size("unsigned __int128" UINT128)
|
check_type_size("unsigned __int128" UINT128)
|
||||||
@ -30,7 +36,7 @@ if (${CMAKE_SYSTEM_NAME} MATCHES "Linux")
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
configure_file(${PROJECT_SOURCE_DIR}/include/maxminddb_config.h.cmake.in
|
configure_file(${PROJECT_SOURCE_DIR}/include/maxminddb_config.h.cmake.in
|
||||||
${CMAKE_CURRENT_BINARY_DIR}/include/maxminddb_config.h)
|
${PROJECT_SOURCE_DIR}/include/maxminddb_config.h)
|
||||||
|
|
||||||
add_library(maxminddb
|
add_library(maxminddb
|
||||||
src/maxminddb.c
|
src/maxminddb.c
|
||||||
@ -52,13 +58,27 @@ endif()
|
|||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
target_link_libraries(maxminddb ws2_32)
|
target_link_libraries(maxminddb ws2_32)
|
||||||
|
if(BUILD_SHARED_LIBS)
|
||||||
|
set_target_properties(maxminddb PROPERTIES WINDOWS_EXPORT_ALL_SYMBOLS ON)
|
||||||
|
endif()
|
||||||
|
if(MSVC_STATIC_RUNTIME)
|
||||||
|
# On MSVC, when MSVC_STATIC_RUNTIME is ON, MT (Release) and MTd (Debug)
|
||||||
|
# run-time libraries will be used instead of MD/MDd. The default is OFF so
|
||||||
|
# MD/MDd are used when nothing related is passed.
|
||||||
|
#
|
||||||
|
# Adapted from https://gitlab.kitware.com/cmake/community/-/wikis/FAQ#make-override-files
|
||||||
|
set(CMAKE_USER_MAKE_RULES_OVERRIDE
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/c_flag_overrides.cmake)
|
||||||
|
set(CMAKE_USER_MAKE_RULES_OVERRIDE_CXX
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/cxx_flag_overrides.cmake)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(CMAKE_SHARED_LIBRARY_PREFIX lib)
|
target_include_directories(maxminddb PUBLIC
|
||||||
set(CMAKE_STATIC_LIBRARY_PREFIX lib)
|
$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}>
|
||||||
|
$<BUILD_INTERFACE:${PROJECT_SOURCE_DIR}/include>
|
||||||
target_include_directories(maxminddb PUBLIC ${CMAKE_CURRENT_BINARY_DIR}/include)
|
$<INSTALL_INTERFACE:include>
|
||||||
target_include_directories(maxminddb PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
)
|
||||||
|
|
||||||
set(MAXMINDB_HEADERS
|
set(MAXMINDB_HEADERS
|
||||||
include/maxminddb.h
|
include/maxminddb.h
|
||||||
@ -66,17 +86,14 @@ set(MAXMINDB_HEADERS
|
|||||||
)
|
)
|
||||||
set_target_properties(maxminddb PROPERTIES PUBLIC_HEADER "${MAXMINDB_HEADERS}")
|
set_target_properties(maxminddb PROPERTIES PUBLIC_HEADER "${MAXMINDB_HEADERS}")
|
||||||
|
|
||||||
#install(TARGETS maxminddb
|
install(TARGETS maxminddb
|
||||||
# EXPORT maxminddb
|
EXPORT maxminddb)
|
||||||
# ARCHIVE DESTINATION lib
|
|
||||||
# PUBLIC_HEADER DESTINATION include/
|
|
||||||
#)
|
|
||||||
|
|
||||||
# This is required to work with FetchContent
|
# This is required to work with FetchContent
|
||||||
#install(EXPORT maxminddb
|
install(EXPORT maxminddb
|
||||||
# FILE maxminddb-config.cmake
|
FILE maxminddb-config.cmake
|
||||||
# NAMESPACE maxminddb::
|
NAMESPACE maxminddb::
|
||||||
# DESTINATION lib/cmake/maxminddb)
|
DESTINATION lib/cmake/maxminddb)
|
||||||
|
|
||||||
# We always want to build mmdblookup
|
# We always want to build mmdblookup
|
||||||
add_subdirectory(bin)
|
add_subdirectory(bin)
|
||||||
|
41
vendor/MaxmindDB/Changes.md
vendored
41
vendor/MaxmindDB/Changes.md
vendored
@ -1,3 +1,44 @@
|
|||||||
|
## 1.7.0
|
||||||
|
|
||||||
|
* `FD_CLOEXEC` is now set on platforms that do not support `O_CLOEXEC`.
|
||||||
|
Reported by rittneje. GitHub #273.
|
||||||
|
* When building with Visual Studio, you may now build a static runtime with
|
||||||
|
CMake by setting `MSVC_STATIC_RUNTIME` to `ON`. Pull request by Rafael
|
||||||
|
Santiago. GitHub #269.
|
||||||
|
* The CMake build now works on iOS. Pull request by SpaceIm. GitHub #271.
|
||||||
|
|
||||||
|
## 1.6.0 - 2021-04-29
|
||||||
|
|
||||||
|
* This release includes several improvements to the CMake build. In
|
||||||
|
particular:
|
||||||
|
* C99 support is now properly enabled, fixing builds on older `gcc`
|
||||||
|
versions. Pull request by Jan Včelák. GitHub #257.
|
||||||
|
* `CMAKE_SHARED_LIBRARY_PREFIX` and `CMAKE_STATIC_LIBRARY_PREFIX` are
|
||||||
|
no longer explicitly set and now use the default values for the platform.
|
||||||
|
Pull request by Jan Včelák. GitHub #258.
|
||||||
|
* `target_include_directories` now works as expected. Pull request by Jan
|
||||||
|
Včelák. GitHub #259.
|
||||||
|
* DLLs are now installed on Windows when `libmaxminddb` is built as a
|
||||||
|
shared library. Pull request by Jan Včelák. GitHub #261.
|
||||||
|
* When built as a dynamic library on Windows, all symbols are now exported.
|
||||||
|
Pull request by Jan Včelák. GitHub #262.
|
||||||
|
|
||||||
|
|
||||||
|
## 1.5.2 - 2021-02-18
|
||||||
|
|
||||||
|
* With `libmaxminddb` on Windows and `mmdblookup` generally, there were
|
||||||
|
instances where the return value of `calloc` was not checked, which could
|
||||||
|
lead to issues in low memory situations or when resource limits had been
|
||||||
|
set. Reported by cve-reporting. GitHub #252.
|
||||||
|
|
||||||
|
|
||||||
|
## 1.5.1 - 2021-02-18
|
||||||
|
|
||||||
|
* The formatting of the manpages has been improved and the script that
|
||||||
|
generates them now supports `lowdown` in addition to `pandoc`. Pull request
|
||||||
|
by Faidon Liambotis. GitHub #248.
|
||||||
|
|
||||||
|
|
||||||
## 1.5.0 - 2021-01-05
|
## 1.5.0 - 2021-01-05
|
||||||
|
|
||||||
* A CMake build script has been added for Windows builds. The Visual
|
* A CMake build script has been added for Windows builds. The Visual
|
||||||
|
4
vendor/MaxmindDB/NOTICE
vendored
4
vendor/MaxmindDB/NOTICE
vendored
@ -1,4 +1,4 @@
|
|||||||
Copyright 2013-2014 MaxMind, Inc.
|
Copyright 2013-2021 MaxMind, Inc.
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
@ -10,4 +10,4 @@ Unless required by applicable law or agreed to in writing, software
|
|||||||
distributed under the License is distributed on an "AS IS" BASIS,
|
distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
See the License for the specific language governing permissions and
|
See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
|
17
vendor/MaxmindDB/README.dev.md
vendored
17
vendor/MaxmindDB/README.dev.md
vendored
@ -1,7 +1,6 @@
|
|||||||
# Releasing this library
|
# Releasing this library
|
||||||
|
|
||||||
We release by uploading the tarball to GitHub, uploading Ubuntu PPAs, and by
|
We release by uploading the tarball to GitHub and uploading Ubuntu PPAs.
|
||||||
updating the Homebrew recipe for this library.
|
|
||||||
|
|
||||||
## Creating the release tarball
|
## Creating the release tarball
|
||||||
You may want to refer to the section about prerequisites.
|
You may want to refer to the section about prerequisites.
|
||||||
@ -9,9 +8,12 @@ You may want to refer to the section about prerequisites.
|
|||||||
* Check whether there are any open issues to fix while you're doing this.
|
* Check whether there are any open issues to fix while you're doing this.
|
||||||
* Update `Changes.md` to include specify the new version, today's date, and
|
* Update `Changes.md` to include specify the new version, today's date, and
|
||||||
list relevant changes. Commit this.
|
list relevant changes. Commit this.
|
||||||
|
* Create a new branch off of the latest `main` for the release.
|
||||||
* Run `./dev-bin/release.sh` to update various files in the distro, our
|
* Run `./dev-bin/release.sh` to update various files in the distro, our
|
||||||
GitHub pages, and creates a GitHub release with the tarball.
|
GitHub pages, and creates a GitHub release with the tarball.
|
||||||
* Check the release looks good on both GitHub and launchpad.net.
|
* Check the release looks good on both GitHub and launchpad.net.
|
||||||
|
* Make a pull request against `main` with the changes from the release
|
||||||
|
script.
|
||||||
|
|
||||||
## PPA
|
## PPA
|
||||||
|
|
||||||
@ -27,9 +29,16 @@ configurations different than Greg's machine.
|
|||||||
Check whether any new Ubuntu versions need to be listed in this script
|
Check whether any new Ubuntu versions need to be listed in this script
|
||||||
before running it.
|
before running it.
|
||||||
|
|
||||||
You should run it from `master`.
|
You should run it from `main`.
|
||||||
|
|
||||||
## Homebrew
|
## Homebrew (optional)
|
||||||
|
|
||||||
|
Releasing to Homebrew is no longer required as the formulas are easily
|
||||||
|
updated by the end-user using a built-in feature in the tool. These
|
||||||
|
directions remain in case there is a more significant change to the
|
||||||
|
build process that may require a non-trivial update to the formula or
|
||||||
|
in the case where we want the Homebrew version updated promptly for
|
||||||
|
some reason.
|
||||||
|
|
||||||
* Go to https://github.com/Homebrew/homebrew-core/edit/master/Formula/libmaxminddb.rb
|
* Go to https://github.com/Homebrew/homebrew-core/edit/master/Formula/libmaxminddb.rb
|
||||||
* Edit the file to update the url and sha256. You can get the sha256 for the
|
* Edit the file to update the url and sha256. You can get the sha256 for the
|
||||||
|
10
vendor/MaxmindDB/README.md
vendored
10
vendor/MaxmindDB/README.md
vendored
@ -68,7 +68,8 @@ You can clone this repository and build it by running:
|
|||||||
$ git clone --recursive https://github.com/maxmind/libmaxminddb
|
$ git clone --recursive https://github.com/maxmind/libmaxminddb
|
||||||
|
|
||||||
After cloning, run `./bootstrap` from the `libmaxminddb` directory and then
|
After cloning, run `./bootstrap` from the `libmaxminddb` directory and then
|
||||||
follow the instructions for installing from a named release tarball as described above.
|
follow the instructions for installing from a named release tarball as
|
||||||
|
described above.
|
||||||
|
|
||||||
## Using CMake
|
## Using CMake
|
||||||
|
|
||||||
@ -80,6 +81,11 @@ work.
|
|||||||
$ ctest -V .
|
$ ctest -V .
|
||||||
$ cmake --build . --target install
|
$ cmake --build . --target install
|
||||||
|
|
||||||
|
When building with Visual Studio, you may build a multithreaded (MT/MTd)
|
||||||
|
runtime library, using the `MSVC_STATIC_RUNTIME` setting:
|
||||||
|
|
||||||
|
$ cmake -DMSVC_STATIC_RUNTIME=ON -DBUILD_SHARED_LIBS=OFF ..
|
||||||
|
|
||||||
## On Ubuntu via PPA
|
## On Ubuntu via PPA
|
||||||
|
|
||||||
MaxMind provides a PPA for recent version of Ubuntu. To add the PPA to your
|
MaxMind provides a PPA for recent version of Ubuntu. To add the PPA to your
|
||||||
@ -120,6 +126,8 @@ Use `make safedist` to check the resulting tarball.
|
|||||||
|
|
||||||
# Copyright and License
|
# Copyright and License
|
||||||
|
|
||||||
|
Copyright 2013-2021 MaxMind, Inc.
|
||||||
|
|
||||||
Licensed under the Apache License, Version 2.0 (the "License");
|
Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
you may not use this file except in compliance with the License.
|
you may not use this file except in compliance with the License.
|
||||||
You may obtain a copy of the License at
|
You may obtain a copy of the License at
|
||||||
|
2
vendor/MaxmindDB/bin/CMakeLists.txt
vendored
2
vendor/MaxmindDB/bin/CMakeLists.txt
vendored
@ -8,6 +8,6 @@ if(NOT WIN32)
|
|||||||
|
|
||||||
install(
|
install(
|
||||||
TARGETS mmdblookup
|
TARGETS mmdblookup
|
||||||
RUNTIME DESTINATION bin
|
DESTINATION bin
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
406
vendor/MaxmindDB/bin/mmdblookup.c
vendored
406
vendor/MaxmindDB/bin/mmdblookup.c
vendored
@ -23,46 +23,42 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define LOCAL static
|
static void usage(char *program, int exit_code, const char *error);
|
||||||
|
static const char **get_options(int argc,
|
||||||
LOCAL void usage(char *program, int exit_code, const char *error);
|
char **argv,
|
||||||
LOCAL const char **get_options(
|
char **mmdb_file,
|
||||||
int argc,
|
char **ip_address,
|
||||||
char **argv,
|
int *verbose,
|
||||||
char **mmdb_file,
|
int *iterations,
|
||||||
char **ip_address,
|
int *lookup_path_length,
|
||||||
int *verbose,
|
int *const thread_count,
|
||||||
int *iterations,
|
char **const ip_file);
|
||||||
int *lookup_path_length,
|
static MMDB_s open_or_die(const char *fname);
|
||||||
int *const thread_count,
|
static void dump_meta(MMDB_s *mmdb);
|
||||||
char **const ip_file);
|
static bool lookup_from_file(MMDB_s *const mmdb,
|
||||||
LOCAL MMDB_s open_or_die(const char *fname);
|
char const *const ip_file,
|
||||||
LOCAL void dump_meta(MMDB_s *mmdb);
|
bool const dump);
|
||||||
LOCAL bool lookup_from_file(MMDB_s *const mmdb,
|
static int lookup_and_print(MMDB_s *mmdb,
|
||||||
char const *const ip_file,
|
const char *ip_address,
|
||||||
bool const dump);
|
const char **lookup_path,
|
||||||
LOCAL int lookup_and_print(MMDB_s *mmdb, const char *ip_address,
|
int lookup_path_length,
|
||||||
const char **lookup_path,
|
bool verbose);
|
||||||
int lookup_path_length,
|
static int benchmark(MMDB_s *mmdb, int iterations);
|
||||||
bool verbose);
|
static MMDB_lookup_result_s lookup_or_die(MMDB_s *mmdb, const char *ipstr);
|
||||||
LOCAL int benchmark(MMDB_s *mmdb, int iterations);
|
static void random_ipv4(char *ip);
|
||||||
LOCAL MMDB_lookup_result_s lookup_or_die(MMDB_s *mmdb, const char *ipstr);
|
|
||||||
LOCAL void random_ipv4(char *ip);
|
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
// These aren't with the automatically generated prototypes as we'd lose the
|
// These aren't with the automatically generated prototypes as we'd lose the
|
||||||
// enclosing macros.
|
// enclosing macros.
|
||||||
static bool start_threaded_benchmark(
|
static bool start_threaded_benchmark(MMDB_s *const mmdb,
|
||||||
MMDB_s *const mmdb,
|
int const thread_count,
|
||||||
int const thread_count,
|
int const iterations);
|
||||||
int const iterations);
|
|
||||||
static long double get_time(void);
|
static long double get_time(void);
|
||||||
static void *thread(void *arg);
|
static void *thread(void *arg);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
int wmain(int argc, wchar_t **wargv)
|
int wmain(int argc, wchar_t **wargv) {
|
||||||
{
|
|
||||||
// Convert our argument list from UTF-16 to UTF-8.
|
// Convert our argument list from UTF-16 to UTF-8.
|
||||||
char **argv = (char **)calloc(argc, sizeof(char *));
|
char **argv = (char **)calloc(argc, sizeof(char *));
|
||||||
if (!argv) {
|
if (!argv) {
|
||||||
@ -72,11 +68,11 @@ int wmain(int argc, wchar_t **wargv)
|
|||||||
for (int i = 0; i < argc; i++) {
|
for (int i = 0; i < argc; i++) {
|
||||||
int utf8_width;
|
int utf8_width;
|
||||||
char *utf8_string;
|
char *utf8_string;
|
||||||
utf8_width = WideCharToMultiByte(CP_UTF8, 0, wargv[i], -1, NULL, 0,
|
utf8_width =
|
||||||
NULL, NULL);
|
WideCharToMultiByte(CP_UTF8, 0, wargv[i], -1, NULL, 0, NULL, NULL);
|
||||||
if (utf8_width < 1) {
|
if (utf8_width < 1) {
|
||||||
fprintf(stderr, "WideCharToMultiByte() failed: %d\n",
|
fprintf(
|
||||||
GetLastError());
|
stderr, "WideCharToMultiByte() failed: %d\n", GetLastError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
utf8_string = calloc(utf8_width, sizeof(char));
|
utf8_string = calloc(utf8_width, sizeof(char));
|
||||||
@ -84,17 +80,17 @@ int wmain(int argc, wchar_t **wargv)
|
|||||||
fprintf(stderr, "calloc(): %s\n", strerror(errno));
|
fprintf(stderr, "calloc(): %s\n", strerror(errno));
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
if (WideCharToMultiByte(CP_UTF8, 0, wargv[i], -1, utf8_string,
|
if (WideCharToMultiByte(
|
||||||
utf8_width, NULL, NULL) < 1) {
|
CP_UTF8, 0, wargv[i], -1, utf8_string, utf8_width, NULL, NULL) <
|
||||||
fprintf(stderr, "WideCharToMultiByte() failed: %d\n",
|
1) {
|
||||||
GetLastError());
|
fprintf(
|
||||||
|
stderr, "WideCharToMultiByte() failed: %d\n", GetLastError());
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
argv[i] = utf8_string;
|
argv[i] = utf8_string;
|
||||||
}
|
}
|
||||||
#else // _WIN32
|
#else // _WIN32
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv) {
|
||||||
{
|
|
||||||
#endif // _WIN32
|
#endif // _WIN32
|
||||||
char *mmdb_file = NULL;
|
char *mmdb_file = NULL;
|
||||||
char *ip_address = NULL;
|
char *ip_address = NULL;
|
||||||
@ -104,9 +100,15 @@ int main(int argc, char **argv)
|
|||||||
int thread_count = 0;
|
int thread_count = 0;
|
||||||
char *ip_file = NULL;
|
char *ip_file = NULL;
|
||||||
|
|
||||||
const char **lookup_path =
|
const char **lookup_path = get_options(argc,
|
||||||
get_options(argc, argv, &mmdb_file, &ip_address, &verbose, &iterations,
|
argv,
|
||||||
&lookup_path_length, &thread_count, &ip_file);
|
&mmdb_file,
|
||||||
|
&ip_address,
|
||||||
|
&verbose,
|
||||||
|
&iterations,
|
||||||
|
&lookup_path_length,
|
||||||
|
&thread_count,
|
||||||
|
&ip_file);
|
||||||
|
|
||||||
MMDB_s mmdb = open_or_die(mmdb_file);
|
MMDB_s mmdb = open_or_die(mmdb_file);
|
||||||
|
|
||||||
@ -131,13 +133,13 @@ int main(int argc, char **argv)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (0 == iterations) {
|
if (0 == iterations) {
|
||||||
exit(lookup_and_print(&mmdb, ip_address, lookup_path,
|
exit(lookup_and_print(
|
||||||
lookup_path_length, verbose));
|
&mmdb, ip_address, lookup_path, lookup_path_length, verbose));
|
||||||
}
|
}
|
||||||
|
|
||||||
free((void *)lookup_path);
|
free((void *)lookup_path);
|
||||||
|
|
||||||
srand( (int)time(NULL) );
|
srand((int)time(NULL));
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
if (thread_count > 0) {
|
if (thread_count > 0) {
|
||||||
@ -153,97 +155,96 @@ int main(int argc, char **argv)
|
|||||||
exit(benchmark(&mmdb, iterations));
|
exit(benchmark(&mmdb, iterations));
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCAL void usage(char *program, int exit_code, const char *error)
|
static void usage(char *program, int exit_code, const char *error) {
|
||||||
{
|
|
||||||
if (NULL != error) {
|
if (NULL != error) {
|
||||||
fprintf(stderr, "\n *ERROR: %s\n", error);
|
fprintf(stderr, "\n *ERROR: %s\n", error);
|
||||||
}
|
}
|
||||||
|
|
||||||
char *usage = "\n"
|
char *usage =
|
||||||
" %s --file /path/to/file.mmdb --ip 1.2.3.4 [path to lookup]\n"
|
"\n"
|
||||||
"\n"
|
" %s --file /path/to/file.mmdb --ip 1.2.3.4 [path to lookup]\n"
|
||||||
" This application accepts the following options:\n"
|
"\n"
|
||||||
"\n"
|
" This application accepts the following options:\n"
|
||||||
" --file (-f) The path to the MMDB file. Required.\n"
|
"\n"
|
||||||
"\n"
|
" --file (-f) The path to the MMDB file. Required.\n"
|
||||||
" --ip (-i) The IP address to look up. Required.\n"
|
"\n"
|
||||||
"\n"
|
" --ip (-i) The IP address to look up. Required.\n"
|
||||||
" --verbose (-v) Turns on verbose output. Specifically, this causes this\n"
|
"\n"
|
||||||
" application to output the database metadata.\n"
|
" --verbose (-v) Turns on verbose output. Specifically, this "
|
||||||
"\n"
|
"causes this\n"
|
||||||
" --version Print the program's version number and exit.\n"
|
" application to output the database metadata.\n"
|
||||||
"\n"
|
"\n"
|
||||||
" --help (-h -?) Show usage information.\n"
|
" --version Print the program's version number and exit.\n"
|
||||||
"\n"
|
"\n"
|
||||||
" If an IP's data entry resolves to a map or array, you can provide\n"
|
" --help (-h -?) Show usage information.\n"
|
||||||
" a lookup path to only show part of that data.\n"
|
"\n"
|
||||||
"\n"
|
" If an IP's data entry resolves to a map or array, you can provide\n"
|
||||||
" For example, given a JSON structure like this:\n"
|
" a lookup path to only show part of that data.\n"
|
||||||
"\n"
|
"\n"
|
||||||
" {\n"
|
" For example, given a JSON structure like this:\n"
|
||||||
" \"names\": {\n"
|
"\n"
|
||||||
" \"en\": \"Germany\",\n"
|
" {\n"
|
||||||
" \"de\": \"Deutschland\"\n"
|
" \"names\": {\n"
|
||||||
" },\n"
|
" \"en\": \"Germany\",\n"
|
||||||
" \"cities\": [ \"Berlin\", \"Frankfurt\" ]\n"
|
" \"de\": \"Deutschland\"\n"
|
||||||
" }\n"
|
" },\n"
|
||||||
"\n"
|
" \"cities\": [ \"Berlin\", \"Frankfurt\" ]\n"
|
||||||
" You could look up just the English name by calling mmdblookup with a lookup path of:\n"
|
" }\n"
|
||||||
"\n"
|
"\n"
|
||||||
" mmdblookup --file ... --ip ... names en\n"
|
" You could look up just the English name by calling mmdblookup with "
|
||||||
"\n"
|
"a lookup path of:\n"
|
||||||
" Or you could look up the second city in the list with:\n"
|
"\n"
|
||||||
"\n"
|
" mmdblookup --file ... --ip ... names en\n"
|
||||||
" mmdblookup --file ... --ip ... cities 1\n"
|
"\n"
|
||||||
"\n"
|
" Or you could look up the second city in the list with:\n"
|
||||||
" Array numbering begins with zero (0).\n"
|
"\n"
|
||||||
"\n"
|
" mmdblookup --file ... --ip ... cities 1\n"
|
||||||
" If you do not provide a path to lookup, all of the information for a given IP\n"
|
"\n"
|
||||||
" will be shown.\n"
|
" Array numbering begins with zero (0).\n"
|
||||||
"\n";
|
"\n"
|
||||||
|
" If you do not provide a path to lookup, all of the information for "
|
||||||
|
"a given IP\n"
|
||||||
|
" will be shown.\n"
|
||||||
|
"\n";
|
||||||
|
|
||||||
fprintf(stdout, usage, program);
|
fprintf(stdout, usage, program);
|
||||||
exit(exit_code);
|
exit(exit_code);
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCAL const char **get_options(
|
static const char **get_options(int argc,
|
||||||
int argc,
|
char **argv,
|
||||||
char **argv,
|
char **mmdb_file,
|
||||||
char **mmdb_file,
|
char **ip_address,
|
||||||
char **ip_address,
|
int *verbose,
|
||||||
int *verbose,
|
int *iterations,
|
||||||
int *iterations,
|
int *lookup_path_length,
|
||||||
int *lookup_path_length,
|
int *const thread_count,
|
||||||
int *const thread_count,
|
char **const ip_file) {
|
||||||
char **const ip_file)
|
|
||||||
{
|
|
||||||
static int help = 0;
|
static int help = 0;
|
||||||
static int version = 0;
|
static int version = 0;
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
static struct option options[] = {
|
static struct option options[] = {
|
||||||
{ "file", required_argument, 0, 'f' },
|
{"file", required_argument, 0, 'f'},
|
||||||
{ "ip", required_argument, 0, 'i' },
|
{"ip", required_argument, 0, 'i'},
|
||||||
{ "verbose", no_argument, 0, 'v' },
|
{"verbose", no_argument, 0, 'v'},
|
||||||
{ "version", no_argument, 0, 'n' },
|
{"version", no_argument, 0, 'n'},
|
||||||
{ "benchmark", required_argument, 0, 'b' },
|
{"benchmark", required_argument, 0, 'b'},
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
{ "threads", required_argument, 0, 't' },
|
{"threads", required_argument, 0, 't'},
|
||||||
#endif
|
#endif
|
||||||
{ "ip-file", required_argument, 0, 'I' },
|
{"ip-file", required_argument, 0, 'I'},
|
||||||
{ "help", no_argument, 0, 'h' },
|
{"help", no_argument, 0, 'h'},
|
||||||
{ "?", no_argument, 0, 1 },
|
{"?", no_argument, 0, 1},
|
||||||
{ 0, 0, 0, 0 }
|
{0, 0, 0, 0}};
|
||||||
};
|
|
||||||
|
|
||||||
int opt_index;
|
int opt_index;
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
char const * const optstring = "f:i:b:I:vnh?";
|
char const *const optstring = "f:i:b:I:vnh?";
|
||||||
#else
|
#else
|
||||||
char const * const optstring = "f:i:b:t:I:vnh?";
|
char const *const optstring = "f:i:b:t:I:vnh?";
|
||||||
#endif
|
#endif
|
||||||
int opt_char = getopt_long(argc, argv, optstring, options,
|
int opt_char = getopt_long(argc, argv, optstring, options, &opt_index);
|
||||||
&opt_index);
|
|
||||||
|
|
||||||
if (-1 == opt_char) {
|
if (-1 == opt_char) {
|
||||||
break;
|
break;
|
||||||
@ -295,6 +296,10 @@ LOCAL const char **get_options(
|
|||||||
|
|
||||||
const char **lookup_path =
|
const char **lookup_path =
|
||||||
calloc((argc - optind) + 1, sizeof(const char *));
|
calloc((argc - optind) + 1, sizeof(const char *));
|
||||||
|
if (!lookup_path) {
|
||||||
|
fprintf(stderr, "calloc(): %s\n", strerror(errno));
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < argc - optind; i++) {
|
for (i = 0; i < argc - optind; i++) {
|
||||||
lookup_path[i] = argv[i + optind];
|
lookup_path[i] = argv[i + optind];
|
||||||
@ -305,14 +310,13 @@ LOCAL const char **get_options(
|
|||||||
return lookup_path;
|
return lookup_path;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCAL MMDB_s open_or_die(const char *fname)
|
static MMDB_s open_or_die(const char *fname) {
|
||||||
{
|
|
||||||
MMDB_s mmdb;
|
MMDB_s mmdb;
|
||||||
int status = MMDB_open(fname, MMDB_MODE_MMAP, &mmdb);
|
int status = MMDB_open(fname, MMDB_MODE_MMAP, &mmdb);
|
||||||
|
|
||||||
if (MMDB_SUCCESS != status) {
|
if (MMDB_SUCCESS != status) {
|
||||||
fprintf(stderr, "\n Can't open %s - %s\n", fname,
|
fprintf(
|
||||||
MMDB_strerror(status));
|
stderr, "\n Can't open %s - %s\n", fname, MMDB_strerror(status));
|
||||||
|
|
||||||
if (MMDB_IO_ERROR == status) {
|
if (MMDB_IO_ERROR == status) {
|
||||||
fprintf(stderr, " IO error: %s\n", strerror(errno));
|
fprintf(stderr, " IO error: %s\n", strerror(errno));
|
||||||
@ -326,8 +330,7 @@ LOCAL MMDB_s open_or_die(const char *fname)
|
|||||||
return mmdb;
|
return mmdb;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCAL void dump_meta(MMDB_s *mmdb)
|
static void dump_meta(MMDB_s *mmdb) {
|
||||||
{
|
|
||||||
const char *meta_dump = "\n"
|
const char *meta_dump = "\n"
|
||||||
" Database metadata\n"
|
" Database metadata\n"
|
||||||
" Node count: %i\n"
|
" Node count: %i\n"
|
||||||
@ -342,7 +345,8 @@ LOCAL void dump_meta(MMDB_s *mmdb)
|
|||||||
const time_t epoch = (const time_t)mmdb->metadata.build_epoch;
|
const time_t epoch = (const time_t)mmdb->metadata.build_epoch;
|
||||||
strftime(date, 40, "%F %T UTC", gmtime(&epoch));
|
strftime(date, 40, "%F %T UTC", gmtime(&epoch));
|
||||||
|
|
||||||
fprintf(stdout, meta_dump,
|
fprintf(stdout,
|
||||||
|
meta_dump,
|
||||||
mmdb->metadata.node_count,
|
mmdb->metadata.node_count,
|
||||||
mmdb->metadata.record_size,
|
mmdb->metadata.record_size,
|
||||||
mmdb->metadata.ip_version,
|
mmdb->metadata.ip_version,
|
||||||
@ -362,7 +366,8 @@ LOCAL void dump_meta(MMDB_s *mmdb)
|
|||||||
|
|
||||||
fprintf(stdout, " Description:\n");
|
fprintf(stdout, " Description:\n");
|
||||||
for (size_t i = 0; i < mmdb->metadata.description.count; i++) {
|
for (size_t i = 0; i < mmdb->metadata.description.count; i++) {
|
||||||
fprintf(stdout, " %s: %s\n",
|
fprintf(stdout,
|
||||||
|
" %s: %s\n",
|
||||||
mmdb->metadata.description.descriptions[i]->language,
|
mmdb->metadata.description.descriptions[i]->language,
|
||||||
mmdb->metadata.description.descriptions[i]->description);
|
mmdb->metadata.description.descriptions[i]->description);
|
||||||
}
|
}
|
||||||
@ -381,10 +386,9 @@ LOCAL void dump_meta(MMDB_s *mmdb)
|
|||||||
//
|
//
|
||||||
// In addition to being useful for comparisons, this function provides a way to
|
// In addition to being useful for comparisons, this function provides a way to
|
||||||
// have a more deterministic set of lookups for benchmarking.
|
// have a more deterministic set of lookups for benchmarking.
|
||||||
LOCAL bool lookup_from_file(MMDB_s *const mmdb,
|
static bool lookup_from_file(MMDB_s *const mmdb,
|
||||||
char const *const ip_file,
|
char const *const ip_file,
|
||||||
bool const dump)
|
bool const dump) {
|
||||||
{
|
|
||||||
FILE *const fh = fopen(ip_file, "r");
|
FILE *const fh = fopen(ip_file, "r");
|
||||||
if (!fh) {
|
if (!fh) {
|
||||||
fprintf(stderr, "fopen(): %s: %s\n", ip_file, strerror(errno));
|
fprintf(stderr, "fopen(): %s: %s\n", ip_file, strerror(errno));
|
||||||
@ -392,7 +396,7 @@ LOCAL bool lookup_from_file(MMDB_s *const mmdb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
clock_t const clock_start = clock();
|
clock_t const clock_start = clock();
|
||||||
char buf[1024] = { 0 };
|
char buf[1024] = {0};
|
||||||
// I'd normally use uint64_t, but support for it is optional in C99.
|
// I'd normally use uint64_t, but support for it is optional in C99.
|
||||||
unsigned long long i = 0;
|
unsigned long long i = 0;
|
||||||
while (1) {
|
while (1) {
|
||||||
@ -429,10 +433,11 @@ LOCAL bool lookup_from_file(MMDB_s *const mmdb,
|
|||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *entry_data_list = NULL;
|
MMDB_entry_data_list_s *entry_data_list = NULL;
|
||||||
int const status = MMDB_get_entry_data_list(&result.entry,
|
int const status =
|
||||||
&entry_data_list);
|
MMDB_get_entry_data_list(&result.entry, &entry_data_list);
|
||||||
if (status != MMDB_SUCCESS) {
|
if (status != MMDB_SUCCESS) {
|
||||||
fprintf(stderr, "MMDB_get_entry_data_list(): %s\n",
|
fprintf(stderr,
|
||||||
|
"MMDB_get_entry_data_list(): %s\n",
|
||||||
MMDB_strerror(status));
|
MMDB_strerror(status));
|
||||||
fclose(fh);
|
fclose(fh);
|
||||||
MMDB_free_entry_data_list(entry_data_list);
|
MMDB_free_entry_data_list(entry_data_list);
|
||||||
@ -447,10 +452,11 @@ LOCAL bool lookup_from_file(MMDB_s *const mmdb,
|
|||||||
|
|
||||||
if (dump) {
|
if (dump) {
|
||||||
fprintf(stdout, "%s:\n", buf);
|
fprintf(stdout, "%s:\n", buf);
|
||||||
int const status = MMDB_dump_entry_data_list(stderr,
|
int const status =
|
||||||
entry_data_list, 0);
|
MMDB_dump_entry_data_list(stderr, entry_data_list, 0);
|
||||||
if (status != MMDB_SUCCESS) {
|
if (status != MMDB_SUCCESS) {
|
||||||
fprintf(stderr, "MMDB_dump_entry_data_list(): %s\n",
|
fprintf(stderr,
|
||||||
|
"MMDB_dump_entry_data_list(): %s\n",
|
||||||
MMDB_strerror(status));
|
MMDB_strerror(status));
|
||||||
fclose(fh);
|
fclose(fh);
|
||||||
MMDB_free_entry_data_list(entry_data_list);
|
MMDB_free_entry_data_list(entry_data_list);
|
||||||
@ -467,16 +473,18 @@ LOCAL bool lookup_from_file(MMDB_s *const mmdb,
|
|||||||
fprintf(
|
fprintf(
|
||||||
stdout,
|
stdout,
|
||||||
"Looked up %llu addresses in %.2f seconds. %.2f lookups per second.\n",
|
"Looked up %llu addresses in %.2f seconds. %.2f lookups per second.\n",
|
||||||
i, seconds, i / seconds);
|
i,
|
||||||
|
seconds,
|
||||||
|
i / seconds);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCAL int lookup_and_print(MMDB_s *mmdb, const char *ip_address,
|
static int lookup_and_print(MMDB_s *mmdb,
|
||||||
const char **lookup_path,
|
const char *ip_address,
|
||||||
int lookup_path_length,
|
const char **lookup_path,
|
||||||
bool verbose)
|
int lookup_path_length,
|
||||||
{
|
bool verbose) {
|
||||||
|
|
||||||
MMDB_lookup_result_s result = lookup_or_die(mmdb, ip_address);
|
MMDB_lookup_result_s result = lookup_or_die(mmdb, ip_address);
|
||||||
MMDB_entry_data_list_s *entry_data_list = NULL;
|
MMDB_entry_data_list_s *entry_data_list = NULL;
|
||||||
@ -484,38 +492,32 @@ LOCAL int lookup_and_print(MMDB_s *mmdb, const char *ip_address,
|
|||||||
int exit_code = 0;
|
int exit_code = 0;
|
||||||
|
|
||||||
if (verbose) {
|
if (verbose) {
|
||||||
fprintf(
|
fprintf(stdout, "\n Record prefix length: %d\n", result.netmask);
|
||||||
stdout,
|
|
||||||
"\n Record prefix length: %d\n",
|
|
||||||
result.netmask
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result.found_entry) {
|
if (result.found_entry) {
|
||||||
int status;
|
int status;
|
||||||
if (lookup_path_length) {
|
if (lookup_path_length) {
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
status = MMDB_aget_value(&result.entry, &entry_data,
|
status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
||||||
lookup_path);
|
|
||||||
if (MMDB_SUCCESS == status) {
|
if (MMDB_SUCCESS == status) {
|
||||||
if (entry_data.offset) {
|
if (entry_data.offset) {
|
||||||
MMDB_entry_s entry =
|
MMDB_entry_s entry = {.mmdb = mmdb,
|
||||||
{ .mmdb = mmdb, .offset = entry_data.offset };
|
.offset = entry_data.offset};
|
||||||
status = MMDB_get_entry_data_list(&entry,
|
status = MMDB_get_entry_data_list(&entry, &entry_data_list);
|
||||||
&entry_data_list);
|
|
||||||
} else {
|
} else {
|
||||||
fprintf(
|
fprintf(stdout,
|
||||||
stdout,
|
"\n No data was found at the lookup path you "
|
||||||
"\n No data was found at the lookup path you provided\n\n");
|
"provided\n\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
status = MMDB_get_entry_data_list(&result.entry,
|
status = MMDB_get_entry_data_list(&result.entry, &entry_data_list);
|
||||||
&entry_data_list);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (MMDB_SUCCESS != status) {
|
if (MMDB_SUCCESS != status) {
|
||||||
fprintf(stderr, "Got an error looking up the entry data - %s\n",
|
fprintf(stderr,
|
||||||
|
"Got an error looking up the entry data - %s\n",
|
||||||
MMDB_strerror(status));
|
MMDB_strerror(status));
|
||||||
exit_code = 5;
|
exit_code = 5;
|
||||||
goto end;
|
goto end;
|
||||||
@ -533,7 +535,7 @@ LOCAL int lookup_and_print(MMDB_s *mmdb, const char *ip_address,
|
|||||||
exit_code = 6;
|
exit_code = 6;
|
||||||
}
|
}
|
||||||
|
|
||||||
end:
|
end:
|
||||||
MMDB_free_entry_data_list(entry_data_list);
|
MMDB_free_entry_data_list(entry_data_list);
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
free((void *)lookup_path);
|
free((void *)lookup_path);
|
||||||
@ -541,8 +543,7 @@ LOCAL int lookup_and_print(MMDB_s *mmdb, const char *ip_address,
|
|||||||
return exit_code;
|
return exit_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCAL int benchmark(MMDB_s *mmdb, int iterations)
|
static int benchmark(MMDB_s *mmdb, int iterations) {
|
||||||
{
|
|
||||||
char ip_address[16];
|
char ip_address[16];
|
||||||
int exit_code = 0;
|
int exit_code = 0;
|
||||||
|
|
||||||
@ -556,11 +557,12 @@ LOCAL int benchmark(MMDB_s *mmdb, int iterations)
|
|||||||
|
|
||||||
if (result.found_entry) {
|
if (result.found_entry) {
|
||||||
|
|
||||||
int status = MMDB_get_entry_data_list(&result.entry,
|
int status =
|
||||||
&entry_data_list);
|
MMDB_get_entry_data_list(&result.entry, &entry_data_list);
|
||||||
|
|
||||||
if (MMDB_SUCCESS != status) {
|
if (MMDB_SUCCESS != status) {
|
||||||
fprintf(stderr, "Got an error looking up the entry data - %s\n",
|
fprintf(stderr,
|
||||||
|
"Got an error looking up the entry data - %s\n",
|
||||||
MMDB_strerror(status));
|
MMDB_strerror(status));
|
||||||
exit_code = 5;
|
exit_code = 5;
|
||||||
MMDB_free_entry_data_list(entry_data_list);
|
MMDB_free_entry_data_list(entry_data_list);
|
||||||
@ -573,19 +575,20 @@ LOCAL int benchmark(MMDB_s *mmdb, int iterations)
|
|||||||
|
|
||||||
time = clock() - time;
|
time = clock() - time;
|
||||||
double seconds = ((double)time / CLOCKS_PER_SEC);
|
double seconds = ((double)time / CLOCKS_PER_SEC);
|
||||||
fprintf(
|
fprintf(stdout,
|
||||||
stdout,
|
"\n Looked up %i addresses in %.2f seconds. %.2f lookups per "
|
||||||
"\n Looked up %i addresses in %.2f seconds. %.2f lookups per second.\n\n",
|
"second.\n\n",
|
||||||
iterations, seconds, iterations / seconds);
|
iterations,
|
||||||
|
seconds,
|
||||||
|
iterations / seconds);
|
||||||
|
|
||||||
end:
|
end:
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
|
|
||||||
return exit_code;
|
return exit_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCAL MMDB_lookup_result_s lookup_or_die(MMDB_s *mmdb, const char *ipstr)
|
static MMDB_lookup_result_s lookup_or_die(MMDB_s *mmdb, const char *ipstr) {
|
||||||
{
|
|
||||||
int gai_error, mmdb_error;
|
int gai_error, mmdb_error;
|
||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
MMDB_lookup_string(mmdb, ipstr, &gai_error, &mmdb_error);
|
MMDB_lookup_string(mmdb, ipstr, &gai_error, &mmdb_error);
|
||||||
@ -599,12 +602,13 @@ LOCAL MMDB_lookup_result_s lookup_or_die(MMDB_s *mmdb, const char *ipstr)
|
|||||||
#else
|
#else
|
||||||
gai_strerror(gai_error)
|
gai_strerror(gai_error)
|
||||||
#endif
|
#endif
|
||||||
);
|
);
|
||||||
exit(3);
|
exit(3);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (MMDB_SUCCESS != mmdb_error) {
|
if (MMDB_SUCCESS != mmdb_error) {
|
||||||
fprintf(stderr, "\n Got an error from the maxminddb library: %s\n\n",
|
fprintf(stderr,
|
||||||
|
"\n Got an error from the maxminddb library: %s\n\n",
|
||||||
MMDB_strerror(mmdb_error));
|
MMDB_strerror(mmdb_error));
|
||||||
exit(4);
|
exit(4);
|
||||||
}
|
}
|
||||||
@ -612,15 +616,19 @@ LOCAL MMDB_lookup_result_s lookup_or_die(MMDB_s *mmdb, const char *ipstr)
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
LOCAL void random_ipv4(char *ip)
|
static void random_ipv4(char *ip) {
|
||||||
{
|
|
||||||
// rand() is perfectly fine for this use case
|
// rand() is perfectly fine for this use case
|
||||||
// coverity[dont_call]
|
// coverity[dont_call]
|
||||||
int ip_int = rand();
|
int ip_int = rand();
|
||||||
uint8_t *bytes = (uint8_t *)&ip_int;
|
uint8_t *bytes = (uint8_t *)&ip_int;
|
||||||
|
|
||||||
snprintf(ip, 16, "%u.%u.%u.%u",
|
snprintf(ip,
|
||||||
*bytes, *(bytes + 1), *(bytes + 2), *(bytes + 3));
|
16,
|
||||||
|
"%u.%u.%u.%u",
|
||||||
|
*bytes,
|
||||||
|
*(bytes + 1),
|
||||||
|
*(bytes + 2),
|
||||||
|
*(bytes + 3));
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifndef _WIN32
|
#ifndef _WIN32
|
||||||
@ -631,13 +639,11 @@ struct thread_info {
|
|||||||
int iterations;
|
int iterations;
|
||||||
};
|
};
|
||||||
|
|
||||||
static bool start_threaded_benchmark(
|
static bool start_threaded_benchmark(MMDB_s *const mmdb,
|
||||||
MMDB_s *const mmdb,
|
int const thread_count,
|
||||||
int const thread_count,
|
int const iterations) {
|
||||||
int const iterations)
|
struct thread_info *const tinfo =
|
||||||
{
|
calloc(thread_count, sizeof(struct thread_info));
|
||||||
struct thread_info *const tinfo = calloc(thread_count,
|
|
||||||
sizeof(struct thread_info));
|
|
||||||
if (!tinfo) {
|
if (!tinfo) {
|
||||||
fprintf(stderr, "calloc(): %s\n", strerror(errno));
|
fprintf(stderr, "calloc(): %s\n", strerror(errno));
|
||||||
return false;
|
return false;
|
||||||
@ -685,20 +691,22 @@ static bool start_threaded_benchmark(
|
|||||||
rate = total_ips / elapsed;
|
rate = total_ips / elapsed;
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(
|
fprintf(stdout,
|
||||||
stdout,
|
"Looked up %llu addresses using %d threads in %.2Lf seconds. %.2Lf "
|
||||||
"Looked up %llu addresses using %d threads in %.2Lf seconds. %.2Lf lookups per second.\n",
|
"lookups per second.\n",
|
||||||
total_ips, thread_count, elapsed, rate);
|
total_ips,
|
||||||
|
thread_count,
|
||||||
|
elapsed,
|
||||||
|
rate);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
static long double get_time(void)
|
static long double get_time(void) {
|
||||||
{
|
|
||||||
// clock_gettime() is not present on OSX until 10.12.
|
// clock_gettime() is not present on OSX until 10.12.
|
||||||
#ifdef HAVE_CLOCK_GETTIME
|
#ifdef HAVE_CLOCK_GETTIME
|
||||||
struct timespec tp = {
|
struct timespec tp = {
|
||||||
.tv_sec = 0,
|
.tv_sec = 0,
|
||||||
.tv_nsec = 0,
|
.tv_nsec = 0,
|
||||||
};
|
};
|
||||||
clockid_t clk_id = CLOCK_REALTIME;
|
clockid_t clk_id = CLOCK_REALTIME;
|
||||||
@ -720,15 +728,14 @@ static long double get_time(void)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
static void *thread(void *arg)
|
static void *thread(void *arg) {
|
||||||
{
|
|
||||||
const struct thread_info *const tinfo = arg;
|
const struct thread_info *const tinfo = arg;
|
||||||
if (!tinfo) {
|
if (!tinfo) {
|
||||||
fprintf(stderr, "thread(): %s\n", strerror(EINVAL));
|
fprintf(stderr, "thread(): %s\n", strerror(EINVAL));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
char ip_address[16] = { 0 };
|
char ip_address[16] = {0};
|
||||||
|
|
||||||
for (int i = 0; i < tinfo->iterations; i++) {
|
for (int i = 0; i < tinfo->iterations; i++) {
|
||||||
memset(ip_address, 0, 16);
|
memset(ip_address, 0, 16);
|
||||||
@ -740,10 +747,11 @@ static void *thread(void *arg)
|
|||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *entry_data_list = NULL;
|
MMDB_entry_data_list_s *entry_data_list = NULL;
|
||||||
int const status = MMDB_get_entry_data_list(&result.entry,
|
int const status =
|
||||||
&entry_data_list);
|
MMDB_get_entry_data_list(&result.entry, &entry_data_list);
|
||||||
if (status != MMDB_SUCCESS) {
|
if (status != MMDB_SUCCESS) {
|
||||||
fprintf(stderr, "MMDB_get_entry_data_list(): %s\n",
|
fprintf(stderr,
|
||||||
|
"MMDB_get_entry_data_list(): %s\n",
|
||||||
MMDB_strerror(status));
|
MMDB_strerror(status));
|
||||||
MMDB_free_entry_data_list(entry_data_list);
|
MMDB_free_entry_data_list(entry_data_list);
|
||||||
return NULL;
|
return NULL;
|
||||||
|
7
vendor/MaxmindDB/c_flag_overrides.cmake
vendored
Normal file
7
vendor/MaxmindDB/c_flag_overrides.cmake
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
if(MSVC)
|
||||||
|
set(CMAKE_C_FLAGS_DEBUG_INIT "/D_DEBUG /MTd /Zi /Ob0 /Od /RTC1")
|
||||||
|
set(CMAKE_C_FLAGS_MINSIZEREL_INIT "/MT /O1 /Ob1 /D NDEBUG")
|
||||||
|
set(CMAKE_C_FLAGS_RELEASE_INIT "/MT /O2 /Ob2 /D NDEBUG")
|
||||||
|
set(CMAKE_C_FLAGS_RELWITHDEBINFO_INIT "/MT /Zi /O2 /Ob1 /D NDEBUG")
|
||||||
|
endif()
|
||||||
|
|
2
vendor/MaxmindDB/configure.ac
vendored
2
vendor/MaxmindDB/configure.ac
vendored
@ -2,7 +2,7 @@
|
|||||||
# Process this file with autoconf to produce a configure script.
|
# Process this file with autoconf to produce a configure script.
|
||||||
|
|
||||||
AC_PREREQ([2.63])
|
AC_PREREQ([2.63])
|
||||||
AC_INIT([libmaxminddb], [1.5.0], [support@maxmind.com])
|
AC_INIT([libmaxminddb], [1.6.0], [support@maxmind.com])
|
||||||
AC_CONFIG_SRCDIR([include/maxminddb.h])
|
AC_CONFIG_SRCDIR([include/maxminddb.h])
|
||||||
AC_CONFIG_HEADERS([config.h include/maxminddb_config.h])
|
AC_CONFIG_HEADERS([config.h include/maxminddb_config.h])
|
||||||
|
|
||||||
|
6
vendor/MaxmindDB/cxx_flag_overrides.cmake
vendored
Normal file
6
vendor/MaxmindDB/cxx_flag_overrides.cmake
vendored
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
if(MSVC)
|
||||||
|
set(CMAKE_CXX_FLAGS_DEBUG_INIT "/D_DEBUG /MTd /Zi /Ob0 /Od /RTC1")
|
||||||
|
set(CMAKE_CXX_FLAGS_MINSIZEREL_INIT "/MT /O1 /Ob1 /D NDEBUG")
|
||||||
|
set(CMAKE_CXX_FLAGS_RELEASE_INIT "/MT /O2 /Ob2 /D NDEBUG")
|
||||||
|
set(CMAKE_CXX_FLAGS_RELWITHDEBINFO_INIT "/MT /Zi /O2 /Ob1 /D NDEBUG")
|
||||||
|
endif()
|
15
vendor/MaxmindDB/dev-bin/clang-format-all.sh
vendored
Normal file
15
vendor/MaxmindDB/dev-bin/clang-format-all.sh
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
format="clang-format -i -style=file"
|
||||||
|
|
||||||
|
for dir in bin include src t; do
|
||||||
|
c_files=`find $dir -maxdepth 1 -name '*.c'`
|
||||||
|
if [ "$c_files" != "" ]; then
|
||||||
|
$format $dir/*.c;
|
||||||
|
fi
|
||||||
|
|
||||||
|
h_files=`find $dir -maxdepth 1 -name '*.h'`
|
||||||
|
if [ "$h_files" != "" ]; then
|
||||||
|
$format $dir/*.h;
|
||||||
|
fi
|
||||||
|
done
|
77
vendor/MaxmindDB/dev-bin/make-man-pages.pl
vendored
77
vendor/MaxmindDB/dev-bin/make-man-pages.pl
vendored
@ -7,53 +7,75 @@ use autodie qw( :all );
|
|||||||
use FindBin qw( $Bin );
|
use FindBin qw( $Bin );
|
||||||
|
|
||||||
use File::Path qw( mkpath );
|
use File::Path qw( mkpath );
|
||||||
use File::Slurp qw( edit_file read_file write_file );
|
use File::Slurp qw( edit_file read_file );
|
||||||
use File::Temp qw( tempdir );
|
|
||||||
use File::Which qw( which );
|
use File::Which qw( which );
|
||||||
|
|
||||||
sub main {
|
sub main {
|
||||||
my $target = shift || "$Bin/..";
|
my $target = shift || "$Bin/..";
|
||||||
|
|
||||||
my $pandoc = which('pandoc')
|
my @translators = qw ( lowdown pandoc );
|
||||||
or die
|
my $translator;
|
||||||
"\n You must install pandoc in order to generate the man pages.\n\n";
|
foreach my $p (@translators) {
|
||||||
|
if ( defined which($p) ) {
|
||||||
|
$translator = $p;
|
||||||
|
last;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
unless ( defined $translator ) {
|
||||||
|
die "\n You must install one of "
|
||||||
|
. join( ', ', @translators )
|
||||||
|
. " in order to generate the man pages.\n\n";
|
||||||
|
}
|
||||||
|
|
||||||
_make_man( $target, 'libmaxminddb', 3 );
|
_make_man( $translator, $target, 'libmaxminddb', 3 );
|
||||||
_make_lib_man_links($target);
|
_make_lib_man_links($target);
|
||||||
|
|
||||||
_make_man( $target, 'mmdblookup', 1 );
|
_make_man( $translator, $target, 'mmdblookup', 1 );
|
||||||
}
|
}
|
||||||
|
|
||||||
sub _make_man {
|
sub _make_man {
|
||||||
my $target = shift;
|
my $translator = shift;
|
||||||
my $name = shift;
|
my $target = shift;
|
||||||
my $section = shift;
|
my $name = shift;
|
||||||
|
my $section = shift;
|
||||||
|
|
||||||
|
my $input = "$Bin/../doc/$name.md";
|
||||||
my $man_dir = "$target/man/man$section";
|
my $man_dir = "$target/man/man$section";
|
||||||
mkpath($man_dir);
|
mkpath($man_dir);
|
||||||
|
my $output = "$man_dir/$name.$section";
|
||||||
|
|
||||||
my $tempdir = tempdir( CLEANUP => 1 );
|
if ( $translator eq 'pandoc' ) {
|
||||||
|
system(
|
||||||
my $markdown = <<"EOF";
|
'pandoc',
|
||||||
% $name($section)
|
'-s',
|
||||||
|
'-f', 'markdown_mmd+backtick_code_blocks',
|
||||||
EOF
|
'-t', 'man',
|
||||||
$markdown .= read_file("$Bin/../doc/$name.md");
|
'-M', "title:$name",
|
||||||
|
'-M', "section:$section",
|
||||||
my $tempfile = "$tempdir/$name.$section.md";
|
$input,
|
||||||
write_file( $tempfile, $markdown );
|
'-o', $output,
|
||||||
|
);
|
||||||
my $man_file = "$man_dir/$name.$section";
|
_pandoc_postprocess($output);
|
||||||
system( qw( pandoc -s -t man ), $tempfile, '-o', $man_file );
|
}
|
||||||
|
elsif ( $translator eq 'lowdown' ) {
|
||||||
_fix_indentation($man_file);
|
system(
|
||||||
|
'lowdown',
|
||||||
|
'-s',
|
||||||
|
'--out-no-smarty',
|
||||||
|
'-Tman',
|
||||||
|
'-M', "title:$name",
|
||||||
|
'-M', "section:$section",
|
||||||
|
$input,
|
||||||
|
'-o', $output,
|
||||||
|
);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sub _make_lib_man_links {
|
sub _make_lib_man_links {
|
||||||
my $target = shift;
|
my $target = shift;
|
||||||
|
|
||||||
my $header = read_file("$Bin/../include/maxminddb.h");
|
my $header = read_file("$Bin/../include/maxminddb.h");
|
||||||
for my $proto ( $header =~ /^ *extern.+?(\w+)\(/gsm ) {
|
for my $proto ( $header =~ /^ *extern.+?(MMDB_\w+)\(/gsm ) {
|
||||||
open my $fh, '>', "$target/man/man3/$proto.3";
|
open my $fh, '>', "$target/man/man3/$proto.3";
|
||||||
print {$fh} ".so man3/libmaxminddb.3\n";
|
print {$fh} ".so man3/libmaxminddb.3\n";
|
||||||
close $fh;
|
close $fh;
|
||||||
@ -62,12 +84,13 @@ sub _make_lib_man_links {
|
|||||||
|
|
||||||
# AFAICT there's no way to control the indentation depth for code blocks with
|
# AFAICT there's no way to control the indentation depth for code blocks with
|
||||||
# Pandoc.
|
# Pandoc.
|
||||||
sub _fix_indentation {
|
sub _pandoc_postprocess {
|
||||||
my $file = shift;
|
my $file = shift;
|
||||||
|
|
||||||
edit_file(
|
edit_file(
|
||||||
sub {
|
sub {
|
||||||
s/^\.IP\n\.nf/.IP "" 4\n.nf/gm;
|
s/^\.IP\n\.nf/.IP "" 4\n.nf/gm;
|
||||||
|
s/(Automatically generated by Pandoc)(.+)$/$1/m;
|
||||||
},
|
},
|
||||||
$file
|
$file
|
||||||
);
|
);
|
||||||
|
2
vendor/MaxmindDB/dev-bin/ppa-release.sh
vendored
2
vendor/MaxmindDB/dev-bin/ppa-release.sh
vendored
@ -4,7 +4,7 @@ set -e
|
|||||||
set -x
|
set -x
|
||||||
set -u
|
set -u
|
||||||
|
|
||||||
DISTS=( artful zesty xenial trusty precise )
|
DISTS=( groovy focal bionic xenial trusty )
|
||||||
|
|
||||||
VERSION=$(perl -MFile::Slurp::Tiny=read_file -MDateTime <<EOF
|
VERSION=$(perl -MFile::Slurp::Tiny=read_file -MDateTime <<EOF
|
||||||
use v5.16;
|
use v5.16;
|
||||||
|
19
vendor/MaxmindDB/dev-bin/uncrustify-all.sh
vendored
19
vendor/MaxmindDB/dev-bin/uncrustify-all.sh
vendored
@ -1,19 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
|
|
||||||
uncrustify="uncrustify -c .uncrustify.cfg --replace --no-backup"
|
|
||||||
|
|
||||||
# We indent each thing twice because uncrustify is not idempotent - in some
|
|
||||||
# cases it will flip-flop between two indentation styles.
|
|
||||||
for dir in bin include src t; do
|
|
||||||
c_files=`find $dir -maxdepth 1 -name '*.c'`
|
|
||||||
if [ "$c_files" != "" ]; then
|
|
||||||
$uncrustify $dir/*.c;
|
|
||||||
$uncrustify $dir/*.c;
|
|
||||||
fi
|
|
||||||
|
|
||||||
h_files=`find $dir -maxdepth 1 -name '*.h'`
|
|
||||||
if [ "$h_files" != "" ]; then
|
|
||||||
$uncrustify $dir/*.h;
|
|
||||||
$uncrustify $dir/*.h;
|
|
||||||
fi
|
|
||||||
done
|
|
37
vendor/MaxmindDB/include/maxminddb.h
vendored
37
vendor/MaxmindDB/include/maxminddb.h
vendored
@ -28,7 +28,7 @@ extern "C" {
|
|||||||
#include <winsock2.h>
|
#include <winsock2.h>
|
||||||
#include <ws2tcpip.h>
|
#include <ws2tcpip.h>
|
||||||
/* libmaxminddb package version from configure */
|
/* libmaxminddb package version from configure */
|
||||||
#define PACKAGE_VERSION "1.5.0"
|
#define PACKAGE_VERSION "1.6.0"
|
||||||
|
|
||||||
typedef ADDRESS_FAMILY sa_family_t;
|
typedef ADDRESS_FAMILY sa_family_t;
|
||||||
|
|
||||||
@ -87,7 +87,7 @@ typedef ADDRESS_FAMILY sa_family_t;
|
|||||||
|
|
||||||
#if !(MMDB_UINT128_IS_BYTE_ARRAY)
|
#if !(MMDB_UINT128_IS_BYTE_ARRAY)
|
||||||
#if MMDB_UINT128_USING_MODE
|
#if MMDB_UINT128_USING_MODE
|
||||||
typedef unsigned int mmdb_uint128_t __attribute__ ((__mode__(TI)));
|
typedef unsigned int mmdb_uint128_t __attribute__((__mode__(TI)));
|
||||||
#else
|
#else
|
||||||
typedef unsigned __int128 mmdb_uint128_t;
|
typedef unsigned __int128 mmdb_uint128_t;
|
||||||
#endif
|
#endif
|
||||||
@ -139,7 +139,8 @@ typedef struct MMDB_entry_data_s {
|
|||||||
uint32_t type;
|
uint32_t type;
|
||||||
} MMDB_entry_data_s;
|
} MMDB_entry_data_s;
|
||||||
|
|
||||||
/* This is the return type when someone asks for all the entry data in a map or array */
|
/* This is the return type when someone asks for all the entry data in a map or
|
||||||
|
* array */
|
||||||
typedef struct MMDB_entry_data_list_s {
|
typedef struct MMDB_entry_data_list_s {
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
struct MMDB_entry_data_list_s *next;
|
struct MMDB_entry_data_list_s *next;
|
||||||
@ -213,16 +214,16 @@ typedef struct MMDB_search_node_s {
|
|||||||
MMDB_entry_s right_record_entry;
|
MMDB_entry_s right_record_entry;
|
||||||
} MMDB_search_node_s;
|
} MMDB_search_node_s;
|
||||||
|
|
||||||
extern int MMDB_open(const char *const filename, uint32_t flags,
|
extern int
|
||||||
MMDB_s *const mmdb);
|
MMDB_open(const char *const filename, uint32_t flags, MMDB_s *const mmdb);
|
||||||
extern MMDB_lookup_result_s MMDB_lookup_string(const MMDB_s *const mmdb,
|
extern MMDB_lookup_result_s MMDB_lookup_string(const MMDB_s *const mmdb,
|
||||||
const char *const ipstr,
|
const char *const ipstr,
|
||||||
int *const gai_error,
|
int *const gai_error,
|
||||||
int *const mmdb_error);
|
int *const mmdb_error);
|
||||||
extern MMDB_lookup_result_s MMDB_lookup_sockaddr(
|
extern MMDB_lookup_result_s
|
||||||
const MMDB_s *const mmdb,
|
MMDB_lookup_sockaddr(const MMDB_s *const mmdb,
|
||||||
const struct sockaddr *const sockaddr,
|
const struct sockaddr *const sockaddr,
|
||||||
int *const mmdb_error);
|
int *const mmdb_error);
|
||||||
extern int MMDB_read_node(const MMDB_s *const mmdb,
|
extern int MMDB_read_node(const MMDB_s *const mmdb,
|
||||||
uint32_t node_number,
|
uint32_t node_number,
|
||||||
MMDB_search_node_s *const node);
|
MMDB_search_node_s *const node);
|
||||||
@ -237,18 +238,20 @@ extern int MMDB_aget_value(MMDB_entry_s *const start,
|
|||||||
const char *const *const path);
|
const char *const *const path);
|
||||||
extern int MMDB_get_metadata_as_entry_data_list(
|
extern int MMDB_get_metadata_as_entry_data_list(
|
||||||
const MMDB_s *const mmdb, MMDB_entry_data_list_s **const entry_data_list);
|
const MMDB_s *const mmdb, MMDB_entry_data_list_s **const entry_data_list);
|
||||||
extern int MMDB_get_entry_data_list(
|
extern int
|
||||||
MMDB_entry_s *start, MMDB_entry_data_list_s **const entry_data_list);
|
MMDB_get_entry_data_list(MMDB_entry_s *start,
|
||||||
extern void MMDB_free_entry_data_list(
|
MMDB_entry_data_list_s **const entry_data_list);
|
||||||
MMDB_entry_data_list_s *const entry_data_list);
|
extern void
|
||||||
|
MMDB_free_entry_data_list(MMDB_entry_data_list_s *const entry_data_list);
|
||||||
extern void MMDB_close(MMDB_s *const mmdb);
|
extern void MMDB_close(MMDB_s *const mmdb);
|
||||||
extern const char *MMDB_lib_version(void);
|
extern const char *MMDB_lib_version(void);
|
||||||
extern int MMDB_dump_entry_data_list(FILE *const stream,
|
extern int
|
||||||
MMDB_entry_data_list_s *const entry_data_list,
|
MMDB_dump_entry_data_list(FILE *const stream,
|
||||||
int indent);
|
MMDB_entry_data_list_s *const entry_data_list,
|
||||||
|
int indent);
|
||||||
extern const char *MMDB_strerror(int error_code);
|
extern const char *MMDB_strerror(int error_code);
|
||||||
|
|
||||||
#endif /* MAXMINDDB_H */
|
#endif /* MAXMINDDB_H */
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
29
vendor/MaxmindDB/src/data-pool.c
vendored
29
vendor/MaxmindDB/src/data-pool.c
vendored
@ -9,8 +9,7 @@ static bool can_multiply(size_t const, size_t const, size_t const);
|
|||||||
|
|
||||||
// Allocate an MMDB_data_pool_s. It initially has space for size
|
// Allocate an MMDB_data_pool_s. It initially has space for size
|
||||||
// MMDB_entry_data_list_s structs.
|
// MMDB_entry_data_list_s structs.
|
||||||
MMDB_data_pool_s *data_pool_new(size_t const size)
|
MMDB_data_pool_s *data_pool_new(size_t const size) {
|
||||||
{
|
|
||||||
MMDB_data_pool_s *const pool = calloc(1, sizeof(MMDB_data_pool_s));
|
MMDB_data_pool_s *const pool = calloc(1, sizeof(MMDB_data_pool_s));
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -40,8 +39,7 @@ MMDB_data_pool_s *data_pool_new(size_t const size)
|
|||||||
// the given max. max will typically be SIZE_MAX.
|
// the given max. max will typically be SIZE_MAX.
|
||||||
//
|
//
|
||||||
// We want to know if we'll wrap around.
|
// We want to know if we'll wrap around.
|
||||||
static bool can_multiply(size_t const max, size_t const m, size_t const n)
|
static bool can_multiply(size_t const max, size_t const m, size_t const n) {
|
||||||
{
|
|
||||||
if (m == 0) {
|
if (m == 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -50,8 +48,7 @@ static bool can_multiply(size_t const max, size_t const m, size_t const n)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Clean up the data pool.
|
// Clean up the data pool.
|
||||||
void data_pool_destroy(MMDB_data_pool_s *const pool)
|
void data_pool_destroy(MMDB_data_pool_s *const pool) {
|
||||||
{
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -65,8 +62,7 @@ void data_pool_destroy(MMDB_data_pool_s *const pool)
|
|||||||
|
|
||||||
// Claim a new struct from the pool. Doing this may cause the pool's size to
|
// Claim a new struct from the pool. Doing this may cause the pool's size to
|
||||||
// grow.
|
// grow.
|
||||||
MMDB_entry_data_list_s *data_pool_alloc(MMDB_data_pool_s *const pool)
|
MMDB_entry_data_list_s *data_pool_alloc(MMDB_data_pool_s *const pool) {
|
||||||
{
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -115,8 +111,7 @@ MMDB_entry_data_list_s *data_pool_alloc(MMDB_data_pool_s *const pool)
|
|||||||
// Turn the structs in the array-like pool into a linked list.
|
// Turn the structs in the array-like pool into a linked list.
|
||||||
//
|
//
|
||||||
// Before calling this function, the list isn't linked up.
|
// Before calling this function, the list isn't linked up.
|
||||||
MMDB_entry_data_list_s *data_pool_to_list(MMDB_data_pool_s *const pool)
|
MMDB_entry_data_list_s *data_pool_to_list(MMDB_data_pool_s *const pool) {
|
||||||
{
|
|
||||||
if (!pool) {
|
if (!pool) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -154,22 +149,16 @@ MMDB_entry_data_list_s *data_pool_to_list(MMDB_data_pool_s *const pool)
|
|||||||
|
|
||||||
static void test_can_multiply(void);
|
static void test_can_multiply(void);
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
test_can_multiply();
|
test_can_multiply();
|
||||||
done_testing();
|
done_testing();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_can_multiply(void)
|
static void test_can_multiply(void) {
|
||||||
{
|
{ ok(can_multiply(SIZE_MAX, 1, SIZE_MAX), "1*SIZE_MAX is ok"); }
|
||||||
{
|
|
||||||
ok(can_multiply(SIZE_MAX, 1, SIZE_MAX), "1*SIZE_MAX is ok");
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{ ok(!can_multiply(SIZE_MAX, 2, SIZE_MAX), "2*SIZE_MAX is not ok"); }
|
||||||
ok(!can_multiply(SIZE_MAX, 2, SIZE_MAX), "2*SIZE_MAX is not ok");
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{
|
||||||
ok(can_multiply(SIZE_MAX, 10240, sizeof(MMDB_entry_data_list_s)),
|
ok(can_multiply(SIZE_MAX, 10240, sizeof(MMDB_entry_data_list_s)),
|
||||||
|
93
vendor/MaxmindDB/src/maxminddb-compat-util.h
vendored
93
vendor/MaxmindDB/src/maxminddb-compat-util.h
vendored
@ -43,32 +43,31 @@
|
|||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
static void *
|
static void *
|
||||||
mmdb_memmem(const void *l, size_t l_len, const void *s, size_t s_len)
|
mmdb_memmem(const void *l, size_t l_len, const void *s, size_t s_len) {
|
||||||
{
|
register char *cur, *last;
|
||||||
register char *cur, *last;
|
const char *cl = (const char *)l;
|
||||||
const char *cl = (const char *)l;
|
const char *cs = (const char *)s;
|
||||||
const char *cs = (const char *)s;
|
|
||||||
|
|
||||||
/* we need something to compare */
|
/* we need something to compare */
|
||||||
if (l_len == 0 || s_len == 0)
|
if (l_len == 0 || s_len == 0)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
/* "s" must be smaller or equal to "l" */
|
/* "s" must be smaller or equal to "l" */
|
||||||
if (l_len < s_len)
|
if (l_len < s_len)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
/* special case where s_len == 1 */
|
/* special case where s_len == 1 */
|
||||||
if (s_len == 1)
|
if (s_len == 1)
|
||||||
return memchr(l, (int)*cs, l_len);
|
return memchr(l, (int)*cs, l_len);
|
||||||
|
|
||||||
/* the last position where its possible to find "s" in "l" */
|
/* the last position where its possible to find "s" in "l" */
|
||||||
last = (char *)cl + l_len - s_len;
|
last = (char *)cl + l_len - s_len;
|
||||||
|
|
||||||
for (cur = (char *)cl; cur <= last; cur++)
|
for (cur = (char *)cl; cur <= last; cur++)
|
||||||
if (cur[0] == cs[0] && memcmp(cur, cs, s_len) == 0)
|
if (cur[0] == cs[0] && memcmp(cur, cs, s_len) == 0)
|
||||||
return cur;
|
return cur;
|
||||||
|
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Applies to strnlen implementation */
|
/* Applies to strnlen implementation */
|
||||||
@ -97,16 +96,14 @@ mmdb_memmem(const void *l, size_t l_len, const void *s, size_t s_len)
|
|||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
static size_t
|
static size_t mmdb_strnlen(const char *s, size_t maxlen) {
|
||||||
mmdb_strnlen(const char *s, size_t maxlen)
|
size_t len;
|
||||||
{
|
|
||||||
size_t len;
|
|
||||||
|
|
||||||
for (len = 0; len < maxlen; len++, s++) {
|
for (len = 0; len < maxlen; len++, s++) {
|
||||||
if (!*s)
|
if (!*s)
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
return (len);
|
return (len);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Applies to strdup and strndup implementation */
|
/* Applies to strdup and strndup implementation */
|
||||||
@ -138,30 +135,26 @@ mmdb_strnlen(const char *s, size_t maxlen)
|
|||||||
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
* SUCH DAMAGE.
|
* SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
static char *
|
static char *mmdb_strdup(const char *str) {
|
||||||
mmdb_strdup(const char *str)
|
size_t len;
|
||||||
{
|
char *copy;
|
||||||
size_t len;
|
|
||||||
char *copy;
|
|
||||||
|
|
||||||
len = strlen(str) + 1;
|
len = strlen(str) + 1;
|
||||||
if ((copy = malloc(len)) == NULL)
|
if ((copy = malloc(len)) == NULL)
|
||||||
return (NULL);
|
return (NULL);
|
||||||
memcpy(copy, str, len);
|
memcpy(copy, str, len);
|
||||||
return (copy);
|
return (copy);
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *
|
static char *mmdb_strndup(const char *str, size_t n) {
|
||||||
mmdb_strndup(const char *str, size_t n)
|
size_t len;
|
||||||
{
|
char *copy;
|
||||||
size_t len;
|
|
||||||
char *copy;
|
|
||||||
|
|
||||||
len = mmdb_strnlen(str, n);
|
len = mmdb_strnlen(str, n);
|
||||||
if ((copy = malloc(len + 1)) == NULL)
|
if ((copy = malloc(len + 1)) == NULL)
|
||||||
return (NULL);
|
return (NULL);
|
||||||
memcpy(copy, str, len);
|
memcpy(copy, str, len);
|
||||||
copy[len] = '\0';
|
copy[len] = '\0';
|
||||||
return (copy);
|
return (copy);
|
||||||
}
|
}
|
||||||
/* *INDENT-ON* */
|
/* *INDENT-ON* */
|
||||||
|
1175
vendor/MaxmindDB/src/maxminddb.c
vendored
1175
vendor/MaxmindDB/src/maxminddb.c
vendored
File diff suppressed because it is too large
Load Diff
14
vendor/MaxmindDB/t/bad_databases_t.c
vendored
14
vendor/MaxmindDB/t/bad_databases_t.c
vendored
@ -8,9 +8,10 @@
|
|||||||
|
|
||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
int test_read(const char *path, const struct stat *UNUSED(
|
int test_read(const char *path,
|
||||||
sbuf), int flags, struct FTW *UNUSED(ftw))
|
const struct stat *UNUSED(sbuf),
|
||||||
{
|
int flags,
|
||||||
|
struct FTW *UNUSED(ftw)) {
|
||||||
// Check if path is a regular file)
|
// Check if path is a regular file)
|
||||||
if (flags != FTW_F) {
|
if (flags != FTW_F) {
|
||||||
return 0;
|
return 0;
|
||||||
@ -36,16 +37,15 @@ int test_read(const char *path, const struct stat *UNUSED(
|
|||||||
BAIL_OUT("could not parse IP address");
|
BAIL_OUT("could not parse IP address");
|
||||||
}
|
}
|
||||||
|
|
||||||
cmp_ok(mmdb_error, "!=", MMDB_SUCCESS, "opening %s returned an error",
|
cmp_ok(
|
||||||
path);
|
mmdb_error, "!=", MMDB_SUCCESS, "opening %s returned an error", path);
|
||||||
|
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
free(mmdb);
|
free(mmdb);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
char *test_db_dir;
|
char *test_db_dir;
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
test_db_dir = "../t/maxmind-db/bad-data";
|
test_db_dir = "../t/maxmind-db/bad-data";
|
||||||
|
31
vendor/MaxmindDB/t/bad_pointers_t.c
vendored
31
vendor/MaxmindDB/t/bad_pointers_t.c
vendored
@ -1,7 +1,6 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-broken-pointers-24.mmdb";
|
const char *filename = "MaxMind-DB-test-broken-pointers-24.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -15,16 +14,20 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
int status = MMDB_get_value(&result.entry, &entry_data, NULL);
|
int status = MMDB_get_value(&result.entry, &entry_data, NULL);
|
||||||
|
|
||||||
cmp_ok(
|
cmp_ok(status,
|
||||||
status, "==", MMDB_INVALID_DATA_ERROR,
|
"==",
|
||||||
"MMDB_get_value returns MMDB_INVALID_DATA_ERROR for bad pointer in data section");
|
MMDB_INVALID_DATA_ERROR,
|
||||||
|
"MMDB_get_value returns MMDB_INVALID_DATA_ERROR for bad pointer "
|
||||||
|
"in data section");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *entry_data_list;
|
MMDB_entry_data_list_s *entry_data_list;
|
||||||
status = MMDB_get_entry_data_list(&result.entry, &entry_data_list);
|
status = MMDB_get_entry_data_list(&result.entry, &entry_data_list);
|
||||||
|
|
||||||
cmp_ok(
|
cmp_ok(status,
|
||||||
status, "==", MMDB_INVALID_DATA_ERROR,
|
"==",
|
||||||
"MMDB_get_entry_data_list returns MMDB_INVALID_DATA_ERROR for bad pointer in data section");
|
MMDB_INVALID_DATA_ERROR,
|
||||||
|
"MMDB_get_entry_data_list returns MMDB_INVALID_DATA_ERROR for "
|
||||||
|
"bad pointer in data section");
|
||||||
|
|
||||||
MMDB_free_entry_data_list(entry_data_list);
|
MMDB_free_entry_data_list(entry_data_list);
|
||||||
}
|
}
|
||||||
@ -36,17 +39,19 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_lookup_result_s UNUSED(result) =
|
MMDB_lookup_result_s UNUSED(result) =
|
||||||
MMDB_lookup_string(mmdb, ip, &gai_error, &mmdb_error);
|
MMDB_lookup_string(mmdb, ip, &gai_error, &mmdb_error);
|
||||||
|
|
||||||
cmp_ok(
|
cmp_ok(mmdb_error,
|
||||||
mmdb_error, "==", MMDB_CORRUPT_SEARCH_TREE_ERROR,
|
"==",
|
||||||
"MMDB_lookup_string sets mmdb_error to MMDB_CORRUPT_SEARCH_TREE_ERROR when a search tree record points outside the data section");
|
MMDB_CORRUPT_SEARCH_TREE_ERROR,
|
||||||
|
"MMDB_lookup_string sets mmdb_error to "
|
||||||
|
"MMDB_CORRUPT_SEARCH_TREE_ERROR when a search tree record "
|
||||||
|
"points outside the data section");
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
164
vendor/MaxmindDB/t/basic_lookup_t.c
vendored
164
vendor/MaxmindDB/t/basic_lookup_t.c
vendored
@ -7,14 +7,19 @@ static void test_big_lookup(void);
|
|||||||
static int Current_Mode;
|
static int Current_Mode;
|
||||||
static const char *Current_Mode_Description;
|
static const char *Current_Mode_Description;
|
||||||
|
|
||||||
void test_one_result(MMDB_s *mmdb, MMDB_lookup_result_s result,
|
void test_one_result(MMDB_s *mmdb,
|
||||||
const char *ip, const char *expect,
|
MMDB_lookup_result_s result,
|
||||||
const char *function, const char *filename,
|
const char *ip,
|
||||||
const char *mode_desc)
|
const char *expect,
|
||||||
{
|
const char *function,
|
||||||
|
const char *filename,
|
||||||
|
const char *mode_desc) {
|
||||||
int is_ok = ok(result.found_entry,
|
int is_ok = ok(result.found_entry,
|
||||||
"got a result for an IP in the database - %s - %s - %s - %s",
|
"got a result for an IP in the database - %s - %s - %s - %s",
|
||||||
function, ip, filename, mode_desc);
|
function,
|
||||||
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
return;
|
return;
|
||||||
@ -33,35 +38,45 @@ void test_one_result(MMDB_s *mmdb, MMDB_lookup_result_s result,
|
|||||||
// something like "::1.2.3.4", not just "1.2.3.4".
|
// something like "::1.2.3.4", not just "1.2.3.4".
|
||||||
int maxlen = strlen(expect) + 3;
|
int maxlen = strlen(expect) + 3;
|
||||||
real_expect = malloc(maxlen);
|
real_expect = malloc(maxlen);
|
||||||
|
if (!real_expect) {
|
||||||
|
BAIL_OUT("could not allocate memory");
|
||||||
|
}
|
||||||
snprintf(real_expect, maxlen, "::%s", expect);
|
snprintf(real_expect, maxlen, "::%s", expect);
|
||||||
}
|
}
|
||||||
|
|
||||||
is(string, real_expect,
|
is(string,
|
||||||
"found expected result for ip key - %s - %s - %s - %s", function, ip,
|
real_expect,
|
||||||
filename, mode_desc);
|
"found expected result for ip key - %s - %s - %s - %s",
|
||||||
|
function,
|
||||||
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
free(real_expect);
|
free(real_expect);
|
||||||
free(string);
|
free(string);
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_one_ip(MMDB_s *mmdb, const char *ip, const char *expect,
|
void test_one_ip(MMDB_s *mmdb,
|
||||||
const char *filename, const char *mode_desc)
|
const char *ip,
|
||||||
{
|
const char *expect,
|
||||||
|
const char *filename,
|
||||||
|
const char *mode_desc) {
|
||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
||||||
|
|
||||||
test_one_result(mmdb, result, ip, expect, "MMDB_lookup_string", filename,
|
test_one_result(
|
||||||
mode_desc);
|
mmdb, result, ip, expect, "MMDB_lookup_string", filename, mode_desc);
|
||||||
|
|
||||||
result = lookup_sockaddr_ok(mmdb, ip, filename, mode_desc);
|
result = lookup_sockaddr_ok(mmdb, ip, filename, mode_desc);
|
||||||
test_one_result(mmdb, result, ip, expect, "MMDB_lookup_addrinfo", filename,
|
test_one_result(
|
||||||
mode_desc);
|
mmdb, result, ip, expect, "MMDB_lookup_addrinfo", filename, mode_desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_ipX_tests(const char *filename, const char **missing_ips,
|
void run_ipX_tests(const char *filename,
|
||||||
int missing_ips_length, const char *pairs[][2],
|
const char **missing_ips,
|
||||||
int pairs_rows)
|
int missing_ips_length,
|
||||||
{
|
const char *pairs[][2],
|
||||||
|
int pairs_rows) {
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
int mode = Current_Mode;
|
int mode = Current_Mode;
|
||||||
const char *mode_desc = Current_Mode_Description;
|
const char *mode_desc = Current_Mode_Description;
|
||||||
@ -78,17 +93,21 @@ void run_ipX_tests(const char *filename, const char **missing_ips,
|
|||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
||||||
|
|
||||||
ok(
|
ok(!result.found_entry,
|
||||||
!result.found_entry,
|
"no result entry struct returned for IP address not in the database "
|
||||||
"no result entry struct returned for IP address not in the database (string lookup) - %s - %s - %s",
|
"(string lookup) - %s - %s - %s",
|
||||||
ip, filename, mode_desc);
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
result = lookup_sockaddr_ok(mmdb, ip, filename, mode_desc);
|
result = lookup_sockaddr_ok(mmdb, ip, filename, mode_desc);
|
||||||
|
|
||||||
ok(
|
ok(!result.found_entry,
|
||||||
!result.found_entry,
|
"no result entry struct returned for IP address not in the database "
|
||||||
"no result entry struct returned for IP address not in the database (ipv4 lookup) - %s - %s - %s",
|
"(ipv4 lookup) - %s - %s - %s",
|
||||||
ip, filename, mode_desc);
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < pairs_rows; i += 1) {
|
for (int i = 0; i < pairs_rows; i += 1) {
|
||||||
@ -102,52 +121,47 @@ void run_ipX_tests(const char *filename, const char **missing_ips,
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_ipv4_tests(int UNUSED(
|
void run_ipv4_tests(int UNUSED(record_size),
|
||||||
record_size), const char *filename, const char *UNUSED(
|
const char *filename,
|
||||||
ignored))
|
const char *UNUSED(ignored)) {
|
||||||
{
|
|
||||||
const char *pairs[9][2] = {
|
const char *pairs[9][2] = {
|
||||||
{ "1.1.1.1", "1.1.1.1" },
|
{"1.1.1.1", "1.1.1.1"},
|
||||||
{ "1.1.1.2", "1.1.1.2" },
|
{"1.1.1.2", "1.1.1.2"},
|
||||||
{ "1.1.1.3", "1.1.1.2" },
|
{"1.1.1.3", "1.1.1.2"},
|
||||||
{ "1.1.1.7", "1.1.1.4" },
|
{"1.1.1.7", "1.1.1.4"},
|
||||||
{ "1.1.1.9", "1.1.1.8" },
|
{"1.1.1.9", "1.1.1.8"},
|
||||||
{ "1.1.1.15", "1.1.1.8" },
|
{"1.1.1.15", "1.1.1.8"},
|
||||||
{ "1.1.1.17", "1.1.1.16" },
|
{"1.1.1.17", "1.1.1.16"},
|
||||||
{ "1.1.1.31", "1.1.1.16" },
|
{"1.1.1.31", "1.1.1.16"},
|
||||||
{ "1.1.1.32", "1.1.1.32" },
|
{"1.1.1.32", "1.1.1.32"},
|
||||||
};
|
};
|
||||||
|
|
||||||
const char *missing[1] = { "2.3.4.5" };
|
const char *missing[1] = {"2.3.4.5"};
|
||||||
run_ipX_tests(filename, missing, 1, pairs, 9);
|
run_ipX_tests(filename, missing, 1, pairs, 9);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_ipv6_tests(int UNUSED(
|
void run_ipv6_tests(int UNUSED(record_size),
|
||||||
record_size), const char *filename, const char *UNUSED(
|
const char *filename,
|
||||||
ignored))
|
const char *UNUSED(ignored)) {
|
||||||
{
|
|
||||||
const char *pairs[9][2] = {
|
const char *pairs[9][2] = {
|
||||||
{ "::1:ffff:ffff", "::1:ffff:ffff" },
|
{"::1:ffff:ffff", "::1:ffff:ffff"},
|
||||||
{ "::2:0:0", "::2:0:0" },
|
{"::2:0:0", "::2:0:0"},
|
||||||
{ "::2:0:1a", "::2:0:0" },
|
{"::2:0:1a", "::2:0:0"},
|
||||||
{ "::2:0:40", "::2:0:40" },
|
{"::2:0:40", "::2:0:40"},
|
||||||
{ "::2:0:4f", "::2:0:40" },
|
{"::2:0:4f", "::2:0:40"},
|
||||||
{ "::2:0:50", "::2:0:50" },
|
{"::2:0:50", "::2:0:50"},
|
||||||
{ "::2:0:52", "::2:0:50" },
|
{"::2:0:52", "::2:0:50"},
|
||||||
{ "::2:0:58", "::2:0:58" },
|
{"::2:0:58", "::2:0:58"},
|
||||||
{ "::2:0:59", "::2:0:58" },
|
{"::2:0:59", "::2:0:58"},
|
||||||
};
|
};
|
||||||
|
|
||||||
const char *missing[2] = { "2.3.4.5", "::abcd" };
|
const char *missing[2] = {"2.3.4.5", "::abcd"};
|
||||||
run_ipX_tests(filename, missing, 2, pairs, 9);
|
run_ipX_tests(filename, missing, 2, pairs, 9);
|
||||||
}
|
}
|
||||||
|
|
||||||
void all_record_sizes(int mode, const char *description)
|
void all_record_sizes(int mode, const char *description) {
|
||||||
{
|
const char *ipv4_filename_fmts[] = {"MaxMind-DB-test-ipv4-%i.mmdb",
|
||||||
const char *ipv4_filename_fmts[] = {
|
"MaxMind-DB-test-mixed-%i.mmdb"};
|
||||||
"MaxMind-DB-test-ipv4-%i.mmdb",
|
|
||||||
"MaxMind-DB-test-mixed-%i.mmdb"
|
|
||||||
};
|
|
||||||
|
|
||||||
Current_Mode = mode;
|
Current_Mode = mode;
|
||||||
Current_Mode_Description = description;
|
Current_Mode_Description = description;
|
||||||
@ -156,40 +170,35 @@ void all_record_sizes(int mode, const char *description)
|
|||||||
for_all_record_sizes(ipv4_filename_fmts[i], &run_ipv4_tests);
|
for_all_record_sizes(ipv4_filename_fmts[i], &run_ipv4_tests);
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *ipv6_filename_fmts[] = {
|
const char *ipv6_filename_fmts[] = {"MaxMind-DB-test-ipv6-%i.mmdb",
|
||||||
"MaxMind-DB-test-ipv6-%i.mmdb",
|
"MaxMind-DB-test-mixed-%i.mmdb"};
|
||||||
"MaxMind-DB-test-mixed-%i.mmdb"
|
|
||||||
};
|
|
||||||
|
|
||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
for_all_record_sizes(ipv6_filename_fmts[i], &run_ipv6_tests);
|
for_all_record_sizes(ipv6_filename_fmts[i], &run_ipv6_tests);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_big_lookup(void)
|
static void test_big_lookup(void) {
|
||||||
{
|
|
||||||
const char *const db_filename = "GeoIP2-Precision-Enterprise-Test.mmdb";
|
const char *const db_filename = "GeoIP2-Precision-Enterprise-Test.mmdb";
|
||||||
const char *const db_path = test_database_path(db_filename);
|
const char *const db_path = test_database_path(db_filename);
|
||||||
ok(db_path != NULL, "got database path");
|
ok(db_path != NULL, "got database path");
|
||||||
|
|
||||||
MMDB_s * const mmdb = open_ok(db_path, MMDB_MODE_MMAP, "mmap mode");
|
MMDB_s *const mmdb = open_ok(db_path, MMDB_MODE_MMAP, "mmap mode");
|
||||||
ok(mmdb != NULL, "opened MMDB");
|
ok(mmdb != NULL, "opened MMDB");
|
||||||
free((char *)db_path);
|
free((char *)db_path);
|
||||||
|
|
||||||
int gai_err = 0, mmdb_err = 0;
|
int gai_err = 0, mmdb_err = 0;
|
||||||
const char *const ip_address = "81.2.69.160";
|
const char *const ip_address = "81.2.69.160";
|
||||||
MMDB_lookup_result_s result = MMDB_lookup_string(mmdb, ip_address, &gai_err,
|
MMDB_lookup_result_s result =
|
||||||
&mmdb_err);
|
MMDB_lookup_string(mmdb, ip_address, &gai_err, &mmdb_err);
|
||||||
ok(gai_err == 0, "no getaddrinfo error");
|
ok(gai_err == 0, "no getaddrinfo error");
|
||||||
ok(mmdb_err == MMDB_SUCCESS, "no error from maxminddb library");
|
ok(mmdb_err == MMDB_SUCCESS, "no error from maxminddb library");
|
||||||
ok(result.found_entry, "found IP");
|
ok(result.found_entry, "found IP");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *entry_data_list = NULL;
|
MMDB_entry_data_list_s *entry_data_list = NULL;
|
||||||
ok(
|
ok(MMDB_get_entry_data_list(&result.entry, &entry_data_list) ==
|
||||||
MMDB_get_entry_data_list(&result.entry,
|
MMDB_SUCCESS,
|
||||||
&entry_data_list) == MMDB_SUCCESS,
|
"successfully looked up entry data list");
|
||||||
"successfully looked up entry data list"
|
|
||||||
);
|
|
||||||
ok(entry_data_list != NULL, "got an entry_data_list");
|
ok(entry_data_list != NULL, "got an entry_data_list");
|
||||||
|
|
||||||
MMDB_free_entry_data_list(entry_data_list);
|
MMDB_free_entry_data_list(entry_data_list);
|
||||||
@ -198,8 +207,7 @@ static void test_big_lookup(void)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&all_record_sizes);
|
for_all_modes(&all_record_sizes);
|
||||||
test_big_lookup();
|
test_big_lookup();
|
||||||
|
112
vendor/MaxmindDB/t/data-pool-t.c
vendored
112
vendor/MaxmindDB/t/data-pool-t.c
vendored
@ -1,21 +1,19 @@
|
|||||||
|
#include "libtap/tap.h"
|
||||||
|
#include "maxminddb_test_helper.h"
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <data-pool.h>
|
#include <data-pool.h>
|
||||||
#include <inttypes.h>
|
#include <inttypes.h>
|
||||||
#include "libtap/tap.h"
|
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include "maxminddb_test_helper.h"
|
|
||||||
|
|
||||||
static void test_data_pool_new(void);
|
static void test_data_pool_new(void);
|
||||||
static void test_data_pool_destroy(void);
|
static void test_data_pool_destroy(void);
|
||||||
static void test_data_pool_alloc(void);
|
static void test_data_pool_alloc(void);
|
||||||
static void test_data_pool_to_list(void);
|
static void test_data_pool_to_list(void);
|
||||||
static bool create_and_check_list(size_t const,
|
static bool create_and_check_list(size_t const, size_t const);
|
||||||
size_t const);
|
|
||||||
static void check_block_count(MMDB_entry_data_list_s const *const,
|
static void check_block_count(MMDB_entry_data_list_s const *const,
|
||||||
size_t const);
|
size_t const);
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
test_data_pool_new();
|
test_data_pool_new();
|
||||||
test_data_pool_destroy();
|
test_data_pool_destroy();
|
||||||
@ -24,8 +22,7 @@ int main(void)
|
|||||||
done_testing();
|
done_testing();
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_data_pool_new(void)
|
static void test_data_pool_new(void) {
|
||||||
{
|
|
||||||
{
|
{
|
||||||
MMDB_data_pool_s *const pool = data_pool_new(0);
|
MMDB_data_pool_s *const pool = data_pool_new(0);
|
||||||
ok(!pool, "size 0 is not valid");
|
ok(!pool, "size 0 is not valid");
|
||||||
@ -45,11 +42,8 @@ static void test_data_pool_new(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_data_pool_destroy(void)
|
static void test_data_pool_destroy(void) {
|
||||||
{
|
{ data_pool_destroy(NULL); }
|
||||||
{
|
|
||||||
data_pool_destroy(NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
{
|
{
|
||||||
MMDB_data_pool_s *const pool = data_pool_new(512);
|
MMDB_data_pool_s *const pool = data_pool_new(512);
|
||||||
@ -58,8 +52,7 @@ static void test_data_pool_destroy(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_data_pool_alloc(void)
|
static void test_data_pool_alloc(void) {
|
||||||
{
|
|
||||||
{
|
{
|
||||||
MMDB_data_pool_s *const pool = data_pool_new(1);
|
MMDB_data_pool_s *const pool = data_pool_new(1);
|
||||||
ok(pool != NULL, "created pool");
|
ok(pool != NULL, "created pool");
|
||||||
@ -109,20 +102,18 @@ static void test_data_pool_alloc(void)
|
|||||||
ok(entry != NULL, "got an entry");
|
ok(entry != NULL, "got an entry");
|
||||||
entry->entry_data.offset = (uint32_t)initial_size;
|
entry->entry_data.offset = (uint32_t)initial_size;
|
||||||
|
|
||||||
cmp_ok(pool->size, "==", initial_size * 2,
|
cmp_ok(
|
||||||
"size is the initial size*2");
|
pool->size, "==", initial_size * 2, "size is the initial size*2");
|
||||||
cmp_ok(pool->used, "==", 1, "used size is as expected");
|
cmp_ok(pool->used, "==", 1, "used size is as expected");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *const list = data_pool_to_list(pool);
|
MMDB_entry_data_list_s *const list = data_pool_to_list(pool);
|
||||||
|
|
||||||
MMDB_entry_data_list_s *element = list;
|
MMDB_entry_data_list_s *element = list;
|
||||||
for (size_t i = 0; i < initial_size + 1; i++) {
|
for (size_t i = 0; i < initial_size + 1; i++) {
|
||||||
ok(
|
ok(element->entry_data.offset == (uint32_t)i,
|
||||||
element->entry_data.offset == (uint32_t)i,
|
"found offset %" PRIu32 ", should have %zu",
|
||||||
"found offset %" PRIu32 ", should have %zu",
|
element->entry_data.offset,
|
||||||
element->entry_data.offset,
|
i);
|
||||||
i
|
|
||||||
);
|
|
||||||
element = element->next;
|
element = element->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,8 +124,7 @@ static void test_data_pool_alloc(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_data_pool_to_list(void)
|
static void test_data_pool_to_list(void) {
|
||||||
{
|
|
||||||
{
|
{
|
||||||
size_t const initial_size = 16;
|
size_t const initial_size = 16;
|
||||||
MMDB_data_pool_s *const pool = data_pool_new(initial_size);
|
MMDB_data_pool_s *const pool = data_pool_new(initial_size);
|
||||||
@ -143,8 +133,8 @@ static void test_data_pool_to_list(void)
|
|||||||
MMDB_entry_data_list_s *const entry1 = data_pool_alloc(pool);
|
MMDB_entry_data_list_s *const entry1 = data_pool_alloc(pool);
|
||||||
ok(entry1 != NULL, "got an entry");
|
ok(entry1 != NULL, "got an entry");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *const list_one_element
|
MMDB_entry_data_list_s *const list_one_element =
|
||||||
= data_pool_to_list(pool);
|
data_pool_to_list(pool);
|
||||||
ok(list_one_element != NULL, "got a list");
|
ok(list_one_element != NULL, "got a list");
|
||||||
ok(list_one_element == entry1,
|
ok(list_one_element == entry1,
|
||||||
"list's first element is the first we retrieved");
|
"list's first element is the first we retrieved");
|
||||||
@ -153,8 +143,8 @@ static void test_data_pool_to_list(void)
|
|||||||
MMDB_entry_data_list_s *const entry2 = data_pool_alloc(pool);
|
MMDB_entry_data_list_s *const entry2 = data_pool_alloc(pool);
|
||||||
ok(entry2 != NULL, "got another entry");
|
ok(entry2 != NULL, "got another entry");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *const list_two_elements
|
MMDB_entry_data_list_s *const list_two_elements =
|
||||||
= data_pool_to_list(pool);
|
data_pool_to_list(pool);
|
||||||
ok(list_two_elements != NULL, "got a list");
|
ok(list_two_elements != NULL, "got a list");
|
||||||
ok(list_two_elements == entry1,
|
ok(list_two_elements == entry1,
|
||||||
"list's first element is the first we retrieved");
|
"list's first element is the first we retrieved");
|
||||||
@ -176,8 +166,8 @@ static void test_data_pool_to_list(void)
|
|||||||
MMDB_entry_data_list_s *const entry1 = data_pool_alloc(pool);
|
MMDB_entry_data_list_s *const entry1 = data_pool_alloc(pool);
|
||||||
ok(entry1 != NULL, "got an entry");
|
ok(entry1 != NULL, "got an entry");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *const list_one_element
|
MMDB_entry_data_list_s *const list_one_element =
|
||||||
= data_pool_to_list(pool);
|
data_pool_to_list(pool);
|
||||||
ok(list_one_element != NULL, "got a list");
|
ok(list_one_element != NULL, "got a list");
|
||||||
ok(list_one_element == entry1,
|
ok(list_one_element == entry1,
|
||||||
"list's first element is the first we retrieved");
|
"list's first element is the first we retrieved");
|
||||||
@ -213,72 +203,54 @@ static void test_data_pool_to_list(void)
|
|||||||
|
|
||||||
{
|
{
|
||||||
diag("starting test: fill one block save for one spot");
|
diag("starting test: fill one block save for one spot");
|
||||||
ok(
|
ok(create_and_check_list(3, 2), "fill one block save for one spot");
|
||||||
create_and_check_list(3, 2),
|
|
||||||
"fill one block save for one spot"
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
diag("starting test: fill one block");
|
diag("starting test: fill one block");
|
||||||
ok(
|
ok(create_and_check_list(3, 3), "fill one block");
|
||||||
create_and_check_list(3, 3),
|
|
||||||
"fill one block"
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
diag("starting test: fill one block and use one spot in the next block");
|
diag(
|
||||||
ok(
|
"starting test: fill one block and use one spot in the next block");
|
||||||
create_and_check_list(3, 3 + 1),
|
ok(create_and_check_list(3, 3 + 1),
|
||||||
"fill one block and use one spot in the next block"
|
"fill one block and use one spot in the next block");
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
diag("starting test: fill two blocks save for one spot");
|
diag("starting test: fill two blocks save for one spot");
|
||||||
ok(
|
ok(create_and_check_list(3, 3 + 3 * 2 - 1),
|
||||||
create_and_check_list(3, 3 + 3 * 2 - 1),
|
"fill two blocks save for one spot");
|
||||||
"fill two blocks save for one spot"
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
diag("starting test: fill two blocks");
|
diag("starting test: fill two blocks");
|
||||||
ok(
|
ok(create_and_check_list(3, 3 + 3 * 2), "fill two blocks");
|
||||||
create_and_check_list(3, 3 + 3 * 2),
|
|
||||||
"fill two blocks"
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
diag("starting test: fill two blocks and use one spot in the next");
|
diag("starting test: fill two blocks and use one spot in the next");
|
||||||
ok(
|
ok(create_and_check_list(3, 3 + 3 * 2 + 1),
|
||||||
create_and_check_list(3, 3 + 3 * 2 + 1),
|
"fill two blocks and use one spot in the next");
|
||||||
"fill two blocks and use one spot in the next"
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
diag("starting test: fill three blocks save for one spot");
|
diag("starting test: fill three blocks save for one spot");
|
||||||
ok(
|
ok(create_and_check_list(3, 3 + 3 * 2 + 3 * 2 * 2 - 1),
|
||||||
create_and_check_list(3, 3 + 3 * 2 + 3 * 2 * 2 - 1),
|
"fill three blocks save for one spot");
|
||||||
"fill three blocks save for one spot"
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
diag("starting test: fill three blocks");
|
diag("starting test: fill three blocks");
|
||||||
ok(
|
ok(create_and_check_list(3, 3 + 3 * 2 + 3 * 2 * 2),
|
||||||
create_and_check_list(3, 3 + 3 * 2 + 3 * 2 * 2),
|
"fill three blocks");
|
||||||
"fill three blocks"
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// It would be nice to have a larger number of these, but it's expensive to
|
// It would be nice to have a larger number of these, but it's expensive to
|
||||||
// run many. We currently hardcode what this will be anyway, so varying
|
// run many. We currently hardcode what this will be anyway, so varying
|
||||||
// this is not very interesting.
|
// this is not very interesting.
|
||||||
size_t const initial_sizes[] = { 1, 2, 32, 64, 128, 256 };
|
size_t const initial_sizes[] = {1, 2, 32, 64, 128, 256};
|
||||||
|
|
||||||
size_t const max_element_count = 4096;
|
size_t const max_element_count = 4096;
|
||||||
|
|
||||||
@ -296,8 +268,7 @@ static void test_data_pool_to_list(void)
|
|||||||
// Use assert() rather than libtap as libtap is significantly slower and we run
|
// Use assert() rather than libtap as libtap is significantly slower and we run
|
||||||
// this frequently.
|
// this frequently.
|
||||||
static bool create_and_check_list(size_t const initial_size,
|
static bool create_and_check_list(size_t const initial_size,
|
||||||
size_t const element_count)
|
size_t const element_count) {
|
||||||
{
|
|
||||||
MMDB_data_pool_s *const pool = data_pool_new(initial_size);
|
MMDB_data_pool_s *const pool = data_pool_new(initial_size);
|
||||||
assert(pool != NULL);
|
assert(pool != NULL);
|
||||||
|
|
||||||
@ -305,8 +276,8 @@ static bool create_and_check_list(size_t const initial_size,
|
|||||||
|
|
||||||
// Hold on to the pointers as we initially see them so that we can check
|
// Hold on to the pointers as we initially see them so that we can check
|
||||||
// they are still valid after building the list.
|
// they are still valid after building the list.
|
||||||
MMDB_entry_data_list_s **const entry_array
|
MMDB_entry_data_list_s **const entry_array =
|
||||||
= calloc(element_count, sizeof(MMDB_entry_data_list_s *));
|
calloc(element_count, sizeof(MMDB_entry_data_list_s *));
|
||||||
assert(entry_array != NULL);
|
assert(entry_array != NULL);
|
||||||
|
|
||||||
for (size_t i = 0; i < element_count; i++) {
|
for (size_t i = 0; i < element_count; i++) {
|
||||||
@ -349,8 +320,7 @@ static bool create_and_check_list(size_t const initial_size,
|
|||||||
// Use assert() rather than libtap as libtap is significantly slower and we run
|
// Use assert() rather than libtap as libtap is significantly slower and we run
|
||||||
// this frequently.
|
// this frequently.
|
||||||
static void check_block_count(MMDB_entry_data_list_s const *const list,
|
static void check_block_count(MMDB_entry_data_list_s const *const list,
|
||||||
size_t const initial_size)
|
size_t const initial_size) {
|
||||||
{
|
|
||||||
size_t got_block_count = 0;
|
size_t got_block_count = 0;
|
||||||
size_t got_element_count = 0;
|
size_t got_element_count = 0;
|
||||||
|
|
||||||
|
253
vendor/MaxmindDB/t/data_entry_list_t.c
vendored
253
vendor/MaxmindDB/t/data_entry_list_t.c
vendored
@ -1,57 +1,68 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_array_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_array_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *array = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *array = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(array->entry_data.type, "==", MMDB_DATA_TYPE_ARRAY,
|
cmp_ok(array->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_ARRAY,
|
||||||
"'array' key's value is an array");
|
"'array' key's value is an array");
|
||||||
cmp_ok(array->entry_data.data_size, "==", 3,
|
cmp_ok(array->entry_data.data_size,
|
||||||
|
"==",
|
||||||
|
3,
|
||||||
"'array' key's value has 3 elements");
|
"'array' key's value has 3 elements");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *idx0 = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *idx0 = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(idx0->entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(idx0->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"first array entry is a UINT32");
|
"first array entry is a UINT32");
|
||||||
cmp_ok(idx0->entry_data.uint32, "==", 1, "first array entry value is 1");
|
cmp_ok(idx0->entry_data.uint32, "==", 1, "first array entry value is 1");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *idx1 = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *idx1 = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(idx1->entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(idx1->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"second array entry is a UINT32");
|
"second array entry is a UINT32");
|
||||||
cmp_ok(idx1->entry_data.uint32, "==", 2, "second array entry value is 2");
|
cmp_ok(idx1->entry_data.uint32, "==", 2, "second array entry value is 2");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *idx2 = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *idx2 = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(idx2->entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(idx2->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"third array entry is a UINT32");
|
"third array entry is a UINT32");
|
||||||
cmp_ok(idx2->entry_data.uint32, "==", 3, "third array entry value is 3");
|
cmp_ok(idx2->entry_data.uint32, "==", 3, "third array entry value is 3");
|
||||||
|
|
||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_boolean_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_boolean_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_BOOLEAN,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_BOOLEAN,
|
||||||
"'boolean' key's value is a boolean");
|
"'boolean' key's value is a boolean");
|
||||||
ok(value->entry_data.boolean, "'boolean' key's value is true");
|
ok(value->entry_data.boolean, "'boolean' key's value is true");
|
||||||
|
|
||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_bytes_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_bytes_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_BYTES,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_BYTES,
|
||||||
"'bytes' key's value is bytes");
|
"'bytes' key's value is bytes");
|
||||||
uint8_t *bytes = malloc(value->entry_data.data_size);
|
uint8_t *bytes = malloc(value->entry_data.data_size);
|
||||||
if (NULL == bytes) {
|
if (NULL == bytes) {
|
||||||
BAIL_OUT("malloc failed");
|
BAIL_OUT("malloc failed");
|
||||||
}
|
}
|
||||||
memcpy(bytes, value->entry_data.bytes, value->entry_data.data_size);
|
memcpy(bytes, value->entry_data.bytes, value->entry_data.data_size);
|
||||||
uint8_t expect[] = { 0x00, 0x00, 0x00, 0x2a };
|
uint8_t expect[] = {0x00, 0x00, 0x00, 0x2a};
|
||||||
|
|
||||||
ok(memcmp(bytes, expect, 4) == 0, "got expected value for bytes key");
|
ok(memcmp(bytes, expect, 4) == 0, "got expected value for bytes key");
|
||||||
|
|
||||||
@ -60,12 +71,13 @@ MMDB_entry_data_list_s *test_bytes_value(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_double_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_double_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_DOUBLE,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_DOUBLE,
|
||||||
"'double' key's value is a double");
|
"'double' key's value is a double");
|
||||||
|
|
||||||
compare_double(value->entry_data.double_value, 42.123456);
|
compare_double(value->entry_data.double_value, 42.123456);
|
||||||
@ -73,12 +85,13 @@ MMDB_entry_data_list_s *test_double_value(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_float_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_float_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_FLOAT,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_FLOAT,
|
||||||
"'float' key's value is a float");
|
"'float' key's value is a float");
|
||||||
|
|
||||||
compare_float(value->entry_data.float_value, 1.1F);
|
compare_float(value->entry_data.float_value, 1.1F);
|
||||||
@ -86,64 +99,79 @@ MMDB_entry_data_list_s *test_float_value(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_int32_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_int32_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_INT32,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_INT32,
|
||||||
"'int32' key's value is an int32");
|
"'int32' key's value is an int32");
|
||||||
|
|
||||||
int32_t expect = 1 << 28;
|
int32_t expect = 1 << 28;
|
||||||
expect *= -1;
|
expect *= -1;
|
||||||
cmp_ok(value->entry_data.int32, "==", expect,
|
cmp_ok(value->entry_data.int32,
|
||||||
|
"==",
|
||||||
|
expect,
|
||||||
"got expected value for int32 key");
|
"got expected value for int32 key");
|
||||||
|
|
||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_arrayX_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_arrayX_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *arrayX = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *arrayX = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(arrayX->entry_data.type, "==", MMDB_DATA_TYPE_ARRAY,
|
cmp_ok(arrayX->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_ARRAY,
|
||||||
"'map{mapX}{arrayX}' key's value is an array");
|
"'map{mapX}{arrayX}' key's value is an array");
|
||||||
cmp_ok(arrayX->entry_data.data_size, "==", 3,
|
cmp_ok(arrayX->entry_data.data_size,
|
||||||
|
"==",
|
||||||
|
3,
|
||||||
"'map{mapX}{arrayX}' key's value has 3 elements");
|
"'map{mapX}{arrayX}' key's value has 3 elements");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *idx0 = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *idx0 = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(idx0->entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(idx0->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"first array entry is a UINT32");
|
"first array entry is a UINT32");
|
||||||
cmp_ok(idx0->entry_data.uint32, "==", 7, "first array entry value is 7");
|
cmp_ok(idx0->entry_data.uint32, "==", 7, "first array entry value is 7");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *idx1 = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *idx1 = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(idx1->entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(idx1->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"second array entry is a UINT32");
|
"second array entry is a UINT32");
|
||||||
cmp_ok(idx1->entry_data.uint32, "==", 8, "second array entry value is 8");
|
cmp_ok(idx1->entry_data.uint32, "==", 8, "second array entry value is 8");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *idx2 = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *idx2 = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(idx2->entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(idx2->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"third array entry is a UINT32");
|
"third array entry is a UINT32");
|
||||||
cmp_ok(idx2->entry_data.uint32, "==", 9, "third array entry value is 9");
|
cmp_ok(idx2->entry_data.uint32, "==", 9, "third array entry value is 9");
|
||||||
|
|
||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_mapX_key_value_pair(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_mapX_key_value_pair(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *mapX_key = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *mapX_key = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(mapX_key->entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
cmp_ok(mapX_key->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"found a map key in 'map{mapX}'");
|
"found a map key in 'map{mapX}'");
|
||||||
const char *mapX_key_name = dup_entry_string_or_bail(mapX_key->entry_data);
|
const char *mapX_key_name = dup_entry_string_or_bail(mapX_key->entry_data);
|
||||||
|
|
||||||
if (strcmp(mapX_key_name, "utf8_stringX") == 0) {
|
if (strcmp(mapX_key_name, "utf8_stringX") == 0) {
|
||||||
MMDB_entry_data_list_s *mapX_value =
|
MMDB_entry_data_list_s *mapX_value = entry_data_list =
|
||||||
entry_data_list = entry_data_list->next;
|
entry_data_list->next;
|
||||||
cmp_ok(mapX_value->entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
cmp_ok(mapX_value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"'map{mapX}{utf8_stringX}' type is utf8_string");
|
"'map{mapX}{utf8_stringX}' type is utf8_string");
|
||||||
const char *utf8_stringX_value = dup_entry_string_or_bail(
|
const char *utf8_stringX_value =
|
||||||
mapX_value->entry_data);
|
dup_entry_string_or_bail(mapX_value->entry_data);
|
||||||
ok(strcmp(utf8_stringX_value, "hello") == 0,
|
ok(strcmp(utf8_stringX_value, "hello") == 0,
|
||||||
"map{mapX}{utf8_stringX} value is 'hello'");
|
"map{mapX}{utf8_stringX} value is 'hello'");
|
||||||
free((void *)utf8_stringX_value);
|
free((void *)utf8_stringX_value);
|
||||||
@ -158,16 +186,22 @@ MMDB_entry_data_list_s *test_mapX_key_value_pair(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_map_value(MMDB_entry_data_list_s *entry_data_list)
|
MMDB_entry_data_list_s *
|
||||||
{
|
test_map_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
MMDB_entry_data_list_s *map = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *map = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(map->entry_data.type, "==", MMDB_DATA_TYPE_MAP,
|
cmp_ok(map->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_MAP,
|
||||||
"'map' key's value is a map");
|
"'map' key's value is a map");
|
||||||
cmp_ok(map->entry_data.data_size, "==", 1,
|
cmp_ok(map->entry_data.data_size,
|
||||||
|
"==",
|
||||||
|
1,
|
||||||
"'map' key's value has 1 key/value pair");
|
"'map' key's value has 1 key/value pair");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *map_key_1 = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *map_key_1 = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(map_key_1->entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
cmp_ok(map_key_1->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"found a map key in 'map'");
|
"found a map key in 'map'");
|
||||||
const char *map_key_1_name =
|
const char *map_key_1_name =
|
||||||
dup_entry_string_or_bail(map_key_1->entry_data);
|
dup_entry_string_or_bail(map_key_1->entry_data);
|
||||||
@ -175,9 +209,13 @@ MMDB_entry_data_list_s *test_map_value(MMDB_entry_data_list_s *entry_data_list)
|
|||||||
free((void *)map_key_1_name);
|
free((void *)map_key_1_name);
|
||||||
|
|
||||||
MMDB_entry_data_list_s *mapX = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *mapX = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(mapX->entry_data.type, "==", MMDB_DATA_TYPE_MAP,
|
cmp_ok(mapX->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_MAP,
|
||||||
"'map{mapX}' key's value is a map");
|
"'map{mapX}' key's value is a map");
|
||||||
cmp_ok(mapX->entry_data.data_size, "==", 2,
|
cmp_ok(mapX->entry_data.data_size,
|
||||||
|
"==",
|
||||||
|
2,
|
||||||
"'map' key's value has 2 key/value pairs");
|
"'map' key's value has 2 key/value pairs");
|
||||||
|
|
||||||
entry_data_list = test_mapX_key_value_pair(entry_data_list);
|
entry_data_list = test_mapX_key_value_pair(entry_data_list);
|
||||||
@ -186,17 +224,32 @@ MMDB_entry_data_list_s *test_map_value(MMDB_entry_data_list_s *entry_data_list)
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_uint128_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_uint128_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_UINT128,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT128,
|
||||||
"'uint128' key's value is an uint128");
|
"'uint128' key's value is an uint128");
|
||||||
|
|
||||||
#if MMDB_UINT128_IS_BYTE_ARRAY
|
#if MMDB_UINT128_IS_BYTE_ARRAY
|
||||||
uint8_t expect[16] = { 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
uint8_t expect[16] = {0x01,
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00};
|
||||||
ok(memcmp(value->entry_data.uint128, expect, 16) == 0,
|
ok(memcmp(value->entry_data.uint128, expect, 16) == 0,
|
||||||
"uint128 field is 2**120");
|
"uint128 field is 2**120");
|
||||||
#else
|
#else
|
||||||
@ -208,12 +261,13 @@ MMDB_entry_data_list_s *test_uint128_value(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_uint16_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_uint16_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_UINT16,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT16,
|
||||||
"'uint16' key's value is an uint16");
|
"'uint16' key's value is an uint16");
|
||||||
uint16_t expect = 100;
|
uint16_t expect = 100;
|
||||||
ok(value->entry_data.uint16 == expect, "uint16 field is 100");
|
ok(value->entry_data.uint16 == expect, "uint16 field is 100");
|
||||||
@ -221,12 +275,13 @@ MMDB_entry_data_list_s *test_uint16_value(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_uint32_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_uint32_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"'uint32' key's value is an uint32");
|
"'uint32' key's value is an uint32");
|
||||||
uint32_t expect = 1 << 28;
|
uint32_t expect = 1 << 28;
|
||||||
cmp_ok(value->entry_data.uint32, "==", expect, "uint32 field is 100");
|
cmp_ok(value->entry_data.uint32, "==", expect, "uint32 field is 100");
|
||||||
@ -234,12 +289,13 @@ MMDB_entry_data_list_s *test_uint32_value(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_uint64_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_uint64_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_UINT64,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT64,
|
||||||
"'uint64' key's value is an uint64");
|
"'uint64' key's value is an uint64");
|
||||||
uint64_t expect = 1;
|
uint64_t expect = 1;
|
||||||
expect <<= 60;
|
expect <<= 60;
|
||||||
@ -248,18 +304,35 @@ MMDB_entry_data_list_s *test_uint64_value(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_utf8_string_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_utf8_string_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
cmp_ok(value->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"'utf8_string' key's value is a string");
|
"'utf8_string' key's value is a string");
|
||||||
const char *utf8_string = dup_entry_string_or_bail(value->entry_data);
|
const char *utf8_string = dup_entry_string_or_bail(value->entry_data);
|
||||||
// This is hex for "unicode! ☯ - ♫" as bytes
|
// This is hex for "unicode! ☯ - ♫" as bytes
|
||||||
char expect[19] =
|
char expect[19] = {0x75,
|
||||||
{ 0x75, 0x6e, 0x69, 0x63, 0x6f, 0x64, 0x65, 0x21, 0x20, 0xe2, 0x98,
|
0x6e,
|
||||||
0xaf, 0x20, 0x2d, 0x20, 0xe2, 0x99, 0xab, 0x00 };
|
0x69,
|
||||||
|
0x63,
|
||||||
|
0x6f,
|
||||||
|
0x64,
|
||||||
|
0x65,
|
||||||
|
0x21,
|
||||||
|
0x20,
|
||||||
|
0xe2,
|
||||||
|
0x98,
|
||||||
|
0xaf,
|
||||||
|
0x20,
|
||||||
|
0x2d,
|
||||||
|
0x20,
|
||||||
|
0xe2,
|
||||||
|
0x99,
|
||||||
|
0xab,
|
||||||
|
0x00};
|
||||||
|
|
||||||
is(utf8_string, expect, "got expected value for utf8_string key");
|
is(utf8_string, expect, "got expected value for utf8_string key");
|
||||||
|
|
||||||
@ -268,8 +341,7 @@ MMDB_entry_data_list_s *test_utf8_string_value(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_tests(int mode, const char *description)
|
void run_tests(int mode, const char *description) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-decoder.mmdb";
|
const char *filename = "MaxMind-DB-test-decoder.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, description);
|
MMDB_s *mmdb = open_ok(path, mode, description);
|
||||||
@ -286,15 +358,19 @@ void run_tests(int mode, const char *description)
|
|||||||
BAIL_OUT("MMDB_get_entry_data_list failed with %s",
|
BAIL_OUT("MMDB_get_entry_data_list failed with %s",
|
||||||
MMDB_strerror(status));
|
MMDB_strerror(status));
|
||||||
} else {
|
} else {
|
||||||
cmp_ok(status, "==", MMDB_SUCCESS,
|
cmp_ok(
|
||||||
"MMDB_get_entry_data_list succeeded");
|
status, "==", MMDB_SUCCESS, "MMDB_get_entry_data_list succeeded");
|
||||||
}
|
}
|
||||||
|
|
||||||
first = entry_data_list;
|
first = entry_data_list;
|
||||||
|
|
||||||
cmp_ok(entry_data_list->entry_data.type, "==", MMDB_DATA_TYPE_MAP,
|
cmp_ok(entry_data_list->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_MAP,
|
||||||
"first entry in entry data list is a map");
|
"first entry in entry data list is a map");
|
||||||
cmp_ok(entry_data_list->entry_data.data_size, "==", 12,
|
cmp_ok(entry_data_list->entry_data.data_size,
|
||||||
|
"==",
|
||||||
|
12,
|
||||||
"first map in entry data list has 12 k/v pairs");
|
"first map in entry data list has 12 k/v pairs");
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
@ -304,7 +380,9 @@ void run_tests(int mode, const char *description)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
cmp_ok(key->entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
cmp_ok(key->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"found a map key");
|
"found a map key");
|
||||||
|
|
||||||
const char *key_name = dup_entry_string_or_bail(key->entry_data);
|
const char *key_name = dup_entry_string_or_bail(key->entry_data);
|
||||||
@ -345,8 +423,7 @@ void run_tests(int mode, const char *description)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
300
vendor/MaxmindDB/t/data_types_t.c
vendored
300
vendor/MaxmindDB/t/data_types_t.c
vendored
@ -1,21 +1,40 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
void test_all_data_types(MMDB_lookup_result_s *result, const char *ip,
|
void test_all_data_types(MMDB_lookup_result_s *result,
|
||||||
const char *UNUSED(filename), const char *mode_desc)
|
const char *ip,
|
||||||
{
|
const char *UNUSED(filename),
|
||||||
|
const char *mode_desc) {
|
||||||
{
|
{
|
||||||
char description[500];
|
char description[500];
|
||||||
snprintf(description, 500, "utf8_string field for %s - %s", ip,
|
snprintf(
|
||||||
mode_desc);
|
description, 500, "utf8_string field for %s - %s", ip, mode_desc);
|
||||||
|
|
||||||
MMDB_entry_data_s data =
|
MMDB_entry_data_s data = data_ok(result,
|
||||||
data_ok(result, MMDB_DATA_TYPE_UTF8_STRING, description,
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"utf8_string", NULL);
|
description,
|
||||||
|
"utf8_string",
|
||||||
|
NULL);
|
||||||
const char *string = mmdb_strndup(data.utf8_string, data.data_size);
|
const char *string = mmdb_strndup(data.utf8_string, data.data_size);
|
||||||
// This is hex for "unicode! ☯ - ♫" as bytes
|
// This is hex for "unicode! ☯ - ♫" as bytes
|
||||||
char expect[19] =
|
char expect[19] = {0x75,
|
||||||
{ 0x75, 0x6e, 0x69, 0x63, 0x6f, 0x64, 0x65, 0x21, 0x20, 0xe2, 0x98,
|
0x6e,
|
||||||
0xaf, 0x20, 0x2d, 0x20, 0xe2, 0x99, 0xab, 0x00 };
|
0x69,
|
||||||
|
0x63,
|
||||||
|
0x6f,
|
||||||
|
0x64,
|
||||||
|
0x65,
|
||||||
|
0x21,
|
||||||
|
0x20,
|
||||||
|
0xe2,
|
||||||
|
0x98,
|
||||||
|
0xaf,
|
||||||
|
0x20,
|
||||||
|
0x2d,
|
||||||
|
0x20,
|
||||||
|
0xe2,
|
||||||
|
0x99,
|
||||||
|
0xab,
|
||||||
|
0x00};
|
||||||
is(string, expect, "got expected utf8_string value");
|
is(string, expect, "got expected utf8_string value");
|
||||||
|
|
||||||
free((char *)string);
|
free((char *)string);
|
||||||
@ -47,7 +66,7 @@ void test_all_data_types(MMDB_lookup_result_s *result, const char *ip,
|
|||||||
|
|
||||||
MMDB_entry_data_s data =
|
MMDB_entry_data_s data =
|
||||||
data_ok(result, MMDB_DATA_TYPE_BYTES, description, "bytes", NULL);
|
data_ok(result, MMDB_DATA_TYPE_BYTES, description, "bytes", NULL);
|
||||||
uint8_t expect[] = { 0x00, 0x00, 0x00, 0x2a };
|
uint8_t expect[] = {0x00, 0x00, 0x00, 0x2a};
|
||||||
ok(memcmp((uint8_t *)data.bytes, expect, 4) == 0,
|
ok(memcmp((uint8_t *)data.bytes, expect, 4) == 0,
|
||||||
"bytes field has expected value");
|
"bytes field has expected value");
|
||||||
}
|
}
|
||||||
@ -98,12 +117,25 @@ void test_all_data_types(MMDB_lookup_result_s *result, const char *ip,
|
|||||||
char description[500];
|
char description[500];
|
||||||
snprintf(description, 500, "uint128 field for %s - %s", ip, mode_desc);
|
snprintf(description, 500, "uint128 field for %s - %s", ip, mode_desc);
|
||||||
|
|
||||||
MMDB_entry_data_s data =
|
MMDB_entry_data_s data = data_ok(
|
||||||
data_ok(result, MMDB_DATA_TYPE_UINT128, description, "uint128",
|
result, MMDB_DATA_TYPE_UINT128, description, "uint128", NULL);
|
||||||
NULL);
|
|
||||||
#if MMDB_UINT128_IS_BYTE_ARRAY
|
#if MMDB_UINT128_IS_BYTE_ARRAY
|
||||||
uint8_t expect[16] = { 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
uint8_t expect[16] = {0x01,
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00};
|
||||||
ok(memcmp(data.uint128, expect, 16) == 0, "uint128 field is 2**120");
|
ok(memcmp(data.uint128, expect, 16) == 0, "uint128 field is 2**120");
|
||||||
#else
|
#else
|
||||||
mmdb_uint128_t expect = 1;
|
mmdb_uint128_t expect = 1;
|
||||||
@ -116,9 +148,8 @@ void test_all_data_types(MMDB_lookup_result_s *result, const char *ip,
|
|||||||
char description[500];
|
char description[500];
|
||||||
snprintf(description, 500, "boolean field for %s - %s", ip, mode_desc);
|
snprintf(description, 500, "boolean field for %s - %s", ip, mode_desc);
|
||||||
|
|
||||||
MMDB_entry_data_s data =
|
MMDB_entry_data_s data = data_ok(
|
||||||
data_ok(result, MMDB_DATA_TYPE_BOOLEAN, description, "boolean",
|
result, MMDB_DATA_TYPE_BOOLEAN, description, "boolean", NULL);
|
||||||
NULL);
|
|
||||||
cmp_ok(data.boolean, "==", true, "boolean field is true");
|
cmp_ok(data.boolean, "==", true, "boolean field is true");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -131,21 +162,18 @@ void test_all_data_types(MMDB_lookup_result_s *result, const char *ip,
|
|||||||
ok(data.data_size == 3, "array field has 3 elements");
|
ok(data.data_size == 3, "array field has 3 elements");
|
||||||
|
|
||||||
snprintf(description, 500, "array[0] for %s - %s", ip, mode_desc);
|
snprintf(description, 500, "array[0] for %s - %s", ip, mode_desc);
|
||||||
data =
|
data = data_ok(
|
||||||
data_ok(result, MMDB_DATA_TYPE_UINT32, description, "array", "0",
|
result, MMDB_DATA_TYPE_UINT32, description, "array", "0", NULL);
|
||||||
NULL);
|
|
||||||
ok(data.uint32 == 1, "array[0] is 1");
|
ok(data.uint32 == 1, "array[0] is 1");
|
||||||
|
|
||||||
snprintf(description, 500, "array[1] for %s - %s", ip, mode_desc);
|
snprintf(description, 500, "array[1] for %s - %s", ip, mode_desc);
|
||||||
data =
|
data = data_ok(
|
||||||
data_ok(result, MMDB_DATA_TYPE_UINT32, description, "array", "1",
|
result, MMDB_DATA_TYPE_UINT32, description, "array", "1", NULL);
|
||||||
NULL);
|
|
||||||
ok(data.uint32 == 2, "array[1] is 1");
|
ok(data.uint32 == 2, "array[1] is 1");
|
||||||
|
|
||||||
snprintf(description, 500, "array[2] for %s - %s", ip, mode_desc);
|
snprintf(description, 500, "array[2] for %s - %s", ip, mode_desc);
|
||||||
data =
|
data = data_ok(
|
||||||
data_ok(result, MMDB_DATA_TYPE_UINT32, description, "array", "2",
|
result, MMDB_DATA_TYPE_UINT32, description, "array", "2", NULL);
|
||||||
NULL);
|
|
||||||
ok(data.uint32 == 3, "array[2] is 1");
|
ok(data.uint32 == 3, "array[2] is 1");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -159,64 +187,99 @@ void test_all_data_types(MMDB_lookup_result_s *result, const char *ip,
|
|||||||
|
|
||||||
snprintf(description, 500, "map{mapX} for %s - %s", ip, mode_desc);
|
snprintf(description, 500, "map{mapX} for %s - %s", ip, mode_desc);
|
||||||
|
|
||||||
data =
|
data = data_ok(
|
||||||
data_ok(result, MMDB_DATA_TYPE_MAP, description, "map", "mapX",
|
result, MMDB_DATA_TYPE_MAP, description, "map", "mapX", NULL);
|
||||||
NULL);
|
|
||||||
ok(data.data_size == 2, "map{mapX} field has 2 elements");
|
ok(data.data_size == 2, "map{mapX} field has 2 elements");
|
||||||
|
|
||||||
snprintf(description, 500, "map{mapX}{utf8_stringX} for %s - %s", ip,
|
snprintf(description,
|
||||||
|
500,
|
||||||
|
"map{mapX}{utf8_stringX} for %s - %s",
|
||||||
|
ip,
|
||||||
mode_desc);
|
mode_desc);
|
||||||
|
|
||||||
data =
|
data = data_ok(result,
|
||||||
data_ok(result, MMDB_DATA_TYPE_UTF8_STRING, description, "map",
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"mapX", "utf8_stringX", NULL);
|
description,
|
||||||
|
"map",
|
||||||
|
"mapX",
|
||||||
|
"utf8_stringX",
|
||||||
|
NULL);
|
||||||
const char *string = mmdb_strndup(data.utf8_string, data.data_size);
|
const char *string = mmdb_strndup(data.utf8_string, data.data_size);
|
||||||
is(string, "hello", "map{mapX}{utf8_stringX} is 'hello'");
|
is(string, "hello", "map{mapX}{utf8_stringX} is 'hello'");
|
||||||
free((char *)string);
|
free((char *)string);
|
||||||
|
|
||||||
snprintf(description, 500, "map{mapX}{arrayX} for %s - %s", ip,
|
snprintf(
|
||||||
mode_desc);
|
description, 500, "map{mapX}{arrayX} for %s - %s", ip, mode_desc);
|
||||||
data =
|
data = data_ok(result,
|
||||||
data_ok(result, MMDB_DATA_TYPE_ARRAY, description, "map", "mapX",
|
MMDB_DATA_TYPE_ARRAY,
|
||||||
"arrayX", NULL);
|
description,
|
||||||
|
"map",
|
||||||
|
"mapX",
|
||||||
|
"arrayX",
|
||||||
|
NULL);
|
||||||
ok(data.data_size == 3, "map{mapX}{arrayX} field has 3 elements");
|
ok(data.data_size == 3, "map{mapX}{arrayX} field has 3 elements");
|
||||||
|
|
||||||
snprintf(description, 500, "map{mapX}{arrayX}[0] for %s - %s", ip,
|
snprintf(description,
|
||||||
|
500,
|
||||||
|
"map{mapX}{arrayX}[0] for %s - %s",
|
||||||
|
ip,
|
||||||
mode_desc);
|
mode_desc);
|
||||||
data =
|
data = data_ok(result,
|
||||||
data_ok(result, MMDB_DATA_TYPE_UINT32, description, "map", "mapX",
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"arrayX", "0", NULL);
|
description,
|
||||||
|
"map",
|
||||||
|
"mapX",
|
||||||
|
"arrayX",
|
||||||
|
"0",
|
||||||
|
NULL);
|
||||||
ok(data.uint32 == 7, "map{mapX}{arrayX}[0] is 7");
|
ok(data.uint32 == 7, "map{mapX}{arrayX}[0] is 7");
|
||||||
|
|
||||||
snprintf(description, 500, "map{mapX}{arrayX}[1] for %s - %s", ip,
|
snprintf(description,
|
||||||
|
500,
|
||||||
|
"map{mapX}{arrayX}[1] for %s - %s",
|
||||||
|
ip,
|
||||||
mode_desc);
|
mode_desc);
|
||||||
data =
|
data = data_ok(result,
|
||||||
data_ok(result, MMDB_DATA_TYPE_UINT32, description, "map", "mapX",
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"arrayX", "1", NULL);
|
description,
|
||||||
|
"map",
|
||||||
|
"mapX",
|
||||||
|
"arrayX",
|
||||||
|
"1",
|
||||||
|
NULL);
|
||||||
ok(data.uint32 == 8, "map{mapX}{arrayX}[1] is 8");
|
ok(data.uint32 == 8, "map{mapX}{arrayX}[1] is 8");
|
||||||
|
|
||||||
snprintf(description, 500, "map{mapX}{arrayX}[2] for %s - %s", ip,
|
snprintf(description,
|
||||||
|
500,
|
||||||
|
"map{mapX}{arrayX}[2] for %s - %s",
|
||||||
|
ip,
|
||||||
mode_desc);
|
mode_desc);
|
||||||
data =
|
data = data_ok(result,
|
||||||
data_ok(result, MMDB_DATA_TYPE_UINT32, description, "map", "mapX",
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"arrayX", "2", NULL);
|
description,
|
||||||
|
"map",
|
||||||
|
"mapX",
|
||||||
|
"arrayX",
|
||||||
|
"2",
|
||||||
|
NULL);
|
||||||
ok(data.uint32 == 9, "map{mapX}{arrayX}[2] is 9");
|
ok(data.uint32 == 9, "map{mapX}{arrayX}[2] is 9");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_all_data_types_as_zero(MMDB_lookup_result_s *result, const char *ip,
|
void test_all_data_types_as_zero(MMDB_lookup_result_s *result,
|
||||||
const char *UNUSED(
|
const char *ip,
|
||||||
filename), const char *mode_desc)
|
const char *UNUSED(filename),
|
||||||
{
|
const char *mode_desc) {
|
||||||
{
|
{
|
||||||
char description[500];
|
char description[500];
|
||||||
snprintf(description, 500, "utf8_string field for %s - %s", ip,
|
snprintf(
|
||||||
mode_desc);
|
description, 500, "utf8_string field for %s - %s", ip, mode_desc);
|
||||||
|
|
||||||
MMDB_entry_data_s data =
|
MMDB_entry_data_s data = data_ok(result,
|
||||||
data_ok(result, MMDB_DATA_TYPE_UTF8_STRING, description,
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"utf8_string", NULL);
|
description,
|
||||||
|
"utf8_string",
|
||||||
|
NULL);
|
||||||
is(data.utf8_string, "", "got expected utf8_string value (NULL)");
|
is(data.utf8_string, "", "got expected utf8_string value (NULL)");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -249,7 +312,8 @@ void test_all_data_types_as_zero(MMDB_lookup_result_s *result, const char *ip,
|
|||||||
ok(data.data_size == 0, "bytes field data_size is 0");
|
ok(data.data_size == 0, "bytes field data_size is 0");
|
||||||
/* In C does it makes sense to write something like this?
|
/* In C does it makes sense to write something like this?
|
||||||
uint8_t expect[0] = {};
|
uint8_t expect[0] = {};
|
||||||
ok(memcmp(data.bytes, expect, 0) == 0, "got expected bytes value (NULL)"); */
|
ok(memcmp(data.bytes, expect, 0) == 0, "got expected bytes value
|
||||||
|
(NULL)"); */
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -297,12 +361,25 @@ void test_all_data_types_as_zero(MMDB_lookup_result_s *result, const char *ip,
|
|||||||
char description[500];
|
char description[500];
|
||||||
snprintf(description, 500, "uint128 field for %s - %s", ip, mode_desc);
|
snprintf(description, 500, "uint128 field for %s - %s", ip, mode_desc);
|
||||||
|
|
||||||
MMDB_entry_data_s data =
|
MMDB_entry_data_s data = data_ok(
|
||||||
data_ok(result, MMDB_DATA_TYPE_UINT128, description, "uint128",
|
result, MMDB_DATA_TYPE_UINT128, description, "uint128", NULL);
|
||||||
NULL);
|
|
||||||
#if MMDB_UINT128_IS_BYTE_ARRAY
|
#if MMDB_UINT128_IS_BYTE_ARRAY
|
||||||
uint8_t expect[16] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
uint8_t expect[16] = {0x00,
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00,
|
||||||
|
0x00};
|
||||||
ok(memcmp(data.uint128, expect, 16) == 0, "uint128 field is 0");
|
ok(memcmp(data.uint128, expect, 16) == 0, "uint128 field is 0");
|
||||||
#else
|
#else
|
||||||
mmdb_uint128_t expect = 0;
|
mmdb_uint128_t expect = 0;
|
||||||
@ -314,9 +391,8 @@ void test_all_data_types_as_zero(MMDB_lookup_result_s *result, const char *ip,
|
|||||||
char description[500];
|
char description[500];
|
||||||
snprintf(description, 500, "boolean field for %s - %s", ip, mode_desc);
|
snprintf(description, 500, "boolean field for %s - %s", ip, mode_desc);
|
||||||
|
|
||||||
MMDB_entry_data_s data =
|
MMDB_entry_data_s data = data_ok(
|
||||||
data_ok(result, MMDB_DATA_TYPE_BOOLEAN, description, "boolean",
|
result, MMDB_DATA_TYPE_BOOLEAN, description, "boolean", NULL);
|
||||||
NULL);
|
|
||||||
cmp_ok(data.boolean, "==", false, "boolean field is false");
|
cmp_ok(data.boolean, "==", false, "boolean field is false");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -339,8 +415,7 @@ void test_all_data_types_as_zero(MMDB_lookup_result_s *result, const char *ip,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-decoder.mmdb";
|
const char *filename = "MaxMind-DB-test-decoder.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -360,11 +435,15 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
MMDB_lookup_string(mmdb, ip, &gai_error, &mmdb_error);
|
MMDB_lookup_string(mmdb, ip, &gai_error, &mmdb_error);
|
||||||
|
|
||||||
cmp_ok(gai_error, "==", EAI_NONAME,
|
cmp_ok(gai_error,
|
||||||
"MMDB_lookup populates getaddrinfo error properly - %s", ip);
|
"==",
|
||||||
|
EAI_NONAME,
|
||||||
|
"MMDB_lookup populates getaddrinfo error properly - %s",
|
||||||
|
ip);
|
||||||
|
|
||||||
ok(!result.found_entry,
|
ok(!result.found_entry,
|
||||||
"no result entry struct returned for invalid IP address '%s'", ip);
|
"no result entry struct returned for invalid IP address '%s'",
|
||||||
|
ip);
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -372,10 +451,12 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
||||||
|
|
||||||
ok(
|
ok(!result.found_entry,
|
||||||
!result.found_entry,
|
"no result entry struct returned for IP address not in the database "
|
||||||
"no result entry struct returned for IP address not in the database - %s - %s - %s",
|
"- %s - %s - %s",
|
||||||
ip, filename, mode_desc);
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -383,15 +464,21 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
||||||
|
|
||||||
ok(
|
ok(result.found_entry,
|
||||||
result.found_entry,
|
"got a result entry struct for IP address in the database - %s - %s "
|
||||||
"got a result entry struct for IP address in the database - %s - %s - %s",
|
"- %s",
|
||||||
ip, filename, mode_desc);
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
cmp_ok(
|
cmp_ok(result.entry.offset,
|
||||||
result.entry.offset, ">", 0,
|
">",
|
||||||
"result.entry.offset > 0 for address in the database - %s - %s - %s",
|
0,
|
||||||
ip, filename, mode_desc);
|
"result.entry.offset > 0 for address in the database - %s - %s "
|
||||||
|
"- %s",
|
||||||
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
test_all_data_types(&result, ip, filename, mode_desc);
|
test_all_data_types(&result, ip, filename, mode_desc);
|
||||||
}
|
}
|
||||||
@ -401,15 +488,21 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
||||||
|
|
||||||
ok(
|
ok(result.found_entry,
|
||||||
result.found_entry,
|
"got a result entry struct for IP address in the database - %s - %s "
|
||||||
"got a result entry struct for IP address in the database - %s - %s - %s",
|
"- %s",
|
||||||
ip, filename, mode_desc);
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
cmp_ok(
|
cmp_ok(result.entry.offset,
|
||||||
result.entry.offset, ">", 0,
|
">",
|
||||||
"result.entry.offset > 0 for address in the database - %s - %s - %s",
|
0,
|
||||||
ip, filename, mode_desc);
|
"result.entry.offset > 0 for address in the database - %s - %s "
|
||||||
|
"- %s",
|
||||||
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
test_all_data_types(&result, ip, filename, mode_desc);
|
test_all_data_types(&result, ip, filename, mode_desc);
|
||||||
}
|
}
|
||||||
@ -419,10 +512,12 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
||||||
|
|
||||||
ok(
|
ok(result.found_entry,
|
||||||
result.found_entry,
|
"got a result entry struct for IP address in the database - %s - %s "
|
||||||
"got a result entry struct for IP address in the database - %s - %s - %s",
|
"- %s",
|
||||||
ip, filename, mode_desc);
|
ip,
|
||||||
|
filename,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
test_all_data_types_as_zero(&result, ip, filename, mode_desc);
|
test_all_data_types_as_zero(&result, ip, filename, mode_desc);
|
||||||
}
|
}
|
||||||
@ -431,8 +526,7 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
101
vendor/MaxmindDB/t/dump_t.c
vendored
101
vendor/MaxmindDB/t/dump_t.c
vendored
@ -2,8 +2,7 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
#ifdef HAVE_OPEN_MEMSTREAM
|
#ifdef HAVE_OPEN_MEMSTREAM
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-decoder.mmdb";
|
const char *filename = "MaxMind-DB-test-decoder.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -16,8 +15,7 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_entry_data_list_s *entry_data_list;
|
MMDB_entry_data_list_s *entry_data_list;
|
||||||
int status = MMDB_get_entry_data_list(&result.entry, &entry_data_list);
|
int status = MMDB_get_entry_data_list(&result.entry, &entry_data_list);
|
||||||
|
|
||||||
ok(MMDB_SUCCESS == status,
|
ok(MMDB_SUCCESS == status, "MMDB_get_entry_data_list is successful");
|
||||||
"MMDB_get_entry_data_list is successful");
|
|
||||||
|
|
||||||
char *dump_output;
|
char *dump_output;
|
||||||
size_t dump_size;
|
size_t dump_size;
|
||||||
@ -32,54 +30,53 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
|
|
||||||
cmp_ok(dump_size, ">", 0, "MMDB_dump produced output - %s", mode_desc);
|
cmp_ok(dump_size, ">", 0, "MMDB_dump produced output - %s", mode_desc);
|
||||||
|
|
||||||
char *expect[] = {
|
char *expect[] = {"{",
|
||||||
"{",
|
" \"array\": ",
|
||||||
" \"array\": ",
|
" [",
|
||||||
" [",
|
" 1 <uint32>",
|
||||||
" 1 <uint32>",
|
" 2 <uint32>",
|
||||||
" 2 <uint32>",
|
" 3 <uint32>",
|
||||||
" 3 <uint32>",
|
" ]",
|
||||||
" ]",
|
" \"boolean\": ",
|
||||||
" \"boolean\": ",
|
" true <boolean>",
|
||||||
" true <boolean>",
|
" \"bytes\": ",
|
||||||
" \"bytes\": ",
|
" 0000002A <bytes>",
|
||||||
" 0000002A <bytes>",
|
" \"double\": ",
|
||||||
" \"double\": ",
|
" 42.123456 <double>",
|
||||||
" 42.123456 <double>",
|
" \"float\": ",
|
||||||
" \"float\": ",
|
" 1.100000 <float>",
|
||||||
" 1.100000 <float>",
|
" \"int32\": ",
|
||||||
" \"int32\": ",
|
" -268435456 <int32>",
|
||||||
" -268435456 <int32>",
|
" \"map\": ",
|
||||||
" \"map\": ",
|
" {",
|
||||||
" {",
|
" \"mapX\": ",
|
||||||
" \"mapX\": ",
|
" {",
|
||||||
" {",
|
" \"arrayX\": ",
|
||||||
" \"arrayX\": ",
|
" [",
|
||||||
" [",
|
" 7 <uint32>",
|
||||||
" 7 <uint32>",
|
" 8 <uint32>",
|
||||||
" 8 <uint32>",
|
" 9 <uint32>",
|
||||||
" 9 <uint32>",
|
" ]",
|
||||||
" ]",
|
" \"utf8_stringX\": ",
|
||||||
" \"utf8_stringX\": ",
|
" \"hello\" <utf8_string>",
|
||||||
" \"hello\" <utf8_string>",
|
" }",
|
||||||
" }",
|
" }",
|
||||||
" }",
|
" \"uint128\": ",
|
||||||
" \"uint128\": ",
|
" 0x01000000000000000000000000000000 <uint128>",
|
||||||
" 0x01000000000000000000000000000000 <uint128>",
|
" \"uint16\": ",
|
||||||
" \"uint16\": ",
|
" 100 <uint16>",
|
||||||
" 100 <uint16>",
|
" \"uint32\": ",
|
||||||
" \"uint32\": ",
|
" 268435456 <uint32>",
|
||||||
" 268435456 <uint32>",
|
" \"uint64\": ",
|
||||||
" \"uint64\": ",
|
" 1152921504606846976 <uint64>",
|
||||||
" 1152921504606846976 <uint64>",
|
" \"utf8_string\": ",
|
||||||
" \"utf8_string\": ",
|
" \"unicode! ☯ - ♫\" <utf8_string>",
|
||||||
" \"unicode! ☯ - ♫\" <utf8_string>",
|
"}"};
|
||||||
"}"
|
|
||||||
};
|
|
||||||
|
|
||||||
for (int i = 0; i < 42; i++) {
|
for (int i = 0; i < 42; i++) {
|
||||||
ok((strstr(dump_output, expect[i]) != NULL),
|
ok((strstr(dump_output, expect[i]) != NULL),
|
||||||
"dump output contains expected line (%s) - %s", expect[i],
|
"dump output contains expected line (%s) - %s",
|
||||||
|
expect[i],
|
||||||
mode_desc);
|
mode_desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -89,15 +86,13 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(SKIP_ALL, "This test requires the open_memstream() function");
|
plan(SKIP_ALL, "This test requires the open_memstream() function");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
34
vendor/MaxmindDB/t/get_value_pointer_bug_t.c
vendored
34
vendor/MaxmindDB/t/get_value_pointer_bug_t.c
vendored
@ -14,15 +14,20 @@
|
|||||||
* exists before checking to see if the lookups are correct.
|
* exists before checking to see if the lookups are correct.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void test_one_ip(MMDB_s *mmdb, const char *filename, const char *mode_desc,
|
void test_one_ip(MMDB_s *mmdb,
|
||||||
char *ip, char *country_code)
|
const char *filename,
|
||||||
{
|
const char *mode_desc,
|
||||||
|
char *ip,
|
||||||
|
char *country_code) {
|
||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
||||||
|
|
||||||
MMDB_entry_data_s entry_data =
|
MMDB_entry_data_s entry_data = data_ok(&result,
|
||||||
data_ok(&result, MMDB_DATA_TYPE_UTF8_STRING, "country{iso_code}",
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"country", "iso_code", NULL);
|
"country{iso_code}",
|
||||||
|
"country",
|
||||||
|
"iso_code",
|
||||||
|
NULL);
|
||||||
|
|
||||||
if (ok(entry_data.has_data, "found data for country{iso_code}")) {
|
if (ok(entry_data.has_data, "found data for country{iso_code}")) {
|
||||||
char *string =
|
char *string =
|
||||||
@ -31,16 +36,16 @@ void test_one_ip(MMDB_s *mmdb, const char *filename, const char *mode_desc,
|
|||||||
ok(0, "mmdb_strndup() call failed");
|
ok(0, "mmdb_strndup() call failed");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
if (!ok(strcmp(string,
|
if (!ok(strcmp(string, country_code) == 0,
|
||||||
country_code) == 0, "iso_code is %s", country_code)) {
|
"iso_code is %s",
|
||||||
|
country_code)) {
|
||||||
diag(" value is %s", string);
|
diag(" value is %s", string);
|
||||||
}
|
}
|
||||||
free(string);
|
free(string);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "GeoIP2-City-Test.mmdb";
|
const char *filename = "GeoIP2-City-Test.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -50,17 +55,16 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
* another part of the data section. */
|
* another part of the data section. */
|
||||||
test_one_ip(mmdb, filename, mode_desc, "2001:218::", "JP");
|
test_one_ip(mmdb, filename, mode_desc, "2001:218::", "JP");
|
||||||
/* This exercises a bug where one subnet's data shares part of the data
|
/* This exercises a bug where one subnet's data shares part of the data
|
||||||
* with another subnet - in this case it is the "country" key (and others)
|
* with another subnet - in this case it is the "country" key (and others)
|
||||||
* in the top level map. We are testing that the "country" key's value is
|
* in the top level map. We are testing that the "country" key's value is
|
||||||
* handled correctly. The value _should_ be a pointer to another map. */
|
* handled correctly. The value _should_ be a pointer to another map. */
|
||||||
test_one_ip(mmdb, filename, mode_desc, "81.2.69.160", "GB");
|
test_one_ip(mmdb, filename, mode_desc, "81.2.69.160", "GB");
|
||||||
|
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
317
vendor/MaxmindDB/t/get_value_t.c
vendored
317
vendor/MaxmindDB/t/get_value_t.c
vendored
@ -1,52 +1,70 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
void test_array_0_result(int status, MMDB_entry_data_s entry_data,
|
void test_array_0_result(int status,
|
||||||
char *function)
|
MMDB_entry_data_s entry_data,
|
||||||
{
|
char *function) {
|
||||||
cmp_ok(status, "==", MMDB_SUCCESS,
|
cmp_ok(status,
|
||||||
"status for %s() is MMDB_SUCCESS - array[0]", function);
|
"==",
|
||||||
|
MMDB_SUCCESS,
|
||||||
|
"status for %s() is MMDB_SUCCESS - array[0]",
|
||||||
|
function);
|
||||||
ok(entry_data.has_data, "found a value for array[0]");
|
ok(entry_data.has_data, "found a value for array[0]");
|
||||||
cmp_ok(entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"returned entry type is uint32 - array[0]");
|
"returned entry type is uint32 - array[0]");
|
||||||
cmp_ok(entry_data.uint32, "==", 1, "entry value is 1 - array[0]");
|
cmp_ok(entry_data.uint32, "==", 1, "entry value is 1 - array[0]");
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_array_2_result(int status, MMDB_entry_data_s entry_data,
|
void test_array_2_result(int status,
|
||||||
char *function)
|
MMDB_entry_data_s entry_data,
|
||||||
{
|
char *function) {
|
||||||
cmp_ok(status, "==", MMDB_SUCCESS,
|
cmp_ok(status,
|
||||||
"status for %s() is MMDB_SUCCESS - array[2]", function);
|
"==",
|
||||||
|
MMDB_SUCCESS,
|
||||||
|
"status for %s() is MMDB_SUCCESS - array[2]",
|
||||||
|
function);
|
||||||
ok(entry_data.has_data, "found a value for array[2]");
|
ok(entry_data.has_data, "found a value for array[2]");
|
||||||
cmp_ok(entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"returned entry type is uint32 - array[2]");
|
"returned entry type is uint32 - array[2]");
|
||||||
cmp_ok(entry_data.uint32, "==", 3, "entry value is 3 - array[2]");
|
cmp_ok(entry_data.uint32, "==", 3, "entry value is 3 - array[2]");
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_array_minus_3_result(int status, MMDB_entry_data_s entry_data,
|
void test_array_minus_3_result(int status,
|
||||||
char *function)
|
MMDB_entry_data_s entry_data,
|
||||||
{
|
char *function) {
|
||||||
cmp_ok(status, "==", MMDB_SUCCESS,
|
cmp_ok(status,
|
||||||
"status for %s() is MMDB_SUCCESS - array[-3]", function);
|
"==",
|
||||||
|
MMDB_SUCCESS,
|
||||||
|
"status for %s() is MMDB_SUCCESS - array[-3]",
|
||||||
|
function);
|
||||||
ok(entry_data.has_data, "found a value for array[-3]");
|
ok(entry_data.has_data, "found a value for array[-3]");
|
||||||
cmp_ok(entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"returned entry type is uint32 - array[-3]");
|
"returned entry type is uint32 - array[-3]");
|
||||||
cmp_ok(entry_data.uint32, "==", 1, "entry value is 1 - array[-3]");
|
cmp_ok(entry_data.uint32, "==", 1, "entry value is 1 - array[-3]");
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_array_minus_1_result(int status, MMDB_entry_data_s entry_data,
|
void test_array_minus_1_result(int status,
|
||||||
char *function)
|
MMDB_entry_data_s entry_data,
|
||||||
{
|
char *function) {
|
||||||
cmp_ok(status, "==", MMDB_SUCCESS,
|
cmp_ok(status,
|
||||||
"status for %s() is MMDB_SUCCESS - array[-1]", function);
|
"==",
|
||||||
|
MMDB_SUCCESS,
|
||||||
|
"status for %s() is MMDB_SUCCESS - array[-1]",
|
||||||
|
function);
|
||||||
ok(entry_data.has_data, "found a value for array[-1]");
|
ok(entry_data.has_data, "found a value for array[-1]");
|
||||||
cmp_ok(entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"returned entry type is uint32 - array[-1]");
|
"returned entry type is uint32 - array[-1]");
|
||||||
cmp_ok(entry_data.uint32, "==", 3, "entry value is 3 - array[-1]");
|
cmp_ok(entry_data.uint32, "==", 3, "entry value is 3 - array[-1]");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int call_vget_value(MMDB_entry_s *entry, MMDB_entry_data_s *entry_data, ...) {
|
||||||
int call_vget_value(MMDB_entry_s *entry, MMDB_entry_data_s *entry_data, ...)
|
|
||||||
{
|
|
||||||
va_list keys;
|
va_list keys;
|
||||||
va_start(keys, entry_data);
|
va_start(keys, entry_data);
|
||||||
|
|
||||||
@ -57,8 +75,7 @@ int call_vget_value(MMDB_entry_s *entry, MMDB_entry_data_s *entry_data, ...)
|
|||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_simple_structure(int mode, const char *mode_desc)
|
void test_simple_structure(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-decoder.mmdb";
|
const char *filename = "MaxMind-DB-test-decoder.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -70,7 +87,7 @@ void test_simple_structure(int mode, const char *mode_desc)
|
|||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
const char *lookup_path[] = { "array", "0", NULL };
|
const char *lookup_path[] = {"array", "0", NULL};
|
||||||
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
||||||
test_array_0_result(status, entry_data, "MMDB_aget_value");
|
test_array_0_result(status, entry_data, "MMDB_aget_value");
|
||||||
|
|
||||||
@ -84,7 +101,7 @@ void test_simple_structure(int mode, const char *mode_desc)
|
|||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
const char *lookup_path[] = { "array", "2", NULL };
|
const char *lookup_path[] = {"array", "2", NULL};
|
||||||
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
||||||
test_array_2_result(status, entry_data, "MMDB_aget_value");
|
test_array_2_result(status, entry_data, "MMDB_aget_value");
|
||||||
|
|
||||||
@ -96,18 +113,19 @@ void test_simple_structure(int mode, const char *mode_desc)
|
|||||||
test_array_2_result(status, entry_data, "MMDB_vget_value");
|
test_array_2_result(status, entry_data, "MMDB_vget_value");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
int status = MMDB_get_value(&result.entry, &entry_data, "array", "zero",
|
int status =
|
||||||
NULL);
|
MMDB_get_value(&result.entry, &entry_data, "array", "zero", NULL);
|
||||||
cmp_ok(status, "==", MMDB_LOOKUP_PATH_DOES_NOT_MATCH_DATA_ERROR,
|
cmp_ok(status,
|
||||||
|
"==",
|
||||||
|
MMDB_LOOKUP_PATH_DOES_NOT_MATCH_DATA_ERROR,
|
||||||
"MMDB_get_value() returns error on non-integer array index");
|
"MMDB_get_value() returns error on non-integer array index");
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
const char *lookup_path[] = { "array", "-1", NULL };
|
const char *lookup_path[] = {"array", "-1", NULL};
|
||||||
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
||||||
test_array_minus_1_result(status, entry_data, "MMDB_aget_value");
|
test_array_minus_1_result(status, entry_data, "MMDB_aget_value");
|
||||||
|
|
||||||
@ -122,7 +140,7 @@ void test_simple_structure(int mode, const char *mode_desc)
|
|||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
const char *lookup_path[] = { "array", "-3", NULL };
|
const char *lookup_path[] = {"array", "-3", NULL};
|
||||||
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
||||||
test_array_minus_3_result(status, entry_data, "MMDB_aget_value");
|
test_array_minus_3_result(status, entry_data, "MMDB_aget_value");
|
||||||
|
|
||||||
@ -137,77 +155,92 @@ void test_simple_structure(int mode, const char *mode_desc)
|
|||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
int status = MMDB_get_value(&result.entry, &entry_data, "array", "-4",
|
int status =
|
||||||
NULL);
|
MMDB_get_value(&result.entry, &entry_data, "array", "-4", NULL);
|
||||||
cmp_ok(status, "==", MMDB_LOOKUP_PATH_DOES_NOT_MATCH_DATA_ERROR,
|
cmp_ok(status,
|
||||||
|
"==",
|
||||||
|
MMDB_LOOKUP_PATH_DOES_NOT_MATCH_DATA_ERROR,
|
||||||
"MMDB_get_value() returns error on too large negative integer");
|
"MMDB_get_value() returns error on too large negative integer");
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
int status =
|
int status = MMDB_get_value(
|
||||||
MMDB_get_value(&result.entry, &entry_data, "array",
|
&result.entry, &entry_data, "array", "-18446744073709551616", NULL);
|
||||||
"-18446744073709551616",
|
cmp_ok(
|
||||||
NULL);
|
status,
|
||||||
cmp_ok(status, "==", MMDB_INVALID_LOOKUP_PATH_ERROR,
|
"==",
|
||||||
"MMDB_get_value() returns error on integer smaller than LONG_MIN");
|
MMDB_INVALID_LOOKUP_PATH_ERROR,
|
||||||
|
"MMDB_get_value() returns error on integer smaller than LONG_MIN");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
int status =
|
int status = MMDB_get_value(
|
||||||
MMDB_get_value(&result.entry, &entry_data, "array",
|
&result.entry, &entry_data, "array", "18446744073709551616", NULL);
|
||||||
"18446744073709551616",
|
cmp_ok(
|
||||||
NULL);
|
status,
|
||||||
cmp_ok(status, "==", MMDB_INVALID_LOOKUP_PATH_ERROR,
|
"==",
|
||||||
"MMDB_get_value() returns error on integer larger than LONG_MAX");
|
MMDB_INVALID_LOOKUP_PATH_ERROR,
|
||||||
|
"MMDB_get_value() returns error on integer larger than LONG_MAX");
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_complex_map_a_result(int status, MMDB_entry_data_s entry_data,
|
void test_complex_map_a_result(int status,
|
||||||
char *function)
|
MMDB_entry_data_s entry_data,
|
||||||
{
|
char *function) {
|
||||||
cmp_ok(status, "==", MMDB_SUCCESS,
|
cmp_ok(status,
|
||||||
|
"==",
|
||||||
|
MMDB_SUCCESS,
|
||||||
"status for %s() is MMDB_SUCCESS - map1{map2}{array}[0]{map3}{a}",
|
"status for %s() is MMDB_SUCCESS - map1{map2}{array}[0]{map3}{a}",
|
||||||
function);
|
function);
|
||||||
ok(entry_data.has_data,
|
ok(entry_data.has_data, "found a value for map1{map2}{array}[0]{map3}{a}");
|
||||||
"found a value for map1{map2}{array}[0]{map3}{a}");
|
cmp_ok(entry_data.type,
|
||||||
cmp_ok(entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"returned entry type is uint32 - map1{map2}{array}[0]{map3}{a}");
|
"returned entry type is uint32 - map1{map2}{array}[0]{map3}{a}");
|
||||||
cmp_ok(entry_data.uint32, "==", 1,
|
cmp_ok(entry_data.uint32,
|
||||||
|
"==",
|
||||||
|
1,
|
||||||
"entry value is 1 - map1{map2}{array}[0]{map3}{a}");
|
"entry value is 1 - map1{map2}{array}[0]{map3}{a}");
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_complex_map_c_result(int status, MMDB_entry_data_s entry_data,
|
void test_complex_map_c_result(int status,
|
||||||
char *function)
|
MMDB_entry_data_s entry_data,
|
||||||
{
|
char *function) {
|
||||||
cmp_ok(
|
cmp_ok(status,
|
||||||
status, "==", MMDB_SUCCESS,
|
"==",
|
||||||
"status for %s() is MMDB_SUCCESS - map1{map2}{array}[0]{map3}{c}",
|
MMDB_SUCCESS,
|
||||||
function);
|
"status for %s() is MMDB_SUCCESS - map1{map2}{array}[0]{map3}{c}",
|
||||||
ok(entry_data.has_data,
|
function);
|
||||||
"found a value for map1{map2}{array}[0]{map3}{c}");
|
ok(entry_data.has_data, "found a value for map1{map2}{array}[0]{map3}{c}");
|
||||||
cmp_ok(entry_data.type, "==", MMDB_DATA_TYPE_UINT32,
|
cmp_ok(entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UINT32,
|
||||||
"returned entry type is uint32 - map1{map2}{array}[0]{map3}{c}");
|
"returned entry type is uint32 - map1{map2}{array}[0]{map3}{c}");
|
||||||
cmp_ok(entry_data.uint32, "==", 3,
|
cmp_ok(entry_data.uint32,
|
||||||
|
"==",
|
||||||
|
3,
|
||||||
"entry value is 3 - map1{map2}{array}[0]{map3}{c}");
|
"entry value is 3 - map1{map2}{array}[0]{map3}{c}");
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_no_result(int status, MMDB_entry_data_s entry_data, char *function,
|
void test_no_result(int status,
|
||||||
char *path_description)
|
MMDB_entry_data_s entry_data,
|
||||||
{
|
char *function,
|
||||||
cmp_ok(status, "==", MMDB_LOOKUP_PATH_DOES_NOT_MATCH_DATA_ERROR,
|
char *path_description) {
|
||||||
|
cmp_ok(status,
|
||||||
|
"==",
|
||||||
|
MMDB_LOOKUP_PATH_DOES_NOT_MATCH_DATA_ERROR,
|
||||||
"status for %s() is MMDB_LOOKUP_PATH_DOES_NOT_MATCH_DATA_ERROR - %s",
|
"status for %s() is MMDB_LOOKUP_PATH_DOES_NOT_MATCH_DATA_ERROR - %s",
|
||||||
function, path_description);
|
function,
|
||||||
|
path_description);
|
||||||
ok(!entry_data.has_data, "did not find a value for %s", path_description);
|
ok(!entry_data.has_data, "did not find a value for %s", path_description);
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_nested_structure(int mode, const char *mode_desc)
|
void test_nested_structure(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-nested.mmdb";
|
const char *filename = "MaxMind-DB-test-nested.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -219,79 +252,139 @@ void test_nested_structure(int mode, const char *mode_desc)
|
|||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
const char *lookup_path[] =
|
const char *lookup_path[] = {
|
||||||
{ "map1", "map2", "array", "0", "map3", "a", NULL };
|
"map1", "map2", "array", "0", "map3", "a", NULL};
|
||||||
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
||||||
test_complex_map_a_result(status, entry_data, "MMDB_aget_value");
|
test_complex_map_a_result(status, entry_data, "MMDB_aget_value");
|
||||||
|
|
||||||
status = MMDB_get_value(&result.entry, &entry_data,
|
status = MMDB_get_value(&result.entry,
|
||||||
"map1", "map2", "array", "0", "map3", "a",
|
&entry_data,
|
||||||
|
"map1",
|
||||||
|
"map2",
|
||||||
|
"array",
|
||||||
|
"0",
|
||||||
|
"map3",
|
||||||
|
"a",
|
||||||
NULL);
|
NULL);
|
||||||
test_complex_map_a_result(status, entry_data, "MMDB_get_value");
|
test_complex_map_a_result(status, entry_data, "MMDB_get_value");
|
||||||
|
|
||||||
status = call_vget_value(&result.entry, &entry_data,
|
status = call_vget_value(&result.entry,
|
||||||
"map1", "map2", "array", "0", "map3", "a",
|
&entry_data,
|
||||||
|
"map1",
|
||||||
|
"map2",
|
||||||
|
"array",
|
||||||
|
"0",
|
||||||
|
"map3",
|
||||||
|
"a",
|
||||||
NULL);
|
NULL);
|
||||||
test_complex_map_a_result(status, entry_data, "MMDB_vget_value");
|
test_complex_map_a_result(status, entry_data, "MMDB_vget_value");
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
const char *lookup_path[] =
|
const char *lookup_path[] = {
|
||||||
{ "map1", "map2", "array", "0", "map3", "c", NULL };
|
"map1", "map2", "array", "0", "map3", "c", NULL};
|
||||||
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
||||||
test_complex_map_c_result(status, entry_data, "MMDB_aget_value");
|
test_complex_map_c_result(status, entry_data, "MMDB_aget_value");
|
||||||
|
|
||||||
status = MMDB_get_value(&result.entry, &entry_data,
|
status = MMDB_get_value(&result.entry,
|
||||||
"map1", "map2", "array", "0", "map3", "c",
|
&entry_data,
|
||||||
|
"map1",
|
||||||
|
"map2",
|
||||||
|
"array",
|
||||||
|
"0",
|
||||||
|
"map3",
|
||||||
|
"c",
|
||||||
NULL);
|
NULL);
|
||||||
test_complex_map_c_result(status, entry_data, "MMDB_get_value");
|
test_complex_map_c_result(status, entry_data, "MMDB_get_value");
|
||||||
|
|
||||||
status = call_vget_value(&result.entry, &entry_data,
|
status = call_vget_value(&result.entry,
|
||||||
"map1", "map2", "array", "0", "map3", "c",
|
&entry_data,
|
||||||
|
"map1",
|
||||||
|
"map2",
|
||||||
|
"array",
|
||||||
|
"0",
|
||||||
|
"map3",
|
||||||
|
"c",
|
||||||
NULL);
|
NULL);
|
||||||
test_complex_map_c_result(status, entry_data, "MMDB_vget_value");
|
test_complex_map_c_result(status, entry_data, "MMDB_vget_value");
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
const char *lookup_path[] =
|
const char *lookup_path[] = {
|
||||||
{ "map1", "map42", "array", "0", "map3", "c", NULL };
|
"map1", "map42", "array", "0", "map3", "c", NULL};
|
||||||
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
||||||
test_no_result(status, entry_data, "MMDB_aget_value",
|
test_no_result(status,
|
||||||
|
entry_data,
|
||||||
|
"MMDB_aget_value",
|
||||||
"map1{map42}{array}[0]{map3}{c}");
|
"map1{map42}{array}[0]{map3}{c}");
|
||||||
|
|
||||||
status = MMDB_get_value(&result.entry, &entry_data,
|
status = MMDB_get_value(&result.entry,
|
||||||
"map1", "map42", "array", "0", "map3", "c",
|
&entry_data,
|
||||||
|
"map1",
|
||||||
|
"map42",
|
||||||
|
"array",
|
||||||
|
"0",
|
||||||
|
"map3",
|
||||||
|
"c",
|
||||||
NULL);
|
NULL);
|
||||||
test_no_result(status, entry_data, "MMDB_get_value",
|
test_no_result(status,
|
||||||
|
entry_data,
|
||||||
|
"MMDB_get_value",
|
||||||
"map1{map42}{array}[0]{map3}{c}");
|
"map1{map42}{array}[0]{map3}{c}");
|
||||||
|
|
||||||
status = call_vget_value(&result.entry, &entry_data,
|
status = call_vget_value(&result.entry,
|
||||||
"map1", "map42", "array", "0", "map3", "c",
|
&entry_data,
|
||||||
|
"map1",
|
||||||
|
"map42",
|
||||||
|
"array",
|
||||||
|
"0",
|
||||||
|
"map3",
|
||||||
|
"c",
|
||||||
NULL);
|
NULL);
|
||||||
test_no_result(status, entry_data, "MMDB_vget_value",
|
test_no_result(status,
|
||||||
|
entry_data,
|
||||||
|
"MMDB_vget_value",
|
||||||
"map1{map42}{array}[0]{map3}{c}");
|
"map1{map42}{array}[0]{map3}{c}");
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
const char *lookup_path[] =
|
const char *lookup_path[] = {
|
||||||
{ "map1", "map2", "array", "9", "map3", "c", NULL };
|
"map1", "map2", "array", "9", "map3", "c", NULL};
|
||||||
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
int status = MMDB_aget_value(&result.entry, &entry_data, lookup_path);
|
||||||
test_no_result(status, entry_data, "MMDB_aget_value",
|
test_no_result(status,
|
||||||
|
entry_data,
|
||||||
|
"MMDB_aget_value",
|
||||||
"map1{map42}{array}[9]{map3}{c}");
|
"map1{map42}{array}[9]{map3}{c}");
|
||||||
|
|
||||||
status = MMDB_get_value(&result.entry, &entry_data,
|
status = MMDB_get_value(&result.entry,
|
||||||
"map1", "map2", "array", "9", "map3", "c",
|
&entry_data,
|
||||||
|
"map1",
|
||||||
|
"map2",
|
||||||
|
"array",
|
||||||
|
"9",
|
||||||
|
"map3",
|
||||||
|
"c",
|
||||||
NULL);
|
NULL);
|
||||||
test_no_result(status, entry_data, "MMDB_get_value",
|
test_no_result(status,
|
||||||
|
entry_data,
|
||||||
|
"MMDB_get_value",
|
||||||
"map1{map42}{array}[9]{map3}{c}");
|
"map1{map42}{array}[9]{map3}{c}");
|
||||||
|
|
||||||
status = call_vget_value(&result.entry, &entry_data,
|
status = call_vget_value(&result.entry,
|
||||||
"map1", "map2", "array", "9", "map3", "c",
|
&entry_data,
|
||||||
|
"map1",
|
||||||
|
"map2",
|
||||||
|
"array",
|
||||||
|
"9",
|
||||||
|
"map3",
|
||||||
|
"c",
|
||||||
NULL);
|
NULL);
|
||||||
test_no_result(status, entry_data, "MMDB_vget_value",
|
test_no_result(status,
|
||||||
|
entry_data,
|
||||||
|
"MMDB_vget_value",
|
||||||
"map1{map42}{array}[9]{map3}{c}");
|
"map1{map42}{array}[9]{map3}{c}");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -299,14 +392,12 @@ void test_nested_structure(int mode, const char *mode_desc)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
test_simple_structure(mode, mode_desc);
|
test_simple_structure(mode, mode_desc);
|
||||||
test_nested_structure(mode, mode_desc);
|
test_nested_structure(mode, mode_desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
22
vendor/MaxmindDB/t/ipv4_start_cache_t.c
vendored
22
vendor/MaxmindDB/t/ipv4_start_cache_t.c
vendored
@ -1,21 +1,22 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
void test_one_ip(MMDB_s *mmdb, const char *ip, const char *filename,
|
void test_one_ip(MMDB_s *mmdb,
|
||||||
const char *mode_desc)
|
const char *ip,
|
||||||
{
|
const char *filename,
|
||||||
|
const char *mode_desc) {
|
||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
lookup_string_ok(mmdb, ip, filename, mode_desc);
|
||||||
|
|
||||||
ok(
|
ok(result.found_entry,
|
||||||
result.found_entry,
|
"got a result for an IPv4 address included in a larger-than-IPv4 subnet "
|
||||||
"got a result for an IPv4 address included in a larger-than-IPv4 subnet - %s - %s",
|
"- %s - %s",
|
||||||
ip, mode_desc);
|
ip,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
data_ok(&result, MMDB_DATA_TYPE_UTF8_STRING, "string value for IP", NULL);
|
data_ok(&result, MMDB_DATA_TYPE_UTF8_STRING, "string value for IP", NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-no-ipv4-search-tree.mmdb";
|
const char *filename = "MaxMind-DB-no-ipv4-search-tree.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -28,8 +29,7 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
33
vendor/MaxmindDB/t/ipv6_lookup_in_ipv4_t.c
vendored
33
vendor/MaxmindDB/t/ipv6_lookup_in_ipv4_t.c
vendored
@ -1,7 +1,6 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-ipv4-28.mmdb";
|
const char *filename = "MaxMind-DB-test-ipv4-28.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -12,18 +11,18 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_lookup_result_s UNUSED(result) =
|
MMDB_lookup_result_s UNUSED(result) =
|
||||||
MMDB_lookup_string(mmdb, ip, &gai_error, &mmdb_error);
|
MMDB_lookup_string(mmdb, ip, &gai_error, &mmdb_error);
|
||||||
|
|
||||||
cmp_ok(
|
cmp_ok(mmdb_error,
|
||||||
mmdb_error, "==", MMDB_IPV6_LOOKUP_IN_IPV4_DATABASE_ERROR,
|
"==",
|
||||||
"MMDB_lookup_string sets mmdb_error to MMDB_IPV6_LOOKUP_IN_IPV4_DATABASE_ERROR when we try to look up an IPv6 address in an IPv4-only database");
|
MMDB_IPV6_LOOKUP_IN_IPV4_DATABASE_ERROR,
|
||||||
|
"MMDB_lookup_string sets mmdb_error to "
|
||||||
|
"MMDB_IPV6_LOOKUP_IN_IPV4_DATABASE_ERROR when we try to look up an "
|
||||||
|
"IPv6 address in an IPv4-only database");
|
||||||
|
|
||||||
struct addrinfo hints = {
|
struct addrinfo hints = {.ai_family = AF_INET6, .ai_flags = AI_NUMERICHOST};
|
||||||
.ai_family = AF_INET6,
|
|
||||||
.ai_flags = AI_NUMERICHOST
|
|
||||||
};
|
|
||||||
|
|
||||||
struct addrinfo *addresses;
|
struct addrinfo *addresses;
|
||||||
gai_error = getaddrinfo("2001:db8:85a3:0:0:8a2e:370:7334", NULL,
|
gai_error = getaddrinfo(
|
||||||
&hints, &addresses);
|
"2001:db8:85a3:0:0:8a2e:370:7334", NULL, &hints, &addresses);
|
||||||
if (gai_error) {
|
if (gai_error) {
|
||||||
BAIL_OUT("getaddrinfo failed: %s", gai_strerror(gai_error));
|
BAIL_OUT("getaddrinfo failed: %s", gai_strerror(gai_error));
|
||||||
}
|
}
|
||||||
@ -31,17 +30,19 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
mmdb_error = 0;
|
mmdb_error = 0;
|
||||||
MMDB_lookup_sockaddr(mmdb, addresses->ai_addr, &mmdb_error);
|
MMDB_lookup_sockaddr(mmdb, addresses->ai_addr, &mmdb_error);
|
||||||
|
|
||||||
cmp_ok(
|
cmp_ok(mmdb_error,
|
||||||
mmdb_error, "==", MMDB_IPV6_LOOKUP_IN_IPV4_DATABASE_ERROR,
|
"==",
|
||||||
"MMDB_lookup_sockaddr sets mmdb_error to MMDB_IPV6_LOOKUP_IN_IPV4_DATABASE_ERROR when we try to look up an IPv6 address in an IPv4-only database");
|
MMDB_IPV6_LOOKUP_IN_IPV4_DATABASE_ERROR,
|
||||||
|
"MMDB_lookup_sockaddr sets mmdb_error to "
|
||||||
|
"MMDB_IPV6_LOOKUP_IN_IPV4_DATABASE_ERROR when we try to look up an "
|
||||||
|
"IPv6 address in an IPv4-only database");
|
||||||
|
|
||||||
freeaddrinfo(addresses);
|
freeaddrinfo(addresses);
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
128
vendor/MaxmindDB/t/maxminddb_test_helper.c
vendored
128
vendor/MaxmindDB/t/maxminddb_test_helper.c
vendored
@ -18,10 +18,10 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
void for_all_record_sizes(const char *filename_fmt,
|
void for_all_record_sizes(const char *filename_fmt,
|
||||||
void (*tests)(int record_size, const char *filename,
|
void (*tests)(int record_size,
|
||||||
const char *description))
|
const char *filename,
|
||||||
{
|
const char *description)) {
|
||||||
int sizes[] = { 24, 28, 32 };
|
int sizes[] = {24, 28, 32};
|
||||||
for (int i = 0; i < 3; i++) {
|
for (int i = 0; i < 3; i++) {
|
||||||
int size = sizes[i];
|
int size = sizes[i];
|
||||||
|
|
||||||
@ -35,13 +35,11 @@ void for_all_record_sizes(const char *filename_fmt,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void for_all_modes(void (*tests)(int mode, const char *description))
|
void for_all_modes(void (*tests)(int mode, const char *description)) {
|
||||||
{
|
|
||||||
tests(MMDB_MODE_MMAP, "mmap mode");
|
tests(MMDB_MODE_MMAP, "mmap mode");
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *test_database_path(const char *filename)
|
const char *test_database_path(const char *filename) {
|
||||||
{
|
|
||||||
char *test_db_dir;
|
char *test_db_dir;
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
test_db_dir = "../t/maxmind-db/test-data";
|
test_db_dir = "../t/maxmind-db/test-data";
|
||||||
@ -64,10 +62,9 @@ const char *test_database_path(const char *filename)
|
|||||||
return (const char *)path;
|
return (const char *)path;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *dup_entry_string_or_bail(MMDB_entry_data_s entry_data)
|
const char *dup_entry_string_or_bail(MMDB_entry_data_s entry_data) {
|
||||||
{
|
const char *string =
|
||||||
const char *string = mmdb_strndup(entry_data.utf8_string,
|
mmdb_strndup(entry_data.utf8_string, entry_data.data_size);
|
||||||
entry_data.data_size);
|
|
||||||
if (NULL == string) {
|
if (NULL == string) {
|
||||||
BAIL_OUT("mmdb_strndup failed");
|
BAIL_OUT("mmdb_strndup failed");
|
||||||
}
|
}
|
||||||
@ -75,12 +72,11 @@ const char *dup_entry_string_or_bail(MMDB_entry_data_s entry_data)
|
|||||||
return string;
|
return string;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_s *open_ok(const char *db_file, int mode, const char *mode_desc)
|
MMDB_s *open_ok(const char *db_file, int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
if (0 != access(db_file, R_OK)) {
|
if (0 != access(db_file, R_OK)) {
|
||||||
BAIL_OUT(
|
BAIL_OUT("could not read the specified file - %s\nIf you are in a git "
|
||||||
"could not read the specified file - %s\nIf you are in a git checkout try running 'git submodule update --init'",
|
"checkout try running 'git submodule update --init'",
|
||||||
db_file);
|
db_file);
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_s *mmdb = (MMDB_s *)calloc(1, sizeof(MMDB_s));
|
MMDB_s *mmdb = (MMDB_s *)calloc(1, sizeof(MMDB_s));
|
||||||
@ -91,8 +87,10 @@ MMDB_s *open_ok(const char *db_file, int mode, const char *mode_desc)
|
|||||||
|
|
||||||
int status = MMDB_open(db_file, mode, mmdb);
|
int status = MMDB_open(db_file, mode, mmdb);
|
||||||
|
|
||||||
int is_ok = ok(MMDB_SUCCESS == status, "open %s status is success - %s",
|
int is_ok = ok(MMDB_SUCCESS == status,
|
||||||
db_file, mode_desc);
|
"open %s status is success - %s",
|
||||||
|
db_file,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
diag("open status code = %d (%s)", status, MMDB_strerror(status));
|
diag("open status code = %d (%s)", status, MMDB_strerror(status));
|
||||||
@ -102,7 +100,8 @@ MMDB_s *open_ok(const char *db_file, int mode, const char *mode_desc)
|
|||||||
|
|
||||||
is_ok = ok(mmdb->file_size > 0,
|
is_ok = ok(mmdb->file_size > 0,
|
||||||
"mmdb struct has been set for %s - %s",
|
"mmdb struct has been set for %s - %s",
|
||||||
db_file, mode_desc);
|
db_file,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
free(mmdb);
|
free(mmdb);
|
||||||
@ -112,26 +111,26 @@ MMDB_s *open_ok(const char *db_file, int mode, const char *mode_desc)
|
|||||||
return mmdb;
|
return mmdb;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_lookup_result_s lookup_string_ok(MMDB_s *mmdb, const char *ip,
|
MMDB_lookup_result_s lookup_string_ok(MMDB_s *mmdb,
|
||||||
const char *file, const char *mode_desc)
|
const char *ip,
|
||||||
{
|
const char *file,
|
||||||
|
const char *mode_desc) {
|
||||||
int gai_error, mmdb_error;
|
int gai_error, mmdb_error;
|
||||||
MMDB_lookup_result_s result =
|
MMDB_lookup_result_s result =
|
||||||
MMDB_lookup_string(mmdb, ip, &gai_error, &mmdb_error);
|
MMDB_lookup_string(mmdb, ip, &gai_error, &mmdb_error);
|
||||||
|
|
||||||
test_lookup_errors(gai_error, mmdb_error, "MMDB_lookup_string", ip, file,
|
test_lookup_errors(
|
||||||
mode_desc);
|
gai_error, mmdb_error, "MMDB_lookup_string", ip, file, mode_desc);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_lookup_result_s lookup_sockaddr_ok(MMDB_s *mmdb, const char *ip,
|
MMDB_lookup_result_s lookup_sockaddr_ok(MMDB_s *mmdb,
|
||||||
const char *file, const char *mode_desc)
|
const char *ip,
|
||||||
{
|
const char *file,
|
||||||
|
const char *mode_desc) {
|
||||||
int ai_flags = AI_NUMERICHOST;
|
int ai_flags = AI_NUMERICHOST;
|
||||||
struct addrinfo hints = {
|
struct addrinfo hints = {.ai_socktype = SOCK_STREAM};
|
||||||
.ai_socktype = SOCK_STREAM
|
|
||||||
};
|
|
||||||
struct addrinfo *addresses = NULL;
|
struct addrinfo *addresses = NULL;
|
||||||
|
|
||||||
if (ip[0] == ':') {
|
if (ip[0] == ':') {
|
||||||
@ -148,7 +147,7 @@ MMDB_lookup_result_s lookup_sockaddr_ok(MMDB_s *mmdb, const char *ip,
|
|||||||
int gai_error = getaddrinfo(ip, NULL, &hints, &addresses);
|
int gai_error = getaddrinfo(ip, NULL, &hints, &addresses);
|
||||||
|
|
||||||
int mmdb_error = 0;
|
int mmdb_error = 0;
|
||||||
MMDB_lookup_result_s result = { .found_entry = false };
|
MMDB_lookup_result_s result = {.found_entry = false};
|
||||||
if (gai_error == 0) {
|
if (gai_error == 0) {
|
||||||
result = MMDB_lookup_sockaddr(mmdb, addresses->ai_addr, &mmdb_error);
|
result = MMDB_lookup_sockaddr(mmdb, addresses->ai_addr, &mmdb_error);
|
||||||
}
|
}
|
||||||
@ -156,38 +155,48 @@ MMDB_lookup_result_s lookup_sockaddr_ok(MMDB_s *mmdb, const char *ip,
|
|||||||
freeaddrinfo(addresses);
|
freeaddrinfo(addresses);
|
||||||
}
|
}
|
||||||
|
|
||||||
test_lookup_errors(gai_error, mmdb_error, "MMDB_lookup_sockaddr", ip, file,
|
test_lookup_errors(
|
||||||
mode_desc);
|
gai_error, mmdb_error, "MMDB_lookup_sockaddr", ip, file, mode_desc);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_lookup_errors(int gai_error, int mmdb_error,
|
void test_lookup_errors(int gai_error,
|
||||||
const char *function, const char *ip,
|
int mmdb_error,
|
||||||
const char *file, const char *mode_desc)
|
const char *function,
|
||||||
{
|
const char *ip,
|
||||||
|
const char *file,
|
||||||
|
const char *mode_desc) {
|
||||||
|
|
||||||
int is_ok = ok(0 == gai_error,
|
int is_ok = ok(0 == gai_error,
|
||||||
"no getaddrinfo error in call to %s for %s - %s - %s",
|
"no getaddrinfo error in call to %s for %s - %s - %s",
|
||||||
function, ip, file, mode_desc);
|
function,
|
||||||
|
ip,
|
||||||
|
file,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
diag("error from call to getaddrinfo for %s - %s",
|
diag("error from call to getaddrinfo for %s - %s",
|
||||||
ip, gai_strerror(gai_error));
|
ip,
|
||||||
|
gai_strerror(gai_error));
|
||||||
}
|
}
|
||||||
|
|
||||||
is_ok = ok(0 == mmdb_error,
|
is_ok = ok(0 == mmdb_error,
|
||||||
"no MMDB error in call to %s for %s - %s - %s",
|
"no MMDB error in call to %s for %s - %s - %s",
|
||||||
function, ip, file, mode_desc);
|
function,
|
||||||
|
ip,
|
||||||
|
file,
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
diag("MMDB error - %s", MMDB_strerror(mmdb_error));
|
diag("MMDB error - %s", MMDB_strerror(mmdb_error));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_s data_ok(MMDB_lookup_result_s *result, uint32_t expect_type,
|
MMDB_entry_data_s data_ok(MMDB_lookup_result_s *result,
|
||||||
const char *description, ...)
|
uint32_t expect_type,
|
||||||
{
|
const char *description,
|
||||||
|
...) {
|
||||||
va_list keys;
|
va_list keys;
|
||||||
va_start(keys, description);
|
va_start(keys, description);
|
||||||
|
|
||||||
@ -196,13 +205,20 @@ MMDB_entry_data_s data_ok(MMDB_lookup_result_s *result, uint32_t expect_type,
|
|||||||
|
|
||||||
va_end(keys);
|
va_end(keys);
|
||||||
|
|
||||||
if (cmp_ok(status, "==", MMDB_SUCCESS,
|
if (cmp_ok(status,
|
||||||
"no error from call to MMDB_vget_value - %s", description)) {
|
"==",
|
||||||
|
MMDB_SUCCESS,
|
||||||
|
"no error from call to MMDB_vget_value - %s",
|
||||||
|
description)) {
|
||||||
|
|
||||||
if (!cmp_ok(data.type, "==", expect_type,
|
if (!cmp_ok(data.type,
|
||||||
"got the expected data type - %s", description)) {
|
"==",
|
||||||
|
expect_type,
|
||||||
|
"got the expected data type - %s",
|
||||||
|
description)) {
|
||||||
|
|
||||||
diag(" data type value is %i but expected %i", data.type,
|
diag(" data type value is %i but expected %i",
|
||||||
|
data.type,
|
||||||
expect_type);
|
expect_type);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -212,22 +228,20 @@ MMDB_entry_data_s data_ok(MMDB_lookup_result_s *result, uint32_t expect_type,
|
|||||||
return data;
|
return data;
|
||||||
}
|
}
|
||||||
|
|
||||||
void compare_double(double got, double expect)
|
void compare_double(double got, double expect) {
|
||||||
{
|
|
||||||
double diff = fabs(got - expect);
|
double diff = fabs(got - expect);
|
||||||
int is_ok = ok(diff < 0.01, "double value was approximately %2.6f", expect);
|
int is_ok = ok(diff < 0.01, "double value was approximately %2.6f", expect);
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
diag(" got %2.6f but expected %2.6f (diff = %2.6f)",
|
diag(
|
||||||
got, expect, diff);
|
" got %2.6f but expected %2.6f (diff = %2.6f)", got, expect, diff);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void compare_float(float got, float expect)
|
void compare_float(float got, float expect) {
|
||||||
{
|
|
||||||
float diff = fabsf(got - expect);
|
float diff = fabsf(got - expect);
|
||||||
int is_ok = ok(diff < 0.01, "float value was approximately %2.1f", expect);
|
int is_ok = ok(diff < 0.01, "float value was approximately %2.1f", expect);
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
diag(" got %2.4f but expected %2.1f (diff = %2.1f)",
|
diag(
|
||||||
got, expect, diff);
|
" got %2.4f but expected %2.1f (diff = %2.1f)", got, expect, diff);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
28
vendor/MaxmindDB/t/maxminddb_test_helper.h
vendored
28
vendor/MaxmindDB/t/maxminddb_test_helper.h
vendored
@ -6,12 +6,12 @@
|
|||||||
#if HAVE_CONFIG_H
|
#if HAVE_CONFIG_H
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
#endif
|
#endif
|
||||||
|
#include "libtap/tap.h"
|
||||||
|
#include "maxminddb-compat-util.h"
|
||||||
|
#include "maxminddb.h"
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include "maxminddb.h"
|
|
||||||
#include "maxminddb-compat-util.h"
|
|
||||||
#include "libtap/tap.h"
|
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#include <winsock2.h>
|
#include <winsock2.h>
|
||||||
@ -33,9 +33,9 @@
|
|||||||
#define MMDB_TEST_HELPER_C (1)
|
#define MMDB_TEST_HELPER_C (1)
|
||||||
|
|
||||||
#ifdef __GNUC__
|
#ifdef __GNUC__
|
||||||
# define UNUSED(x) UNUSED_ ## x __attribute__((__unused__))
|
#define UNUSED(x) UNUSED_##x __attribute__((__unused__))
|
||||||
#else
|
#else
|
||||||
# define UNUSED
|
#define UNUSED
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define MAX_DESCRIPTION_LENGTH 500
|
#define MAX_DESCRIPTION_LENGTH 500
|
||||||
@ -48,18 +48,24 @@ extern void for_all_modes(void (*tests)(int mode, const char *description));
|
|||||||
extern const char *test_database_path(const char *filename);
|
extern const char *test_database_path(const char *filename);
|
||||||
extern const char *dup_entry_string_or_bail(MMDB_entry_data_s entry_data);
|
extern const char *dup_entry_string_or_bail(MMDB_entry_data_s entry_data);
|
||||||
extern MMDB_s *open_ok(const char *db_file, int mode, const char *mode_desc);
|
extern MMDB_s *open_ok(const char *db_file, int mode, const char *mode_desc);
|
||||||
extern MMDB_lookup_result_s lookup_string_ok(MMDB_s *mmdb, const char *ip,
|
extern MMDB_lookup_result_s lookup_string_ok(MMDB_s *mmdb,
|
||||||
|
const char *ip,
|
||||||
const char *file,
|
const char *file,
|
||||||
const char *mode_desc);
|
const char *mode_desc);
|
||||||
extern MMDB_lookup_result_s lookup_sockaddr_ok(MMDB_s *mmdb, const char *ip,
|
extern MMDB_lookup_result_s lookup_sockaddr_ok(MMDB_s *mmdb,
|
||||||
|
const char *ip,
|
||||||
const char *file,
|
const char *file,
|
||||||
const char *mode_desc);
|
const char *mode_desc);
|
||||||
extern void test_lookup_errors(int gai_error, int mmdb_error,
|
extern void test_lookup_errors(int gai_error,
|
||||||
const char *function, const char *ip,
|
int mmdb_error,
|
||||||
const char *file, const char *mode_desc);
|
const char *function,
|
||||||
|
const char *ip,
|
||||||
|
const char *file,
|
||||||
|
const char *mode_desc);
|
||||||
extern MMDB_entry_data_s data_ok(MMDB_lookup_result_s *result,
|
extern MMDB_entry_data_s data_ok(MMDB_lookup_result_s *result,
|
||||||
uint32_t expect_type,
|
uint32_t expect_type,
|
||||||
const char *description, ...);
|
const char *description,
|
||||||
|
...);
|
||||||
extern void compare_double(double got, double expect);
|
extern void compare_double(double got, double expect);
|
||||||
extern void compare_float(float got, float expect);
|
extern void compare_float(float got, float expect);
|
||||||
|
|
||||||
|
9
vendor/MaxmindDB/t/metadata_pointers_t.c
vendored
9
vendor/MaxmindDB/t/metadata_pointers_t.c
vendored
@ -1,7 +1,6 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-metadata-pointers.mmdb";
|
const char *filename = "MaxMind-DB-test-metadata-pointers.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -9,7 +8,8 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
|
|
||||||
char *repeated_string = "Lots of pointers in metadata";
|
char *repeated_string = "Lots of pointers in metadata";
|
||||||
|
|
||||||
is(mmdb->metadata.database_type, repeated_string,
|
is(mmdb->metadata.database_type,
|
||||||
|
repeated_string,
|
||||||
"decoded pointer database_type");
|
"decoded pointer database_type");
|
||||||
|
|
||||||
for (uint16_t i = 0; i < mmdb->metadata.description.count; i++) {
|
for (uint16_t i = 0; i < mmdb->metadata.description.count; i++) {
|
||||||
@ -24,8 +24,7 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
199
vendor/MaxmindDB/t/metadata_t.c
vendored
199
vendor/MaxmindDB/t/metadata_t.c
vendored
@ -1,38 +1,63 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
void test_metadata(MMDB_s *mmdb, const char *mode_desc)
|
void test_metadata(MMDB_s *mmdb, const char *mode_desc) {
|
||||||
{
|
cmp_ok(mmdb->metadata.node_count,
|
||||||
cmp_ok(mmdb->metadata.node_count, "==", 37, "node_count is 37 - %s",
|
"==",
|
||||||
|
37,
|
||||||
|
"node_count is 37 - %s",
|
||||||
mode_desc);
|
mode_desc);
|
||||||
cmp_ok(mmdb->metadata.record_size, "==", 24, "record_size is 24 - %s",
|
cmp_ok(mmdb->metadata.record_size,
|
||||||
|
"==",
|
||||||
|
24,
|
||||||
|
"record_size is 24 - %s",
|
||||||
mode_desc);
|
mode_desc);
|
||||||
cmp_ok(mmdb->metadata.ip_version, "==", 4, "ip_version is 4 - %s",
|
cmp_ok(
|
||||||
mode_desc);
|
mmdb->metadata.ip_version, "==", 4, "ip_version is 4 - %s", mode_desc);
|
||||||
is(mmdb->metadata.database_type, "Test", "database_type is Test - %s",
|
is(mmdb->metadata.database_type,
|
||||||
|
"Test",
|
||||||
|
"database_type is Test - %s",
|
||||||
mode_desc);
|
mode_desc);
|
||||||
// 2013-07-01T00:00:00Z
|
// 2013-07-01T00:00:00Z
|
||||||
uint64_t expect_epoch = 1372636800;
|
uint64_t expect_epoch = 1372636800;
|
||||||
int is_ok =
|
int is_ok = cmp_ok(mmdb->metadata.build_epoch,
|
||||||
cmp_ok(mmdb->metadata.build_epoch, ">=", expect_epoch,
|
">=",
|
||||||
"build_epoch > %lli", expect_epoch);
|
expect_epoch,
|
||||||
|
"build_epoch > %lli",
|
||||||
|
expect_epoch);
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
diag(" epoch is %lli", mmdb->metadata.build_epoch);
|
diag(" epoch is %lli", mmdb->metadata.build_epoch);
|
||||||
}
|
}
|
||||||
|
|
||||||
cmp_ok(mmdb->metadata.binary_format_major_version, "==", 2,
|
cmp_ok(mmdb->metadata.binary_format_major_version,
|
||||||
"binary_format_major_version is 2 - %s", mode_desc);
|
"==",
|
||||||
cmp_ok(mmdb->metadata.binary_format_minor_version, "==", 0,
|
2,
|
||||||
"binary_format_minor_version is 0 - %s", mode_desc);
|
"binary_format_major_version is 2 - %s",
|
||||||
|
|
||||||
cmp_ok(mmdb->metadata.languages.count, "==", 2, "found 2 languages - %s",
|
|
||||||
mode_desc);
|
mode_desc);
|
||||||
is(mmdb->metadata.languages.names[0], "en", "first language is en - %s",
|
cmp_ok(mmdb->metadata.binary_format_minor_version,
|
||||||
|
"==",
|
||||||
|
0,
|
||||||
|
"binary_format_minor_version is 0 - %s",
|
||||||
|
mode_desc);
|
||||||
|
|
||||||
|
cmp_ok(mmdb->metadata.languages.count,
|
||||||
|
"==",
|
||||||
|
2,
|
||||||
|
"found 2 languages - %s",
|
||||||
|
mode_desc);
|
||||||
|
is(mmdb->metadata.languages.names[0],
|
||||||
|
"en",
|
||||||
|
"first language is en - %s",
|
||||||
mode_desc);
|
mode_desc);
|
||||||
is(mmdb->metadata.languages.names[1], "zh", "second language is zh - %s",
|
is(mmdb->metadata.languages.names[1],
|
||||||
|
"zh",
|
||||||
|
"second language is zh - %s",
|
||||||
mode_desc);
|
mode_desc);
|
||||||
|
|
||||||
cmp_ok(mmdb->metadata.description.count, "==", 2,
|
cmp_ok(mmdb->metadata.description.count,
|
||||||
"found 2 descriptions - %s", mode_desc);
|
"==",
|
||||||
|
2,
|
||||||
|
"found 2 descriptions - %s",
|
||||||
|
mode_desc);
|
||||||
for (uint16_t i = 0; i < mmdb->metadata.description.count; i++) {
|
for (uint16_t i = 0; i < mmdb->metadata.description.count; i++) {
|
||||||
const char *language =
|
const char *language =
|
||||||
mmdb->metadata.description.descriptions[i]->language;
|
mmdb->metadata.description.descriptions[i]->language;
|
||||||
@ -45,34 +70,45 @@ void test_metadata(MMDB_s *mmdb, const char *mode_desc)
|
|||||||
ok(1, "found zh description");
|
ok(1, "found zh description");
|
||||||
is(description, "Test Database Chinese", "zh description");
|
is(description, "Test Database Chinese", "zh description");
|
||||||
} else {
|
} else {
|
||||||
ok(0, "found unknown description in unexpected language - %s",
|
ok(0,
|
||||||
|
"found unknown description in unexpected language - %s",
|
||||||
language);
|
language);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cmp_ok(mmdb->full_record_byte_size, "==", 6,
|
cmp_ok(mmdb->full_record_byte_size,
|
||||||
"full_record_byte_size is 6 - %s", mode_desc);
|
"==",
|
||||||
|
6,
|
||||||
|
"full_record_byte_size is 6 - %s",
|
||||||
|
mode_desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_languages_value(MMDB_entry_data_list_s
|
MMDB_entry_data_list_s *
|
||||||
*entry_data_list)
|
test_languages_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *languages = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *languages = entry_data_list = entry_data_list->next;
|
||||||
|
|
||||||
cmp_ok(languages->entry_data.type, "==", MMDB_DATA_TYPE_ARRAY,
|
cmp_ok(languages->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_ARRAY,
|
||||||
"'languages' key's value is an array");
|
"'languages' key's value is an array");
|
||||||
cmp_ok(languages->entry_data.data_size, "==", 2,
|
cmp_ok(languages->entry_data.data_size,
|
||||||
|
"==",
|
||||||
|
2,
|
||||||
"'languages' key's value has 2 elements");
|
"'languages' key's value has 2 elements");
|
||||||
|
|
||||||
MMDB_entry_data_list_s *idx0 = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *idx0 = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(idx0->entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
cmp_ok(idx0->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"first array entry is a UTF8_STRING");
|
"first array entry is a UTF8_STRING");
|
||||||
const char *lang0 = dup_entry_string_or_bail(idx0->entry_data);
|
const char *lang0 = dup_entry_string_or_bail(idx0->entry_data);
|
||||||
is(lang0, "en", "first language is en");
|
is(lang0, "en", "first language is en");
|
||||||
free((void *)lang0);
|
free((void *)lang0);
|
||||||
|
|
||||||
MMDB_entry_data_list_s *idx1 = entry_data_list = entry_data_list->next;
|
MMDB_entry_data_list_s *idx1 = entry_data_list = entry_data_list->next;
|
||||||
cmp_ok(idx1->entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
cmp_ok(idx1->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"second array entry is a UTF8_STRING");
|
"second array entry is a UTF8_STRING");
|
||||||
const char *lang1 = dup_entry_string_or_bail(idx1->entry_data);
|
const char *lang1 = dup_entry_string_or_bail(idx1->entry_data);
|
||||||
is(lang1, "zh", "second language is zh");
|
is(lang1, "zh", "second language is zh");
|
||||||
@ -81,36 +117,41 @@ MMDB_entry_data_list_s *test_languages_value(MMDB_entry_data_list_s
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
MMDB_entry_data_list_s *test_description_value(
|
MMDB_entry_data_list_s *
|
||||||
MMDB_entry_data_list_s *entry_data_list)
|
test_description_value(MMDB_entry_data_list_s *entry_data_list) {
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *description = entry_data_list =
|
MMDB_entry_data_list_s *description = entry_data_list =
|
||||||
entry_data_list->next;
|
entry_data_list->next;
|
||||||
cmp_ok(description->entry_data.type, "==", MMDB_DATA_TYPE_MAP,
|
cmp_ok(description->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_MAP,
|
||||||
"'description' key's value is a map");
|
"'description' key's value is a map");
|
||||||
cmp_ok(description->entry_data.data_size, "==", 2,
|
cmp_ok(description->entry_data.data_size,
|
||||||
|
"==",
|
||||||
|
2,
|
||||||
"'description' key's value has 2 key/value pairs");
|
"'description' key's value has 2 key/value pairs");
|
||||||
|
|
||||||
for (int i = 0; i < 2; i++) {
|
for (int i = 0; i < 2; i++) {
|
||||||
MMDB_entry_data_list_s *key = entry_data_list =
|
MMDB_entry_data_list_s *key = entry_data_list = entry_data_list->next;
|
||||||
entry_data_list->next;
|
cmp_ok(key->entry_data.type,
|
||||||
cmp_ok(key->entry_data.type, "==",
|
"==",
|
||||||
MMDB_DATA_TYPE_UTF8_STRING,
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"found a map key in 'map'");
|
"found a map key in 'map'");
|
||||||
const char *key_name = dup_entry_string_or_bail(key->entry_data);
|
const char *key_name = dup_entry_string_or_bail(key->entry_data);
|
||||||
|
|
||||||
MMDB_entry_data_list_s *value = entry_data_list =
|
MMDB_entry_data_list_s *value = entry_data_list = entry_data_list->next;
|
||||||
entry_data_list->next;
|
cmp_ok(value->entry_data.type,
|
||||||
cmp_ok(value->entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"map value is a UTF8_STRING");
|
"map value is a UTF8_STRING");
|
||||||
const char *description =
|
const char *description = dup_entry_string_or_bail(value->entry_data);
|
||||||
dup_entry_string_or_bail(value->entry_data);
|
|
||||||
|
|
||||||
if (strcmp(key_name, "en") == 0) {
|
if (strcmp(key_name, "en") == 0) {
|
||||||
is(description, "Test Database",
|
is(description,
|
||||||
|
"Test Database",
|
||||||
"en description == 'Test Database'");
|
"en description == 'Test Database'");
|
||||||
} else if (strcmp(key_name, "zh") == 0) {
|
} else if (strcmp(key_name, "zh") == 0) {
|
||||||
is(description, "Test Database Chinese",
|
is(description,
|
||||||
|
"Test Database Chinese",
|
||||||
"zh description == 'Test Database Chinese'");
|
"zh description == 'Test Database Chinese'");
|
||||||
} else {
|
} else {
|
||||||
ok(0, "unknown key found in description map - %s", key_name);
|
ok(0, "unknown key found in description map - %s", key_name);
|
||||||
@ -123,63 +164,70 @@ MMDB_entry_data_list_s *test_description_value(
|
|||||||
return entry_data_list;
|
return entry_data_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_metadata_as_data_entry_list(MMDB_s * mmdb,
|
void test_metadata_as_data_entry_list(MMDB_s *mmdb, const char *mode_desc) {
|
||||||
const char *mode_desc)
|
|
||||||
{
|
|
||||||
MMDB_entry_data_list_s *entry_data_list, *first;
|
MMDB_entry_data_list_s *entry_data_list, *first;
|
||||||
int status =
|
int status = MMDB_get_metadata_as_entry_data_list(mmdb, &entry_data_list);
|
||||||
MMDB_get_metadata_as_entry_data_list(mmdb, &entry_data_list);
|
|
||||||
|
|
||||||
first = entry_data_list;
|
first = entry_data_list;
|
||||||
|
|
||||||
cmp_ok(status, "==", MMDB_SUCCESS, "get metadata as data_entry_list - %s",
|
cmp_ok(status,
|
||||||
|
"==",
|
||||||
|
MMDB_SUCCESS,
|
||||||
|
"get metadata as data_entry_list - %s",
|
||||||
mode_desc);
|
mode_desc);
|
||||||
|
|
||||||
cmp_ok(first->entry_data.data_size, "==", 9,
|
cmp_ok(first->entry_data.data_size,
|
||||||
|
"==",
|
||||||
|
9,
|
||||||
"metadata map has 9 key/value pairs");
|
"metadata map has 9 key/value pairs");
|
||||||
|
|
||||||
while (1) {
|
while (1) {
|
||||||
MMDB_entry_data_list_s *key = entry_data_list =
|
MMDB_entry_data_list_s *key = entry_data_list = entry_data_list->next;
|
||||||
entry_data_list->next;
|
|
||||||
|
|
||||||
if (!key) {
|
if (!key) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
cmp_ok(key->entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
cmp_ok(key->entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"found a map key");
|
"found a map key");
|
||||||
|
|
||||||
const char *key_name = dup_entry_string_or_bail(key->entry_data);
|
const char *key_name = dup_entry_string_or_bail(key->entry_data);
|
||||||
if (strcmp(key_name, "node_count") == 0) {
|
if (strcmp(key_name, "node_count") == 0) {
|
||||||
MMDB_entry_data_list_s *value
|
MMDB_entry_data_list_s *value = entry_data_list =
|
||||||
= entry_data_list = entry_data_list->next;
|
entry_data_list->next;
|
||||||
cmp_ok(value->entry_data.uint32, "==", 37, "node_count == 37");
|
cmp_ok(value->entry_data.uint32, "==", 37, "node_count == 37");
|
||||||
} else if (strcmp(key_name, "record_size") == 0) {
|
} else if (strcmp(key_name, "record_size") == 0) {
|
||||||
MMDB_entry_data_list_s *value
|
MMDB_entry_data_list_s *value = entry_data_list =
|
||||||
= entry_data_list = entry_data_list->next;
|
entry_data_list->next;
|
||||||
cmp_ok(value->entry_data.uint16, "==", 24, "record_size == 24");
|
cmp_ok(value->entry_data.uint16, "==", 24, "record_size == 24");
|
||||||
} else if (strcmp(key_name, "ip_version") == 0) {
|
} else if (strcmp(key_name, "ip_version") == 0) {
|
||||||
MMDB_entry_data_list_s *value
|
MMDB_entry_data_list_s *value = entry_data_list =
|
||||||
= entry_data_list = entry_data_list->next;
|
entry_data_list->next;
|
||||||
cmp_ok(value->entry_data.uint16, "==", 4, "ip_version == 4");
|
cmp_ok(value->entry_data.uint16, "==", 4, "ip_version == 4");
|
||||||
} else if (strcmp(key_name, "binary_format_major_version") == 0) {
|
} else if (strcmp(key_name, "binary_format_major_version") == 0) {
|
||||||
MMDB_entry_data_list_s *value
|
MMDB_entry_data_list_s *value = entry_data_list =
|
||||||
= entry_data_list = entry_data_list->next;
|
entry_data_list->next;
|
||||||
cmp_ok(value->entry_data.uint16, "==", 2,
|
cmp_ok(value->entry_data.uint16,
|
||||||
|
"==",
|
||||||
|
2,
|
||||||
"binary_format_major_version == 2");
|
"binary_format_major_version == 2");
|
||||||
} else if (strcmp(key_name, "binary_format_minor_version") == 0) {
|
} else if (strcmp(key_name, "binary_format_minor_version") == 0) {
|
||||||
MMDB_entry_data_list_s *value
|
MMDB_entry_data_list_s *value = entry_data_list =
|
||||||
= entry_data_list = entry_data_list->next;
|
entry_data_list->next;
|
||||||
cmp_ok(value->entry_data.uint16, "==", 0,
|
cmp_ok(value->entry_data.uint16,
|
||||||
|
"==",
|
||||||
|
0,
|
||||||
"binary_format_minor_version == 0");
|
"binary_format_minor_version == 0");
|
||||||
} else if (strcmp(key_name, "build_epoch") == 0) {
|
} else if (strcmp(key_name, "build_epoch") == 0) {
|
||||||
MMDB_entry_data_list_s *value
|
MMDB_entry_data_list_s *value = entry_data_list =
|
||||||
= entry_data_list = entry_data_list->next;
|
entry_data_list->next;
|
||||||
ok(value->entry_data.uint64 > 1373571901,
|
ok(value->entry_data.uint64 > 1373571901,
|
||||||
"build_epoch > 1373571901");
|
"build_epoch > 1373571901");
|
||||||
} else if (strcmp(key_name, "database_type") == 0) {
|
} else if (strcmp(key_name, "database_type") == 0) {
|
||||||
MMDB_entry_data_list_s *value
|
MMDB_entry_data_list_s *value = entry_data_list =
|
||||||
= entry_data_list = entry_data_list->next;
|
entry_data_list->next;
|
||||||
const char *type = dup_entry_string_or_bail(value->entry_data);
|
const char *type = dup_entry_string_or_bail(value->entry_data);
|
||||||
is(type, "Test", "type == Test");
|
is(type, "Test", "type == Test");
|
||||||
free((void *)type);
|
free((void *)type);
|
||||||
@ -188,8 +236,7 @@ void test_metadata_as_data_entry_list(MMDB_s * mmdb,
|
|||||||
} else if (strcmp(key_name, "description") == 0) {
|
} else if (strcmp(key_name, "description") == 0) {
|
||||||
entry_data_list = test_description_value(entry_data_list);
|
entry_data_list = test_description_value(entry_data_list);
|
||||||
} else {
|
} else {
|
||||||
ok(0, "unknown key found in metadata map - %s",
|
ok(0, "unknown key found in metadata map - %s", key_name);
|
||||||
key_name);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
free((void *)key_name);
|
free((void *)key_name);
|
||||||
@ -198,8 +245,7 @@ void test_metadata_as_data_entry_list(MMDB_s * mmdb,
|
|||||||
MMDB_free_entry_data_list(first);
|
MMDB_free_entry_data_list(first);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *file = "MaxMind-DB-test-ipv4-24.mmdb";
|
const char *file = "MaxMind-DB-test-ipv4-24.mmdb";
|
||||||
const char *path = test_database_path(file);
|
const char *path = test_database_path(file);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -218,8 +264,7 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
14
vendor/MaxmindDB/t/no_map_get_value_t.c
vendored
14
vendor/MaxmindDB/t/no_map_get_value_t.c
vendored
@ -1,7 +1,6 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-string-value-entries.mmdb";
|
const char *filename = "MaxMind-DB-string-value-entries.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
@ -14,18 +13,21 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
int status = MMDB_get_value(&result.entry, &entry_data, NULL);
|
int status = MMDB_get_value(&result.entry, &entry_data, NULL);
|
||||||
|
|
||||||
cmp_ok(status, "==", MMDB_SUCCESS,
|
cmp_ok(status,
|
||||||
|
"==",
|
||||||
|
MMDB_SUCCESS,
|
||||||
"status for MMDB_get_value() is MMDB_SUCCESS");
|
"status for MMDB_get_value() is MMDB_SUCCESS");
|
||||||
ok(entry_data.has_data, "found a value when varargs list is just NULL");
|
ok(entry_data.has_data, "found a value when varargs list is just NULL");
|
||||||
cmp_ok(entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
cmp_ok(entry_data.type,
|
||||||
|
"==",
|
||||||
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
"returned entry type is utf8_string");
|
"returned entry type is utf8_string");
|
||||||
|
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
257
vendor/MaxmindDB/t/read_node_t.c
vendored
257
vendor/MaxmindDB/t/read_node_t.c
vendored
@ -1,50 +1,64 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
void test_entry_data(MMDB_s *mmdb, MMDB_entry_s *entry, uint32_t node_number,
|
void test_entry_data(MMDB_s *mmdb,
|
||||||
char * node_record)
|
MMDB_entry_s *entry,
|
||||||
{
|
uint32_t node_number,
|
||||||
|
char *node_record) {
|
||||||
MMDB_entry_data_s entry_data;
|
MMDB_entry_data_s entry_data;
|
||||||
int status =
|
int status = MMDB_get_value(entry, &entry_data, "ip", NULL);
|
||||||
MMDB_get_value(entry, &entry_data, "ip",
|
cmp_ok(status, "==", MMDB_SUCCESS, "successful data lookup for node");
|
||||||
NULL);
|
cmp_ok(entry_data.type,
|
||||||
cmp_ok(status, "==", MMDB_SUCCESS,
|
"==",
|
||||||
"successful data lookup for node");
|
MMDB_DATA_TYPE_UTF8_STRING,
|
||||||
cmp_ok(
|
"returned entry type is UTF8_STRING for %s record of node %i",
|
||||||
entry_data.type, "==", MMDB_DATA_TYPE_UTF8_STRING,
|
node_record,
|
||||||
"returned entry type is UTF8_STRING for %s record of node %i",
|
node_number);
|
||||||
node_record, node_number);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_read_node_tests(MMDB_s *mmdb, const uint32_t tests[][5],
|
void run_read_node_tests(MMDB_s *mmdb,
|
||||||
|
const uint32_t tests[][5],
|
||||||
int test_count,
|
int test_count,
|
||||||
uint8_t record_size)
|
uint8_t record_size) {
|
||||||
{
|
|
||||||
for (int i = 0; i < test_count; i++) {
|
for (int i = 0; i < test_count; i++) {
|
||||||
uint32_t node_number = tests[i][0];
|
uint32_t node_number = tests[i][0];
|
||||||
MMDB_search_node_s node;
|
MMDB_search_node_s node;
|
||||||
int status = MMDB_read_node(mmdb, node_number, &node);
|
int status = MMDB_read_node(mmdb, node_number, &node);
|
||||||
if (MMDB_SUCCESS == status) {
|
if (MMDB_SUCCESS == status) {
|
||||||
cmp_ok(node.left_record, "==", tests[i][1],
|
cmp_ok(node.left_record,
|
||||||
|
"==",
|
||||||
|
tests[i][1],
|
||||||
"left record for node %i is %i - %i bit DB",
|
"left record for node %i is %i - %i bit DB",
|
||||||
node_number, tests[i][1], record_size);
|
node_number,
|
||||||
cmp_ok(node.left_record_type, "==", tests[i][2],
|
tests[i][1],
|
||||||
"left record type for node %i is %i", node_number,
|
record_size);
|
||||||
|
cmp_ok(node.left_record_type,
|
||||||
|
"==",
|
||||||
|
tests[i][2],
|
||||||
|
"left record type for node %i is %i",
|
||||||
|
node_number,
|
||||||
tests[i][2]);
|
tests[i][2]);
|
||||||
if (node.left_record_type == MMDB_RECORD_TYPE_DATA) {
|
if (node.left_record_type == MMDB_RECORD_TYPE_DATA) {
|
||||||
test_entry_data(mmdb, &node.left_record_entry, node_number,
|
test_entry_data(
|
||||||
"left");
|
mmdb, &node.left_record_entry, node_number, "left");
|
||||||
}
|
}
|
||||||
|
|
||||||
cmp_ok(node.right_record, "==", tests[i][3],
|
cmp_ok(node.right_record,
|
||||||
|
"==",
|
||||||
|
tests[i][3],
|
||||||
"right record for node %i is %i - %i bit DB",
|
"right record for node %i is %i - %i bit DB",
|
||||||
node_number, tests[i][3], record_size);
|
node_number,
|
||||||
cmp_ok(node.right_record_type, "==", tests[i][4],
|
tests[i][3],
|
||||||
"right record type for node %i is %i", node_number,
|
record_size);
|
||||||
|
cmp_ok(node.right_record_type,
|
||||||
|
"==",
|
||||||
|
tests[i][4],
|
||||||
|
"right record type for node %i is %i",
|
||||||
|
node_number,
|
||||||
tests[i][4]);
|
tests[i][4]);
|
||||||
|
|
||||||
if (node.right_record_type == MMDB_RECORD_TYPE_DATA) {
|
if (node.right_record_type == MMDB_RECORD_TYPE_DATA) {
|
||||||
test_entry_data(mmdb, &node.right_record_entry, node_number,
|
test_entry_data(
|
||||||
"right");
|
mmdb, &node.right_record_entry, node_number, "right");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
diag("call to MMDB_read_node for node %i failed - %i bit DB",
|
diag("call to MMDB_read_node for node %i failed - %i bit DB",
|
||||||
@ -54,87 +68,168 @@ void run_read_node_tests(MMDB_s *mmdb, const uint32_t tests[][5],
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_24_bit_record_tests(int mode, const char *mode_desc)
|
void run_24_bit_record_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-mixed-24.mmdb";
|
const char *filename = "MaxMind-DB-test-mixed-24.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
free((void *)path);
|
free((void *)path);
|
||||||
|
|
||||||
const uint32_t tests[7][5] = {
|
const uint32_t tests[7][5] = {
|
||||||
{ 0, 1, MMDB_RECORD_TYPE_SEARCH_NODE, 242,
|
{0, 1, MMDB_RECORD_TYPE_SEARCH_NODE, 242, MMDB_RECORD_TYPE_EMPTY},
|
||||||
MMDB_RECORD_TYPE_EMPTY },
|
{
|
||||||
{ 80, 81, MMDB_RECORD_TYPE_SEARCH_NODE, 197,
|
80,
|
||||||
MMDB_RECORD_TYPE_SEARCH_NODE, },
|
81,
|
||||||
{ 96, 97, MMDB_RECORD_TYPE_SEARCH_NODE, 242,
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
MMDB_RECORD_TYPE_EMPTY, },
|
197,
|
||||||
{ 103, 242, MMDB_RECORD_TYPE_EMPTY, 104,
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
MMDB_RECORD_TYPE_SEARCH_NODE, },
|
},
|
||||||
{ 127, 242, MMDB_RECORD_TYPE_EMPTY, 315,
|
{
|
||||||
MMDB_RECORD_TYPE_DATA, },
|
96,
|
||||||
{ 132, 329, MMDB_RECORD_TYPE_DATA, 242,
|
97,
|
||||||
MMDB_RECORD_TYPE_EMPTY, },
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
{ 241, 96, MMDB_RECORD_TYPE_SEARCH_NODE, 242,
|
242,
|
||||||
MMDB_RECORD_TYPE_EMPTY, }
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
};
|
},
|
||||||
|
{
|
||||||
|
103,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
104,
|
||||||
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
127,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
315,
|
||||||
|
MMDB_RECORD_TYPE_DATA,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
132,
|
||||||
|
329,
|
||||||
|
MMDB_RECORD_TYPE_DATA,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
241,
|
||||||
|
96,
|
||||||
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
}};
|
||||||
run_read_node_tests(mmdb, tests, 7, 24);
|
run_read_node_tests(mmdb, tests, 7, 24);
|
||||||
|
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_28_bit_record_tests(int mode, const char *mode_desc)
|
void run_28_bit_record_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-mixed-28.mmdb";
|
const char *filename = "MaxMind-DB-test-mixed-28.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
free((void *)path);
|
free((void *)path);
|
||||||
|
|
||||||
const uint32_t tests[7][5] = {
|
const uint32_t tests[7][5] = {
|
||||||
{ 0, 1, MMDB_RECORD_TYPE_SEARCH_NODE, 242,
|
{0, 1, MMDB_RECORD_TYPE_SEARCH_NODE, 242, MMDB_RECORD_TYPE_EMPTY},
|
||||||
MMDB_RECORD_TYPE_EMPTY },
|
{
|
||||||
{ 80, 81, MMDB_RECORD_TYPE_SEARCH_NODE, 197,
|
80,
|
||||||
MMDB_RECORD_TYPE_SEARCH_NODE, },
|
81,
|
||||||
{ 96, 97, MMDB_RECORD_TYPE_SEARCH_NODE, 242,
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
MMDB_RECORD_TYPE_EMPTY, },
|
197,
|
||||||
{ 103, 242, MMDB_RECORD_TYPE_EMPTY, 104,
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
MMDB_RECORD_TYPE_SEARCH_NODE, },
|
},
|
||||||
{ 127, 242, MMDB_RECORD_TYPE_EMPTY, 315,
|
{
|
||||||
MMDB_RECORD_TYPE_DATA, },
|
96,
|
||||||
{ 132, 329, MMDB_RECORD_TYPE_DATA, 242,
|
97,
|
||||||
MMDB_RECORD_TYPE_EMPTY, },
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
{ 241, 96, MMDB_RECORD_TYPE_SEARCH_NODE, 242,
|
242,
|
||||||
MMDB_RECORD_TYPE_EMPTY, }
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
};
|
},
|
||||||
|
{
|
||||||
|
103,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
104,
|
||||||
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
127,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
315,
|
||||||
|
MMDB_RECORD_TYPE_DATA,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
132,
|
||||||
|
329,
|
||||||
|
MMDB_RECORD_TYPE_DATA,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
241,
|
||||||
|
96,
|
||||||
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
}};
|
||||||
run_read_node_tests(mmdb, tests, 7, 28);
|
run_read_node_tests(mmdb, tests, 7, 28);
|
||||||
|
|
||||||
MMDB_close(mmdb);
|
MMDB_close(mmdb);
|
||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_32_bit_record_tests(int mode, const char *mode_desc)
|
void run_32_bit_record_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-mixed-32.mmdb";
|
const char *filename = "MaxMind-DB-test-mixed-32.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
free((void *)path);
|
free((void *)path);
|
||||||
|
|
||||||
const uint32_t tests[7][5] = {
|
const uint32_t tests[7][5] = {
|
||||||
{ 0, 1, MMDB_RECORD_TYPE_SEARCH_NODE, 242,
|
{0, 1, MMDB_RECORD_TYPE_SEARCH_NODE, 242, MMDB_RECORD_TYPE_EMPTY},
|
||||||
MMDB_RECORD_TYPE_EMPTY },
|
{
|
||||||
{ 80, 81, MMDB_RECORD_TYPE_SEARCH_NODE, 197,
|
80,
|
||||||
MMDB_RECORD_TYPE_SEARCH_NODE, },
|
81,
|
||||||
{ 96, 97, MMDB_RECORD_TYPE_SEARCH_NODE, 242,
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
MMDB_RECORD_TYPE_EMPTY, },
|
197,
|
||||||
{ 103, 242, MMDB_RECORD_TYPE_EMPTY, 104,
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
MMDB_RECORD_TYPE_SEARCH_NODE, },
|
},
|
||||||
{ 127, 242, MMDB_RECORD_TYPE_EMPTY, 315,
|
{
|
||||||
MMDB_RECORD_TYPE_DATA, },
|
96,
|
||||||
{ 132, 329, MMDB_RECORD_TYPE_DATA, 242,
|
97,
|
||||||
MMDB_RECORD_TYPE_EMPTY, },
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
{ 241, 96, MMDB_RECORD_TYPE_SEARCH_NODE, 242,
|
242,
|
||||||
MMDB_RECORD_TYPE_EMPTY, }
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
};
|
},
|
||||||
|
{
|
||||||
|
103,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
104,
|
||||||
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
127,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
315,
|
||||||
|
MMDB_RECORD_TYPE_DATA,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
132,
|
||||||
|
329,
|
||||||
|
MMDB_RECORD_TYPE_DATA,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
241,
|
||||||
|
96,
|
||||||
|
MMDB_RECORD_TYPE_SEARCH_NODE,
|
||||||
|
242,
|
||||||
|
MMDB_RECORD_TYPE_EMPTY,
|
||||||
|
}};
|
||||||
|
|
||||||
run_read_node_tests(mmdb, tests, 7, 32);
|
run_read_node_tests(mmdb, tests, 7, 32);
|
||||||
|
|
||||||
@ -142,15 +237,13 @@ void run_32_bit_record_tests(int mode, const char *mode_desc)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
run_24_bit_record_tests(mode, mode_desc);
|
run_24_bit_record_tests(mode, mode_desc);
|
||||||
run_28_bit_record_tests(mode, mode_desc);
|
run_28_bit_record_tests(mode, mode_desc);
|
||||||
run_32_bit_record_tests(mode, mode_desc);
|
run_32_bit_record_tests(mode, mode_desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
106
vendor/MaxmindDB/t/threads_t.c
vendored
106
vendor/MaxmindDB/t/threads_t.c
vendored
@ -17,8 +17,7 @@ typedef struct test_result {
|
|||||||
char *data_value;
|
char *data_value;
|
||||||
} test_result_s;
|
} test_result_s;
|
||||||
|
|
||||||
void test_one_ip(MMDB_s *mmdb, const char *ip, test_result_s *test_result)
|
void test_one_ip(MMDB_s *mmdb, const char *ip, test_result_s *test_result) {
|
||||||
{
|
|
||||||
|
|
||||||
test_result->ip_looked_up = ip;
|
test_result->ip_looked_up = ip;
|
||||||
|
|
||||||
@ -60,66 +59,77 @@ void test_one_ip(MMDB_s *mmdb, const char *ip, test_result_s *test_result)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
void *run_one_thread(void *arg)
|
void *run_one_thread(void *arg) {
|
||||||
{
|
|
||||||
thread_arg_s *thread_arg = (thread_arg_s *)arg;
|
thread_arg_s *thread_arg = (thread_arg_s *)arg;
|
||||||
|
|
||||||
MMDB_s *mmdb = thread_arg->mmdb;
|
MMDB_s *mmdb = thread_arg->mmdb;
|
||||||
const char *ip = thread_arg->ip_to_lookup;
|
const char *ip = thread_arg->ip_to_lookup;
|
||||||
|
|
||||||
test_result_s *result = malloc(sizeof(test_result_s));
|
test_result_s *result = malloc(sizeof(test_result_s));
|
||||||
|
if (!result) {
|
||||||
|
BAIL_OUT("could not allocate memory");
|
||||||
|
}
|
||||||
test_one_ip(mmdb, ip, result);
|
test_one_ip(mmdb, ip, result);
|
||||||
|
|
||||||
pthread_exit((void *)result);
|
pthread_exit((void *)result);
|
||||||
}
|
}
|
||||||
|
|
||||||
void process_result(test_result_s *result, const char *expect,
|
void process_result(test_result_s *result,
|
||||||
const char *mode_desc)
|
const char *expect,
|
||||||
{
|
const char *mode_desc) {
|
||||||
int is_ok;
|
int is_ok;
|
||||||
is_ok =
|
is_ok = ok(!result->lookup_string_gai_error,
|
||||||
ok(!result->lookup_string_gai_error, "no getaddrinfo error for %s - %s",
|
"no getaddrinfo error for %s - %s",
|
||||||
result->ip_looked_up, mode_desc);
|
result->ip_looked_up,
|
||||||
|
mode_desc);
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
is_ok = ok(!result->lookup_string_mmdb_error, "no mmdb error for %s - %s",
|
is_ok = ok(!result->lookup_string_mmdb_error,
|
||||||
result->ip_looked_up, mode_desc);
|
"no mmdb error for %s - %s",
|
||||||
|
result->ip_looked_up,
|
||||||
|
mode_desc);
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
is_ok = ok(result->found_entry, "got a result for %s in the database - %s",
|
is_ok = ok(result->found_entry,
|
||||||
result->ip_looked_up, mode_desc);
|
"got a result for %s in the database - %s",
|
||||||
|
result->ip_looked_up,
|
||||||
|
mode_desc);
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
is_ok =
|
is_ok = ok(!result->get_value_status,
|
||||||
ok(!result->get_value_status,
|
"no error from MMDB_get_value for %s - %s",
|
||||||
"no error from MMDB_get_value for %s - %s",
|
result->ip_looked_up,
|
||||||
result->ip_looked_up,
|
mode_desc);
|
||||||
mode_desc);
|
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
is_ok = ok(result->data_type_ok,
|
is_ok = ok(result->data_type_ok,
|
||||||
"MMDB_get_value found a utf8_string at 'ip' key for %s - %s",
|
"MMDB_get_value found a utf8_string at 'ip' key for %s - %s",
|
||||||
result->ip_looked_up, mode_desc);
|
result->ip_looked_up,
|
||||||
|
mode_desc);
|
||||||
if (!is_ok) {
|
if (!is_ok) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
is(result->data_value, expect,
|
is(result->data_value,
|
||||||
|
expect,
|
||||||
"found expected result for 'ip' key for %s - %s",
|
"found expected result for 'ip' key for %s - %s",
|
||||||
result->ip_looked_up, mode_desc);
|
result->ip_looked_up,
|
||||||
|
mode_desc);
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_ipX_tests(MMDB_s *mmdb, const char *pairs[][2], int pairs_rows,
|
void run_ipX_tests(MMDB_s *mmdb,
|
||||||
int mode, const char *mode_desc)
|
const char *pairs[][2],
|
||||||
{
|
int pairs_rows,
|
||||||
|
int mode,
|
||||||
|
const char *mode_desc) {
|
||||||
pthread_t threads[pairs_rows];
|
pthread_t threads[pairs_rows];
|
||||||
struct thread_arg thread_args[pairs_rows];
|
struct thread_arg thread_args[pairs_rows];
|
||||||
|
|
||||||
@ -128,8 +138,8 @@ void run_ipX_tests(MMDB_s *mmdb, const char *pairs[][2], int pairs_rows,
|
|||||||
thread_args[i].mmdb = mmdb;
|
thread_args[i].mmdb = mmdb;
|
||||||
thread_args[i].ip_to_lookup = pairs[i][0];
|
thread_args[i].ip_to_lookup = pairs[i][0];
|
||||||
|
|
||||||
int error = pthread_create(&threads[i], NULL, run_one_thread,
|
int error =
|
||||||
&thread_args[i]);
|
pthread_create(&threads[i], NULL, run_one_thread, &thread_args[i]);
|
||||||
if (error) {
|
if (error) {
|
||||||
BAIL_OUT("pthread_create failed");
|
BAIL_OUT("pthread_create failed");
|
||||||
}
|
}
|
||||||
@ -153,32 +163,31 @@ void run_ipX_tests(MMDB_s *mmdb, const char *pairs[][2], int pairs_rows,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_tests(int mode, const char *mode_desc)
|
void run_tests(int mode, const char *mode_desc) {
|
||||||
{
|
|
||||||
const char *filename = "MaxMind-DB-test-mixed-32.mmdb";
|
const char *filename = "MaxMind-DB-test-mixed-32.mmdb";
|
||||||
const char *path = test_database_path(filename);
|
const char *path = test_database_path(filename);
|
||||||
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
MMDB_s *mmdb = open_ok(path, mode, mode_desc);
|
||||||
free((void *)path);
|
free((void *)path);
|
||||||
|
|
||||||
const char *pairs[18][2] = {
|
const char *pairs[18][2] = {
|
||||||
{ "1.1.1.1", "::1.1.1.1" },
|
{"1.1.1.1", "::1.1.1.1"},
|
||||||
{ "1.1.1.2", "::1.1.1.2" },
|
{"1.1.1.2", "::1.1.1.2"},
|
||||||
{ "1.1.1.3", "::1.1.1.2" },
|
{"1.1.1.3", "::1.1.1.2"},
|
||||||
{ "1.1.1.7", "::1.1.1.4" },
|
{"1.1.1.7", "::1.1.1.4"},
|
||||||
{ "1.1.1.9", "::1.1.1.8" },
|
{"1.1.1.9", "::1.1.1.8"},
|
||||||
{ "1.1.1.15", "::1.1.1.8" },
|
{"1.1.1.15", "::1.1.1.8"},
|
||||||
{ "1.1.1.17", "::1.1.1.16" },
|
{"1.1.1.17", "::1.1.1.16"},
|
||||||
{ "1.1.1.31", "::1.1.1.16" },
|
{"1.1.1.31", "::1.1.1.16"},
|
||||||
{ "1.1.1.32", "::1.1.1.32" },
|
{"1.1.1.32", "::1.1.1.32"},
|
||||||
{ "::1:ffff:ffff", "::1:ffff:ffff" },
|
{"::1:ffff:ffff", "::1:ffff:ffff"},
|
||||||
{ "::2:0:0", "::2:0:0" },
|
{"::2:0:0", "::2:0:0"},
|
||||||
{ "::2:0:1a", "::2:0:0" },
|
{"::2:0:1a", "::2:0:0"},
|
||||||
{ "::2:0:40", "::2:0:40" },
|
{"::2:0:40", "::2:0:40"},
|
||||||
{ "::2:0:4f", "::2:0:40" },
|
{"::2:0:4f", "::2:0:40"},
|
||||||
{ "::2:0:50", "::2:0:50" },
|
{"::2:0:50", "::2:0:50"},
|
||||||
{ "::2:0:52", "::2:0:50" },
|
{"::2:0:52", "::2:0:50"},
|
||||||
{ "::2:0:58", "::2:0:58" },
|
{"::2:0:58", "::2:0:58"},
|
||||||
{ "::2:0:59", "::2:0:58" },
|
{"::2:0:59", "::2:0:58"},
|
||||||
};
|
};
|
||||||
|
|
||||||
run_ipX_tests(mmdb, pairs, 18, mode, mode_desc);
|
run_ipX_tests(mmdb, pairs, 18, mode, mode_desc);
|
||||||
@ -187,8 +196,7 @@ void run_tests(int mode, const char *mode_desc)
|
|||||||
free(mmdb);
|
free(mmdb);
|
||||||
}
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
plan(NO_PLAN);
|
plan(NO_PLAN);
|
||||||
for_all_modes(&run_tests);
|
for_all_modes(&run_tests);
|
||||||
done_testing();
|
done_testing();
|
||||||
|
3
vendor/MaxmindDB/t/version_t.c
vendored
3
vendor/MaxmindDB/t/version_t.c
vendored
@ -1,7 +1,6 @@
|
|||||||
#include "maxminddb_test_helper.h"
|
#include "maxminddb_test_helper.h"
|
||||||
|
|
||||||
int main(void)
|
int main(void) {
|
||||||
{
|
|
||||||
const char *version = MMDB_lib_version();
|
const char *version = MMDB_lib_version();
|
||||||
if (ok((version != NULL), "MMDB_lib_version exists")) {
|
if (ok((version != NULL), "MMDB_lib_version exists")) {
|
||||||
is(version, PACKAGE_VERSION, "version is " PACKAGE_VERSION);
|
is(version, PACKAGE_VERSION, "version is " PACKAGE_VERSION);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user