diff options
| author | Mehmet Samet Duman <yongdohyun@projecttick.org> | 2026-04-02 18:42:50 +0300 |
|---|---|---|
| committer | Mehmet Samet Duman <yongdohyun@projecttick.org> | 2026-04-02 18:42:50 +0300 |
| commit | 5fad10f89c485cfdc7b99011f07609f8871160d4 (patch) | |
| tree | 1860b39753b652dfe54d3cbbc80c875f40198d1f /json4cpp/tests/src/unit-assert_macro.cpp | |
| parent | 292baed7ac0cf84263263966ed32ed113cae857f (diff) | |
| parent | 9a737481aed085fd289f82dff1fa8c3c66627a7e (diff) | |
| download | Project-Tick-5fad10f89c485cfdc7b99011f07609f8871160d4.tar.gz Project-Tick-5fad10f89c485cfdc7b99011f07609f8871160d4.zip | |
Add 'json4cpp/' from commit '9a737481aed085fd289f82dff1fa8c3c66627a7e'
git-subtree-dir: json4cpp
git-subtree-mainline: 292baed7ac0cf84263263966ed32ed113cae857f
git-subtree-split: 9a737481aed085fd289f82dff1fa8c3c66627a7e
Diffstat (limited to 'json4cpp/tests/src/unit-assert_macro.cpp')
| -rw-r--r-- | json4cpp/tests/src/unit-assert_macro.cpp | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/json4cpp/tests/src/unit-assert_macro.cpp b/json4cpp/tests/src/unit-assert_macro.cpp new file mode 100644 index 0000000000..adedfc9344 --- /dev/null +++ b/json4cpp/tests/src/unit-assert_macro.cpp @@ -0,0 +1,48 @@ +// __ _____ _____ _____ +// __| | __| | | | JSON for Modern C++ (supporting code) +// | | |__ | | | | | | version 3.12.0 +// |_____|_____|_____|_|___| https://github.com/nlohmann/json +// +// SPDX-FileCopyrightText: 2013-2026 Niels Lohmann <https://nlohmann.me> +// SPDX-License-Identifier: MIT + +#include "doctest_compatibility.h" + +// avoid warning when assert does not abort +DOCTEST_GCC_SUPPRESS_WARNING_PUSH +DOCTEST_GCC_SUPPRESS_WARNING("-Wstrict-overflow") +DOCTEST_CLANG_SUPPRESS_WARNING_PUSH +DOCTEST_CLANG_SUPPRESS_WARNING("-Wstrict-overflow") + +/// global variable to record side effect of assert calls +static int assert_counter; + +/// set failure variable to true instead of calling assert(x) +#define JSON_ASSERT(x) {if (!(x)) ++assert_counter; } + +#include <nlohmann/json.hpp> +using nlohmann::json; + +// the test assumes exceptions to work +#if !defined(JSON_NOEXCEPTION) +TEST_CASE("JSON_ASSERT(x)") +{ + SECTION("basic_json(first, second)") + { + assert_counter = 0; + CHECK(assert_counter == 0); + + const json::iterator it{}; + json j; + + // in case assertions do not abort execution, an exception is thrown + CHECK_THROWS_WITH_AS(json(it, j.end()), "[json.exception.invalid_iterator.201] iterators are not compatible", json::invalid_iterator); + + // check that assertion actually happened + CHECK(assert_counter == 1); + } +} +#endif + +DOCTEST_GCC_SUPPRESS_WARNING_POP +DOCTEST_CLANG_SUPPRESS_WARNING_POP |
