|
@@ -11,11 +11,18 @@ struct FakeProcess: entt::Process<FakeProcess, int> {
|
|
|
void unpause() noexcept { process_type::unpause(); }
|
|
void unpause() noexcept { process_type::unpause(); }
|
|
|
|
|
|
|
|
void init() { initInvoked = true; }
|
|
void init() { initInvoked = true; }
|
|
|
- void update(delta_type) { updateInvoked = true; }
|
|
|
|
|
void succeeded() { succeededInvoked = true; }
|
|
void succeeded() { succeededInvoked = true; }
|
|
|
void failed() { failedInvoked = true; }
|
|
void failed() { failedInvoked = true; }
|
|
|
void aborted() { abortedInvoked = true; }
|
|
void aborted() { abortedInvoked = true; }
|
|
|
|
|
|
|
|
|
|
+ void update(delta_type, void *data) {
|
|
|
|
|
+ if(data) {
|
|
|
|
|
+ (*static_cast<int *>(data))++;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ updateInvoked = true;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
bool initInvoked{false};
|
|
bool initInvoked{false};
|
|
|
bool updateInvoked{false};
|
|
bool updateInvoked{false};
|
|
|
bool succeededInvoked{false};
|
|
bool succeededInvoked{false};
|
|
@@ -95,6 +102,26 @@ TEST(Process, Fail) {
|
|
|
ASSERT_FALSE(process.abortedInvoked);
|
|
ASSERT_FALSE(process.abortedInvoked);
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+TEST(Process, Data) {
|
|
|
|
|
+ FakeProcess process;
|
|
|
|
|
+ int value = 0;
|
|
|
|
|
+
|
|
|
|
|
+ process.tick(0, &value);
|
|
|
|
|
+ process.succeed();
|
|
|
|
|
+ process.tick(0, &value);
|
|
|
|
|
+
|
|
|
|
|
+ ASSERT_FALSE(process.alive());
|
|
|
|
|
+ ASSERT_TRUE(process.dead());
|
|
|
|
|
+ ASSERT_FALSE(process.paused());
|
|
|
|
|
+
|
|
|
|
|
+ ASSERT_EQ(value, 1);
|
|
|
|
|
+ ASSERT_TRUE(process.initInvoked);
|
|
|
|
|
+ ASSERT_TRUE(process.updateInvoked);
|
|
|
|
|
+ ASSERT_TRUE(process.succeededInvoked);
|
|
|
|
|
+ ASSERT_FALSE(process.failedInvoked);
|
|
|
|
|
+ ASSERT_FALSE(process.abortedInvoked);
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
TEST(Process, AbortNextTick) {
|
|
TEST(Process, AbortNextTick) {
|
|
|
FakeProcess process;
|
|
FakeProcess process;
|
|
|
|
|
|
|
@@ -132,7 +159,7 @@ TEST(Process, AbortImmediately) {
|
|
|
|
|
|
|
|
TEST(ProcessAdaptor, Resolved) {
|
|
TEST(ProcessAdaptor, Resolved) {
|
|
|
bool updated = false;
|
|
bool updated = false;
|
|
|
- auto lambda = [&updated](std::uint64_t, auto resolve, auto) {
|
|
|
|
|
|
|
+ auto lambda = [&updated](std::uint64_t, void *, auto resolve, auto) {
|
|
|
ASSERT_FALSE(updated);
|
|
ASSERT_FALSE(updated);
|
|
|
updated = true;
|
|
updated = true;
|
|
|
resolve();
|
|
resolve();
|
|
@@ -148,7 +175,7 @@ TEST(ProcessAdaptor, Resolved) {
|
|
|
|
|
|
|
|
TEST(ProcessAdaptor, Rejected) {
|
|
TEST(ProcessAdaptor, Rejected) {
|
|
|
bool updated = false;
|
|
bool updated = false;
|
|
|
- auto lambda = [&updated](std::uint64_t, auto, auto rejected) {
|
|
|
|
|
|
|
+ auto lambda = [&updated](std::uint64_t, void *, auto, auto rejected) {
|
|
|
ASSERT_FALSE(updated);
|
|
ASSERT_FALSE(updated);
|
|
|
updated = true;
|
|
updated = true;
|
|
|
rejected();
|
|
rejected();
|
|
@@ -161,3 +188,19 @@ TEST(ProcessAdaptor, Rejected) {
|
|
|
ASSERT_TRUE(process.rejected());
|
|
ASSERT_TRUE(process.rejected());
|
|
|
ASSERT_TRUE(updated);
|
|
ASSERT_TRUE(updated);
|
|
|
}
|
|
}
|
|
|
|
|
+
|
|
|
|
|
+TEST(ProcessAdaptor, Data) {
|
|
|
|
|
+ int value = 0;
|
|
|
|
|
+
|
|
|
|
|
+ auto lambda = [](std::uint64_t, void *data, auto resolve, auto) {
|
|
|
|
|
+ *static_cast<int *>(data) = 42;
|
|
|
|
|
+ resolve();
|
|
|
|
|
+ };
|
|
|
|
|
+
|
|
|
|
|
+ auto process = entt::ProcessAdaptor<decltype(lambda), std::uint64_t>{lambda};
|
|
|
|
|
+
|
|
|
|
|
+ process.tick(0, &value);
|
|
|
|
|
+
|
|
|
|
|
+ ASSERT_TRUE(process.dead());
|
|
|
|
|
+ ASSERT_EQ(value, 42);
|
|
|
|
|
+}
|