Selaa lähdekoodia

Test updated to use ctor directly.

main
offa 7 vuotta sitten
vanhempi
commit
968da64e9d
1 muutettua tiedostoa jossa 21 lisäystä ja 21 poistoa
  1. +21
    -21
      test/UniqueResourceTest.cpp

+ 21
- 21
test/UniqueResourceTest.cpp Näytä tiedosto

@@ -39,7 +39,7 @@ namespace
TEST_CASE("construction with move", "[UniqueResource]")
{
REQUIRE_CALL(m, deleter(3));
auto guard = sr::make_unique_resource(Handle{3}, deleter);
auto guard = sr::unique_resource{Handle{3}, deleter};
static_cast<void>(guard);
}

@@ -48,7 +48,7 @@ TEST_CASE("construction with copy", "[UniqueResource]")
REQUIRE_CALL(m, deleter(3));
const Handle h{3};
const auto d = [](auto v) { m.deleter(v); };
auto guard = sr::make_unique_resource(h, d);
auto guard = sr::unique_resource{h, d};
static_cast<void>(guard);
}

@@ -59,7 +59,7 @@ TEST_CASE("construction with copy calls deleter and rethrows on failed copy", "[
const auto d = [](const auto&) { m.deleter(3); };
REQUIRE_CALL(m, deleter(3));

sr::unique_resource<decltype(noMove), decltype(d)> guard{noMove, d};
sr::unique_resource guard{noMove, d};
static_cast<void>(guard);
}());
}
@@ -67,7 +67,7 @@ TEST_CASE("construction with copy calls deleter and rethrows on failed copy", "[
TEST_CASE("move-construction with move", "[UniqueResource]")
{
REQUIRE_CALL(m, deleter(3));
auto movedFrom = sr::make_unique_resource(Handle{3}, deleter);
auto movedFrom = sr::unique_resource{Handle{3}, deleter};
auto guard = std::move(movedFrom);
CHECK(guard.get() == 3);
}
@@ -78,19 +78,19 @@ TEST_CASE("move-construction with copy", "[UniqueResource]")
auto d = [](auto) { deleter(7); };

const CopyMock copyMock;
sr::unique_resource<CopyMock, decltype(d)> movedFrom{copyMock, d};
sr::unique_resource movedFrom{copyMock, d};
auto guard = std::move(movedFrom);
static_cast<void>(guard);
}

TEST_CASE("move assignment calls deleter", "[UniqueResource]")
{
auto moveFrom = sr::make_unique_resource(Handle{3}, deleter);
auto moveFrom = sr::unique_resource{Handle{3}, deleter};
REQUIRE_CALL(m, deleter(4));

{
REQUIRE_CALL(m, deleter(3));
auto guard = sr::make_unique_resource(Handle{4}, deleter);
auto guard = sr::unique_resource{Handle{4}, deleter};
guard = std::move(moveFrom);
}
}
@@ -98,13 +98,13 @@ TEST_CASE("move assignment calls deleter", "[UniqueResource]")
TEST_CASE("deleter called on destruction", "[UniqueResource]")
{
REQUIRE_CALL(m, deleter(3));
auto guard = sr::make_unique_resource(Handle{3}, deleter);
auto guard = sr::unique_resource{Handle{3}, deleter};
static_cast<void>(guard);
}

