| /* |
| __ _____ _____ _____ |
| __| | __| | | | JSON for Modern C++ (test suite) |
| | | |__ | | | | | | version 3.9.1 |
| |_____|_____|_____|_|___| https://github.com/nlohmann/json |
| |
| Licensed under the MIT License <http://opensource.org/licenses/MIT>. |
| SPDX-License-Identifier: MIT |
| Copyright (c) 2013-2019 Niels Lohmann <http://nlohmann.me>. |
| |
| Permission is hereby granted, free of charge, to any person obtaining a copy |
| of this software and associated documentation files (the "Software"), to deal |
| in the Software without restriction, including without limitation the rights |
| to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
| copies of the Software, and to permit persons to whom the Software is |
| furnished to do so, subject to the following conditions: |
| |
| The above copyright notice and this permission notice shall be included in all |
| copies or substantial portions of the Software. |
| |
| THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
| AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
| OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE |
| SOFTWARE. |
| */ |
| |
| #include "doctest_compatibility.h" |
| |
| #include <nlohmann/json.hpp> |
| using nlohmann::json; |
| |
| TEST_CASE("element access 1") |
| { |
| SECTION("array") |
| { |
| json j = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| const json j_const = j; |
| |
| SECTION("access specified element with bounds checking") |
| { |
| SECTION("access within bounds") |
| { |
| CHECK(j.at(0) == json(1)); |
| CHECK(j.at(1) == json(1u)); |
| CHECK(j.at(2) == json(true)); |
| CHECK(j.at(3) == json(nullptr)); |
| CHECK(j.at(4) == json("string")); |
| CHECK(j.at(5) == json(42.23)); |
| CHECK(j.at(6) == json::object()); |
| CHECK(j.at(7) == json({1, 2, 3})); |
| |
| CHECK(j_const.at(0) == json(1)); |
| CHECK(j_const.at(1) == json(1u)); |
| CHECK(j_const.at(2) == json(true)); |
| CHECK(j_const.at(3) == json(nullptr)); |
| CHECK(j_const.at(4) == json("string")); |
| CHECK(j_const.at(5) == json(42.23)); |
| CHECK(j_const.at(6) == json::object()); |
| CHECK(j_const.at(7) == json({1, 2, 3})); |
| } |
| |
| SECTION("access outside bounds") |
| { |
| CHECK_THROWS_AS(j.at(8), json::out_of_range&); |
| CHECK_THROWS_AS(j_const.at(8), json::out_of_range&); |
| |
| CHECK_THROWS_WITH(j.at(8), |
| "[json.exception.out_of_range.401] array index 8 is out of range"); |
| CHECK_THROWS_WITH(j_const.at(8), |
| "[json.exception.out_of_range.401] array index 8 is out of range"); |
| } |
| |
| SECTION("access on non-array type") |
| { |
| SECTION("null") |
| { |
| json j_nonarray(json::value_t::null); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray.at(0), json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const.at(0), json::type_error&); |
| |
| CHECK_THROWS_WITH(j_nonarray.at(0), "[json.exception.type_error.304] cannot use at() with null"); |
| CHECK_THROWS_WITH(j_nonarray_const.at(0), "[json.exception.type_error.304] cannot use at() with null"); |
| } |
| |
| SECTION("boolean") |
| { |
| json j_nonarray(json::value_t::boolean); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray.at(0), json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const.at(0), json::type_error&); |
| |
| CHECK_THROWS_WITH(j_nonarray.at(0), "[json.exception.type_error.304] cannot use at() with boolean"); |
| CHECK_THROWS_WITH(j_nonarray_const.at(0), "[json.exception.type_error.304] cannot use at() with boolean"); |
| } |
| |
| SECTION("string") |
| { |
| json j_nonarray(json::value_t::string); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray.at(0), json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const.at(0), json::type_error&); |
| |
| CHECK_THROWS_WITH(j_nonarray.at(0), "[json.exception.type_error.304] cannot use at() with string"); |
| CHECK_THROWS_WITH(j_nonarray_const.at(0), "[json.exception.type_error.304] cannot use at() with string"); |
| } |
| |
| SECTION("object") |
| { |
| json j_nonarray(json::value_t::object); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray.at(0), json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const.at(0), json::type_error&); |
| |
| CHECK_THROWS_WITH(j_nonarray.at(0), "[json.exception.type_error.304] cannot use at() with object"); |
| CHECK_THROWS_WITH(j_nonarray_const.at(0), "[json.exception.type_error.304] cannot use at() with object"); |
| } |
| |
| SECTION("number (integer)") |
| { |
| json j_nonarray(json::value_t::number_integer); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray.at(0), json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const.at(0), json::type_error&); |
| |
| CHECK_THROWS_WITH(j_nonarray.at(0), "[json.exception.type_error.304] cannot use at() with number"); |
| CHECK_THROWS_WITH(j_nonarray_const.at(0), "[json.exception.type_error.304] cannot use at() with number"); |
| } |
| |
| SECTION("number (unsigned)") |
| { |
| json j_nonarray(json::value_t::number_unsigned); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray.at(0), json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const.at(0), json::type_error&); |
| |
| CHECK_THROWS_WITH(j_nonarray.at(0), "[json.exception.type_error.304] cannot use at() with number"); |
| CHECK_THROWS_WITH(j_nonarray_const.at(0), "[json.exception.type_error.304] cannot use at() with number"); |
| } |
| |
| SECTION("number (floating-point)") |
| { |
| json j_nonarray(json::value_t::number_float); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray.at(0), json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const.at(0), json::type_error&); |
| |
| CHECK_THROWS_WITH(j_nonarray.at(0), "[json.exception.type_error.304] cannot use at() with number"); |
| CHECK_THROWS_WITH(j_nonarray_const.at(0), "[json.exception.type_error.304] cannot use at() with number"); |
| } |
| } |
| } |
| |
| SECTION("front and back") |
| { |
| CHECK(j.front() == json(1)); |
| CHECK(j_const.front() == json(1)); |
| CHECK(j.back() == json({1, 2, 3})); |
| CHECK(j_const.back() == json({1, 2, 3})); |
| } |
| |
| SECTION("access specified element") |
| { |
| SECTION("access within bounds") |
| { |
| CHECK(j[0] == json(1)); |
| CHECK(j[1] == json(1u)); |
| CHECK(j[2] == json(true)); |
| CHECK(j[3] == json(nullptr)); |
| CHECK(j[4] == json("string")); |
| CHECK(j[5] == json(42.23)); |
| CHECK(j[6] == json::object()); |
| CHECK(j[7] == json({1, 2, 3})); |
| |
| CHECK(j_const[0] == json(1)); |
| CHECK(j_const[1] == json(1u)); |
| CHECK(j_const[2] == json(true)); |
| CHECK(j_const[3] == json(nullptr)); |
| CHECK(j_const[4] == json("string")); |
| CHECK(j_const[5] == json(42.23)); |
| CHECK(j_const[6] == json::object()); |
| CHECK(j_const[7] == json({1, 2, 3})); |
| } |
| |
| SECTION("access on non-array type") |
| { |
| SECTION("null") |
| { |
| SECTION("standard tests") |
| { |
| json j_nonarray(json::value_t::null); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_NOTHROW(j_nonarray[0]); |
| CHECK_THROWS_AS(j_nonarray_const[0], json::type_error&); |
| CHECK_THROWS_WITH(j_nonarray_const[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with null"); |
| } |
| |
| SECTION("implicit transformation to properly filled array") |
| { |
| json j_nonarray; |
| j_nonarray[3] = 42; |
| CHECK(j_nonarray == json({nullptr, nullptr, nullptr, 42})); |
| } |
| } |
| |
| SECTION("boolean") |
| { |
| json j_nonarray(json::value_t::boolean); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray[0], json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const[0], json::type_error&); |
| CHECK_THROWS_WITH(j_nonarray[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with boolean"); |
| CHECK_THROWS_WITH(j_nonarray_const[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with boolean"); |
| } |
| |
| SECTION("string") |
| { |
| json j_nonarray(json::value_t::string); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray[0], json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const[0], json::type_error&); |
| CHECK_THROWS_WITH(j_nonarray[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with string"); |
| CHECK_THROWS_WITH(j_nonarray_const[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with string"); |
| } |
| |
| SECTION("object") |
| { |
| json j_nonarray(json::value_t::object); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray[0], json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const[0], json::type_error&); |
| CHECK_THROWS_WITH(j_nonarray[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with object"); |
| CHECK_THROWS_WITH(j_nonarray_const[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with object"); |
| } |
| |
| SECTION("number (integer)") |
| { |
| json j_nonarray(json::value_t::number_integer); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray[0], json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const[0], json::type_error&); |
| CHECK_THROWS_WITH(j_nonarray[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with number"); |
| CHECK_THROWS_WITH(j_nonarray_const[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with number"); |
| } |
| |
| SECTION("number (unsigned)") |
| { |
| json j_nonarray(json::value_t::number_unsigned); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray[0], json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const[0], json::type_error&); |
| CHECK_THROWS_WITH(j_nonarray[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with number"); |
| CHECK_THROWS_WITH(j_nonarray_const[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with number"); |
| } |
| |
| SECTION("number (floating-point)") |
| { |
| json j_nonarray(json::value_t::number_float); |
| const json j_nonarray_const(j_nonarray); |
| CHECK_THROWS_AS(j_nonarray[0], json::type_error&); |
| CHECK_THROWS_AS(j_nonarray_const[0], json::type_error&); |
| CHECK_THROWS_WITH(j_nonarray[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with number"); |
| CHECK_THROWS_WITH(j_nonarray_const[0], "[json.exception.type_error.305] cannot use operator[] with a numeric argument with number"); |
| } |
| } |
| } |
| |
| SECTION("remove specified element") |
| { |
| SECTION("remove element by index") |
| { |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| jarray.erase(0); |
| CHECK(jarray == json({1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}})); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| jarray.erase(1); |
| CHECK(jarray == json({1, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}})); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| jarray.erase(2); |
| CHECK(jarray == json({1, 1u, nullptr, "string", 42.23, json::object(), {1, 2, 3}})); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| jarray.erase(3); |
| CHECK(jarray == json({1, 1u, true, "string", 42.23, json::object(), {1, 2, 3}})); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| jarray.erase(4); |
| CHECK(jarray == json({1, 1u, true, nullptr, 42.23, json::object(), {1, 2, 3}})); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| jarray.erase(5); |
| CHECK(jarray == json({1, 1u, true, nullptr, "string", json::object(), {1, 2, 3}})); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| jarray.erase(6); |
| CHECK(jarray == json({1, 1u, true, nullptr, "string", 42.23, {1, 2, 3}})); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| jarray.erase(7); |
| CHECK(jarray == json({1, 1u, true, nullptr, "string", 42.23, json::object()})); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| CHECK_THROWS_AS(jarray.erase(8), json::out_of_range&); |
| CHECK_THROWS_WITH(jarray.erase(8), |
| "[json.exception.out_of_range.401] array index 8 is out of range"); |
| } |
| } |
| |
| SECTION("remove element by iterator") |
| { |
| SECTION("erase(begin())") |
| { |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::iterator it2 = jarray.erase(jarray.begin()); |
| CHECK(jarray == json({1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}})); |
| CHECK(*it2 == json(1u)); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::const_iterator it2 = jarray.erase(jarray.cbegin()); |
| CHECK(jarray == json({1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}})); |
| CHECK(*it2 == json(1u)); |
| } |
| } |
| |
| SECTION("erase(begin(), end())") |
| { |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::iterator it2 = jarray.erase(jarray.begin(), jarray.end()); |
| CHECK(jarray == json::array()); |
| CHECK(it2 == jarray.end()); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::const_iterator it2 = jarray.erase(jarray.cbegin(), jarray.cend()); |
| CHECK(jarray == json::array()); |
| CHECK(it2 == jarray.cend()); |
| } |
| } |
| |
| SECTION("erase(begin(), begin())") |
| { |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::iterator it2 = jarray.erase(jarray.begin(), jarray.begin()); |
| CHECK(jarray == json({1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}})); |
| CHECK(*it2 == json(1)); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::const_iterator it2 = jarray.erase(jarray.cbegin(), jarray.cbegin()); |
| CHECK(jarray == json({1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}})); |
| CHECK(*it2 == json(1)); |
| } |
| } |
| |
| SECTION("erase at offset") |
| { |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::iterator it = jarray.begin() + 4; |
| json::iterator it2 = jarray.erase(it); |
| CHECK(jarray == json({1, 1u, true, nullptr, 42.23, json::object(), {1, 2, 3}})); |
| CHECK(*it2 == json(42.23)); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::const_iterator it = jarray.cbegin() + 4; |
| json::const_iterator it2 = jarray.erase(it); |
| CHECK(jarray == json({1, 1u, true, nullptr, 42.23, json::object(), {1, 2, 3}})); |
| CHECK(*it2 == json(42.23)); |
| } |
| } |
| |
| SECTION("erase subrange") |
| { |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::iterator it2 = jarray.erase(jarray.begin() + 3, jarray.begin() + 6); |
| CHECK(jarray == json({1, 1u, true, json::object(), {1, 2, 3}})); |
| CHECK(*it2 == json::object()); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json::const_iterator it2 = jarray.erase(jarray.cbegin() + 3, jarray.cbegin() + 6); |
| CHECK(jarray == json({1, 1u, true, json::object(), {1, 2, 3}})); |
| CHECK(*it2 == json::object()); |
| } |
| } |
| |
| SECTION("different arrays") |
| { |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json jarray2 = {"foo", "bar"}; |
| CHECK_THROWS_AS(jarray.erase(jarray2.begin()), json::invalid_iterator&); |
| CHECK_THROWS_AS(jarray.erase(jarray.begin(), jarray2.end()), json::invalid_iterator&); |
| CHECK_THROWS_AS(jarray.erase(jarray2.begin(), jarray.end()), json::invalid_iterator&); |
| CHECK_THROWS_AS(jarray.erase(jarray2.begin(), jarray2.end()), json::invalid_iterator&); |
| |
| CHECK_THROWS_WITH(jarray.erase(jarray2.begin()), |
| "[json.exception.invalid_iterator.202] iterator does not fit current value"); |
| CHECK_THROWS_WITH(jarray.erase(jarray.begin(), jarray2.end()), |
| "[json.exception.invalid_iterator.203] iterators do not fit current value"); |
| CHECK_THROWS_WITH(jarray.erase(jarray2.begin(), jarray.end()), |
| "[json.exception.invalid_iterator.203] iterators do not fit current value"); |
| CHECK_THROWS_WITH(jarray.erase(jarray2.begin(), jarray2.end()), |
| "[json.exception.invalid_iterator.203] iterators do not fit current value"); |
| } |
| { |
| json jarray = {1, 1u, true, nullptr, "string", 42.23, json::object(), {1, 2, 3}}; |
| json jarray2 = {"foo", "bar"}; |
| CHECK_THROWS_AS(jarray.erase(jarray2.cbegin()), json::invalid_iterator&); |
| CHECK_THROWS_AS(jarray.erase(jarray.cbegin(), jarray2.cend()), json::invalid_iterator&); |
| CHECK_THROWS_AS(jarray.erase(jarray2.cbegin(), jarray.cend()), json::invalid_iterator&); |
| CHECK_THROWS_AS(jarray.erase(jarray2.cbegin(), jarray2.cend()), json::invalid_iterator&); |
| |
| CHECK_THROWS_WITH(jarray.erase(jarray2.cbegin()), |
| "[json.exception.invalid_iterator.202] iterator does not fit current value"); |
| CHECK_THROWS_WITH(jarray.erase(jarray.cbegin(), jarray2.cend()), |
| "[json.exception.invalid_iterator.203] iterators do not fit current value"); |
| CHECK_THROWS_WITH(jarray.erase(jarray2.cbegin(), jarray.cend()), |
| "[json.exception.invalid_iterator.203] iterators do not fit current value"); |
| CHECK_THROWS_WITH(jarray.erase(jarray2.cbegin(), jarray2.cend()), |
| "[json.exception.invalid_iterator.203] iterators do not fit current value"); |
| } |
| } |
| } |
| |
| SECTION("remove element by index in non-array type") |
| { |
| SECTION("null") |
| { |
| json j_nonobject(json::value_t::null); |
| CHECK_THROWS_AS(j_nonobject.erase(0), json::type_error&); |
| CHECK_THROWS_WITH(j_nonobject.erase(0), |
| "[json.exception.type_error.307] cannot use erase() with null"); |
| } |
| |
| SECTION("boolean") |
| { |
| json j_nonobject(json::value_t::boolean); |
| CHECK_THROWS_AS(j_nonobject.erase(0), json::type_error&); |
| CHECK_THROWS_WITH(j_nonobject.erase(0), |
| "[json.exception.type_error.307] cannot use erase() with boolean"); |
| } |
| |
| SECTION("string") |
| { |
| json j_nonobject(json::value_t::string); |
| CHECK_THROWS_AS(j_nonobject.erase(0), json::type_error&); |
| CHECK_THROWS_WITH(j_nonobject.erase(0), |
| "[json.exception.type_error.307] cannot use erase() with string"); |
| } |
| |
| SECTION("object") |
| { |
| json j_nonobject(json::value_t::object); |
| CHECK_THROWS_AS(j_nonobject.erase(0), json::type_error&); |
| CHECK_THROWS_WITH(j_nonobject.erase(0), |
| "[json.exception.type_error.307] cannot use erase() with object"); |
| } |
| |
| SECTION("number (integer)") |
| { |
| json j_nonobject(json::value_t::number_integer); |
| CHECK_THROWS_AS(j_nonobject.erase(0), json::type_error&); |
| CHECK_THROWS_WITH(j_nonobject.erase(0), |
| "[json.exception.type_error.307] cannot use erase() with number"); |
| } |
| |
| SECTION("number (unsigned)") |
| { |
| json j_nonobject(json::value_t::number_unsigned); |
| CHECK_THROWS_AS(j_nonobject.erase(0), json::type_error&); |
| CHECK_THROWS_WITH(j_nonobject.erase(0), |
| "[json.exception.type_error.307] cannot use erase() with number"); |
| } |
| |
| SECTION("number (floating-point)") |
| { |
| json j_nonobject(json::value_t::number_float); |
| CHECK_THROWS_AS(j_nonobject.erase(0), json::type_error&); |
| CHECK_THROWS_WITH(j_nonobject.erase(0), |
| "[json.exception.type_error.307] cannot use erase() with number"); |
| } |
| } |
| } |
| } |
| |
| SECTION("other values") |
| { |
| SECTION("front and back") |
| { |
| SECTION("null") |
| { |
| { |
| json j; |
| CHECK_THROWS_AS(j.front(), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.back(), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.front(), "[json.exception.invalid_iterator.214] cannot get value"); |
| CHECK_THROWS_WITH(j.back(), "[json.exception.invalid_iterator.214] cannot get value"); |
| } |
| { |
| const json j{}; |
| CHECK_THROWS_AS(j.front(), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.back(), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.front(), "[json.exception.invalid_iterator.214] cannot get value"); |
| CHECK_THROWS_WITH(j.back(), "[json.exception.invalid_iterator.214] cannot get value"); |
| } |
| } |
| |
| SECTION("string") |
| { |
| { |
| json j = "foo"; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| { |
| const json j = "bar"; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| } |
| |
| SECTION("number (boolean)") |
| { |
| { |
| json j = false; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| { |
| const json j = true; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| } |
| |
| SECTION("number (integer)") |
| { |
| { |
| json j = 17; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| { |
| const json j = 17; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| } |
| |
| SECTION("number (unsigned)") |
| { |
| { |
| json j = 17u; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| { |
| const json j = 17u; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| } |
| |
| SECTION("number (floating point)") |
| { |
| { |
| json j = 23.42; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| { |
| const json j = 23.42; |
| CHECK(j.front() == j); |
| CHECK(j.back() == j); |
| } |
| } |
| } |
| |
| SECTION("erase with one valid iterator") |
| { |
| SECTION("null") |
| { |
| { |
| json j; |
| CHECK_THROWS_AS(j.erase(j.begin()), json::type_error&); |
| CHECK_THROWS_WITH(j.erase(j.begin()), |
| "[json.exception.type_error.307] cannot use erase() with null"); |
| } |
| { |
| json j; |
| CHECK_THROWS_AS(j.erase(j.cbegin()), json::type_error&); |
| CHECK_THROWS_WITH(j.erase(j.begin()), |
| "[json.exception.type_error.307] cannot use erase() with null"); |
| } |
| } |
| |
| SECTION("string") |
| { |
| { |
| json j = "foo"; |
| json::iterator it = j.erase(j.begin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = "bar"; |
| json::const_iterator it = j.erase(j.cbegin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("number (boolean)") |
| { |
| { |
| json j = false; |
| json::iterator it = j.erase(j.begin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = true; |
| json::const_iterator it = j.erase(j.cbegin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("number (integer)") |
| { |
| { |
| json j = 17; |
| json::iterator it = j.erase(j.begin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = 17; |
| json::const_iterator it = j.erase(j.cbegin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("number (unsigned)") |
| { |
| { |
| json j = 17u; |
| json::iterator it = j.erase(j.begin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = 17u; |
| json::const_iterator it = j.erase(j.cbegin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("number (floating point)") |
| { |
| { |
| json j = 23.42; |
| json::iterator it = j.erase(j.begin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = 23.42; |
| json::const_iterator it = j.erase(j.cbegin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("binary") |
| { |
| { |
| json j = json::binary({1, 2, 3}); |
| json::iterator it = j.erase(j.begin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = json::binary({1, 2, 3}); |
| json::const_iterator it = j.erase(j.cbegin()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| } |
| |
| SECTION("erase with one invalid iterator") |
| { |
| SECTION("string") |
| { |
| { |
| json j = "foo"; |
| CHECK_THROWS_AS(j.erase(j.end()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| { |
| json j = "bar"; |
| CHECK_THROWS_AS(j.erase(j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| } |
| |
| SECTION("number (boolean)") |
| { |
| { |
| json j = false; |
| CHECK_THROWS_AS(j.erase(j.end()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| { |
| json j = true; |
| CHECK_THROWS_AS(j.erase(j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| } |
| |
| SECTION("number (integer)") |
| { |
| { |
| json j = 17; |
| CHECK_THROWS_AS(j.erase(j.end()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| { |
| json j = 17; |
| CHECK_THROWS_AS(j.erase(j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| } |
| |
| SECTION("number (unsigned)") |
| { |
| { |
| json j = 17u; |
| CHECK_THROWS_AS(j.erase(j.end()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| { |
| json j = 17u; |
| CHECK_THROWS_AS(j.erase(j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| } |
| |
| SECTION("number (floating point)") |
| { |
| { |
| json j = 23.42; |
| CHECK_THROWS_AS(j.erase(j.end()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| { |
| json j = 23.42; |
| CHECK_THROWS_AS(j.erase(j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend()), |
| "[json.exception.invalid_iterator.205] iterator out of range"); |
| } |
| } |
| } |
| |
| SECTION("erase with two valid iterators") |
| { |
| SECTION("null") |
| { |
| { |
| json j; |
| CHECK_THROWS_AS(j.erase(j.begin(), j.end()), json::type_error&); |
| CHECK_THROWS_WITH(j.erase(j.begin(), j.end()), |
| "[json.exception.type_error.307] cannot use erase() with null"); |
| } |
| { |
| json j; |
| CHECK_THROWS_AS(j.erase(j.cbegin(), j.cend()), json::type_error&); |
| CHECK_THROWS_WITH(j.erase(j.cbegin(), j.cend()), |
| "[json.exception.type_error.307] cannot use erase() with null"); |
| } |
| } |
| |
| SECTION("string") |
| { |
| { |
| json j = "foo"; |
| json::iterator it = j.erase(j.begin(), j.end()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = "bar"; |
| json::const_iterator it = j.erase(j.cbegin(), j.cend()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("number (boolean)") |
| { |
| { |
| json j = false; |
| json::iterator it = j.erase(j.begin(), j.end()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = true; |
| json::const_iterator it = j.erase(j.cbegin(), j.cend()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("number (integer)") |
| { |
| { |
| json j = 17; |
| json::iterator it = j.erase(j.begin(), j.end()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = 17; |
| json::const_iterator it = j.erase(j.cbegin(), j.cend()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("number (unsigned)") |
| { |
| { |
| json j = 17u; |
| json::iterator it = j.erase(j.begin(), j.end()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = 17u; |
| json::const_iterator it = j.erase(j.cbegin(), j.cend()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("number (floating point)") |
| { |
| { |
| json j = 23.42; |
| json::iterator it = j.erase(j.begin(), j.end()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = 23.42; |
| json::const_iterator it = j.erase(j.cbegin(), j.cend()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| |
| SECTION("binary") |
| { |
| { |
| json j = json::binary({1, 2, 3}); |
| json::iterator it = j.erase(j.begin(), j.end()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| { |
| json j = json::binary({1, 2, 3}); |
| json::const_iterator it = j.erase(j.cbegin(), j.cend()); |
| CHECK(j.type() == json::value_t::null); |
| CHECK(it == j.end()); |
| } |
| } |
| } |
| |
| SECTION("erase with two invalid iterators") |
| { |
| SECTION("string") |
| { |
| { |
| json j = "foo"; |
| CHECK_THROWS_AS(j.erase(j.end(), j.end()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.begin(), j.begin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end(), j.end()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.begin(), j.begin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| { |
| json j = "bar"; |
| CHECK_THROWS_AS(j.erase(j.cend(), j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.cbegin(), j.cbegin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend(), j.cend()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.cbegin(), j.cbegin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| } |
| |
| SECTION("number (boolean)") |
| { |
| { |
| json j = false; |
| CHECK_THROWS_AS(j.erase(j.end(), j.end()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.begin(), j.begin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end(), j.end()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.begin(), j.begin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| { |
| json j = true; |
| CHECK_THROWS_AS(j.erase(j.cend(), j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.cbegin(), j.cbegin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend(), j.cend()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.cbegin(), j.cbegin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| } |
| |
| SECTION("number (integer)") |
| { |
| { |
| json j = 17; |
| CHECK_THROWS_AS(j.erase(j.end(), j.end()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.begin(), j.begin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end(), j.end()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.begin(), j.begin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| { |
| json j = 17; |
| CHECK_THROWS_AS(j.erase(j.cend(), j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.cbegin(), j.cbegin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend(), j.cend()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.cbegin(), j.cbegin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| } |
| |
| SECTION("number (unsigned)") |
| { |
| { |
| json j = 17u; |
| CHECK_THROWS_AS(j.erase(j.end(), j.end()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.begin(), j.begin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end(), j.end()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.begin(), j.begin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| { |
| json j = 17u; |
| CHECK_THROWS_AS(j.erase(j.cend(), j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.cbegin(), j.cbegin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend(), j.cend()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.cbegin(), j.cbegin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| } |
| |
| SECTION("number (floating point)") |
| { |
| { |
| json j = 23.42; |
| CHECK_THROWS_AS(j.erase(j.end(), j.end()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.begin(), j.begin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.end(), j.end()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.begin(), j.begin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| { |
| json j = 23.42; |
| CHECK_THROWS_AS(j.erase(j.cend(), j.cend()), json::invalid_iterator&); |
| CHECK_THROWS_AS(j.erase(j.cbegin(), j.cbegin()), json::invalid_iterator&); |
| CHECK_THROWS_WITH(j.erase(j.cend(), j.cend()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| CHECK_THROWS_WITH(j.erase(j.cbegin(), j.cbegin()), "[json.exception.invalid_iterator.204] iterators out of range"); |
| } |
| } |
| } |
| } |
| } |