From f5cae64e525715e715fca97d0b2634a0968dc789 Mon Sep 17 00:00:00 2001 From: Nikita Ofitserov Date: Sun, 23 Jul 2017 23:59:34 +0300 Subject: [PATCH] Update tests while fixing possible UB std::initializer_list does not own the temporaries created in its initialization. Therefore, storing it in an independent stack variable is unsafe. --- test/src/unit-constructor1.cpp | 27 +++++++++------------------ 1 file changed, 9 insertions(+), 18 deletions(-) diff --git a/test/src/unit-constructor1.cpp b/test/src/unit-constructor1.cpp index a8f5deb8..446bb0b3 100644 --- a/test/src/unit-constructor1.cpp +++ b/test/src/unit-constructor1.cpp @@ -842,8 +842,7 @@ TEST_CASE("constructors") { SECTION("explicit") { - std::initializer_list l; - json j(l); + json j(json::initializer_list_t {}); CHECK(j.type() == json::value_t::object); } @@ -860,8 +859,7 @@ TEST_CASE("constructors") { SECTION("explicit") { - std::initializer_list l = {json(json::array_t())}; - json j(l); + json j(json::initializer_list_t {json(json::array_t())}); CHECK(j.type() == json::value_t::array); } @@ -876,8 +874,7 @@ TEST_CASE("constructors") { SECTION("explicit") { - std::initializer_list l = {json(json::object_t())}; - json j(l); + json j(json::initializer_list_t {json(json::object_t())}); CHECK(j.type() == json::value_t::array); } @@ -892,8 +889,7 @@ TEST_CASE("constructors") { SECTION("explicit") { - std::initializer_list l = {json("Hello world")}; - json j(l); + json j(json::initializer_list_t {json("Hello world")}); CHECK(j.type() == json::value_t::array); } @@ -908,8 +904,7 @@ TEST_CASE("constructors") { SECTION("explicit") { - std::initializer_list l = {json(true)}; - json j(l); + json j(json::initializer_list_t {json(true)}); CHECK(j.type() == json::value_t::array); } @@ -924,8 +919,7 @@ TEST_CASE("constructors") { SECTION("explicit") { - std::initializer_list l = {json(1)}; - json j(l); + json j(json::initializer_list_t {json(1)}); CHECK(j.type() == json::value_t::array); } @@ -940,8 +934,7 @@ TEST_CASE("constructors") { SECTION("explicit") { - std::initializer_list l = {json(1u)}; - json j(l); + json j(json::initializer_list_t {json(1u)}); CHECK(j.type() == json::value_t::array); } @@ -956,8 +949,7 @@ TEST_CASE("constructors") { SECTION("explicit") { - std::initializer_list l = {json(42.23)}; - json j(l); + json j(json::initializer_list_t {json(42.23)}); CHECK(j.type() == json::value_t::array); } @@ -973,8 +965,7 @@ TEST_CASE("constructors") { SECTION("explicit") { - std::initializer_list l = {1, 1u, 42.23, true, nullptr, json::object_t(), json::array_t()}; - json j(l); + json j(json::initializer_list_t {1, 1u, 42.23, true, nullptr, json::object_t(), json::array_t()}); CHECK(j.type() == json::value_t::array); }