ecore: add check to make sure that the order of future_get and value_set can be switched.

This commit is contained in:
Cedric BAIL 2016-11-03 17:58:58 -07:00
parent 10e4e65250
commit a614303fb6
1 changed files with 40 additions and 0 deletions

View File

@ -463,6 +463,45 @@ START_TEST(efl_test_promise_future_success)
}
END_TEST
// Test value set before future_get
START_TEST(efl_test_promise_future_success_before_get)
{
Efl_Promise *p;
Efl_Future *f;
Future_Ok fo = { EINA_FALSE, EINA_FALSE, EINA_FALSE };
Eina_Bool deadf = EINA_FALSE, deadp = EINA_FALSE;
int progress = 7;
int value = 42;
ecore_init();
p = efl_add(EFL_PROMISE_CLASS, ecore_main_loop_get());
fail_if(!p);
efl_promise_value_set(p, &value, NULL);
efl_future_use(&f, efl_promise_future_get(p));
fail_if(!f);
efl_event_callback_add(f, EFL_EVENT_DEL, _death, &deadf);
efl_event_callback_add(p, EFL_EVENT_DEL, _death, &deadp);
fail_if(deadp || deadf);
fail_if(!efl_future_then(f, _then, _cancel, _progress, &fo));
fail_if(f);
fail_if(!fo.then || fo.cancel || fo.progress);
fail_if(!deadf || deadp);
efl_del(p);
fail_if(!deadp);
ecore_shutdown();
}
END_TEST
START_TEST(efl_test_promise_future_cancel)
{
Efl_Promise *p;
@ -1224,6 +1263,7 @@ void ecore_test_ecore_promise(TCase *tc)
tcase_add_test(tc, efl_test_promise_future_optional_cancel);
tcase_add_test(tc, efl_test_promise_all);
tcase_add_test(tc, efl_test_promise_all_after_value_set);
tcase_add_test(tc, efl_test_promise_future_success_before_get);
tcase_add_test(tc, efl_test_promise_race);
tcase_add_test(tc, efl_test_future_link);
tcase_add_test(tc, efl_test_recursive_mess);