TEST_CASE("reset calls deleter", "[UniqueResource]")
{
auto guard = sr::make_unique_resource(Handle{3}, deleter);
auto guard = sr::unique_resource{Handle{3}, deleter};

{
REQUIRE_CALL(m, deleter(3));
@@ -115,7 +115,7 @@ TEST_CASE("reset calls deleter", "[UniqueResource]")
TEST_CASE("reset does not call deleter if released", "[UniqueResource]")
{
REQUIRE_CALL(m, deleter(3)).TIMES(0);
auto guard = sr::make_unique_resource(Handle{3}, deleter);
auto guard = sr::unique_resource{Handle{3}, deleter};
guard.release();
guard.reset();
}
@@ -124,7 +124,7 @@ TEST_CASE("reset sets new value and calls deleter on previous", "[UniqueResource
{
REQUIRE_CALL(m, deleter(3));
REQUIRE_CALL(m, deleter(7));
auto guard = sr::make_unique_resource(Handle{3}, deleter);
auto guard = sr::unique_resource{Handle{3}, deleter};
guard.reset(Handle{7});
}

@@ -133,28 +133,28 @@ TEST_CASE("reset handles exception on assignment", "[UniqueResource]")
REQUIRE_CALL(m, deleter(3));
REQUIRE_CALL(m, deleter(7));
auto d = [](const auto& v) { deleter(v.m_handle); };
auto guard = sr::make_unique_resource(ConditialThrowOnCopyMock{3, false}, d);
auto guard = sr::unique_resource{ConditialThrowOnCopyMock{3, false}, d};
guard.reset(ConditialThrowOnCopyMock{7, true});
}

TEST_CASE("release disables deleter", "[UniqueResource]")
{
REQUIRE_CALL(m, deleter(3)).TIMES(0);
auto guard = sr::make_unique_resource(Handle{3}, deleter);
auto guard = sr::unique_resource{Handle{3}, deleter};
guard.release();
}

TEST_CASE("get returns resource", "[UniqueResource]")
{
REQUIRE_CALL(m, deleter(3));
auto guard = sr::make_unique_resource(Handle{3}, deleter);
auto guard = sr::unique_resource{Handle{3}, deleter};
CHECK(guard.get() == 3);
}

TEST_CASE("pointer access returns resource" "[UniqueResource]")
{
const auto p = std::make_pair(3, 4);
auto guard = sr::make_unique_resource(&p, [](auto*) { });
auto guard = sr::unique_resource{&p, [](auto*) { }};
REQUIRE(guard->first == 3);
REQUIRE(guard->second == 4);
}
@@ -162,13 +162,13 @@ TEST_CASE("pointer access returns resource" "[UniqueResource]")
TEST_CASE("pointer dereference returns resource" "[UniqueResource]")
{
Handle h{5};
auto guard = sr::make_unique_resource(PtrHandle{&h}, [](auto*) { });
auto guard = sr::unique_resource{PtrHandle{&h}, [](auto*) { }};
REQUIRE(*guard == 5);
}

TEST_CASE("deleter access", "[UniqueResource]")
{
auto guard = sr::make_unique_resource(Handle{3}, deleter);
auto guard = sr::unique_resource{Handle{3}, deleter};
guard.release();

{
@@ -180,11 +180,11 @@ TEST_CASE("deleter access", "[UniqueResource]")
TEST_CASE("swap", "[UniqueResource]")
{
REQUIRE_CALL(m, deleter(7));
auto guard1 = sr::make_unique_resource(Handle{3}, deleter);
auto guard1 = sr::unique_resource(Handle{3}, deleter);

{
REQUIRE_CALL(m, deleter(3));
auto guard2 = sr::make_unique_resource(Handle{7}, deleter);
auto guard2 = sr::unique_resource{Handle{7}, deleter};
guard2.swap(guard1);
REQUIRE(guard1.get() == 7);
REQUIRE(guard2.get() == 3);
@@ -194,7 +194,7 @@ TEST_CASE("swap", "[UniqueResource]")
TEST_CASE("make unique resource", "[UniqueResource]")
{
REQUIRE_CALL(m, deleter(7));
auto guard = sr::make_unique_resource(Handle{7}, deleter);
auto guard = sr::unique_resource{Handle{7}, deleter};
static_cast<void>(guard);
}

@@ -202,7 +202,7 @@ TEST_CASE("make unique resource with reference wrapper", "[UniqueResource]")
{
REQUIRE_CALL(m, deleter(3));
Handle h{3};
auto guard = sr::make_unique_resource(std::ref(h), deleter);
auto guard = sr::unique_resource{std::ref(h), deleter};
static_cast<void>(guard);
}


Loading…
Peruuta
Tallenna