Merge branch 'bugfix/pthread_cxx_test_race' into 'master'
test: Fix possible race in pthread C++ test Closes IDF-1270 See merge request espressif/esp-idf!7054
This commit is contained in:
commit
d4366e0e05
1 changed files with 36 additions and 31 deletions
|
@ -12,47 +12,50 @@
|
|||
#include "esp_log.h"
|
||||
const static char *TAG = "pthread_test";
|
||||
|
||||
static std::shared_ptr<int> global_sp;
|
||||
static std::mutex mtx;
|
||||
static std::shared_ptr<int> global_sp_mtx; // protected by mux
|
||||
|
||||
static std::recursive_mutex recur_mtx;
|
||||
static std::shared_ptr<int> global_sp_recur_mtx; // protected by recursive mux
|
||||
|
||||
static void thread_do_nothing() {}
|
||||
|
||||
static void thread_main()
|
||||
{
|
||||
int i = 0;
|
||||
std::cout << "thread_main CXX " << std::hex << std::this_thread::get_id() << std::endl;
|
||||
std::chrono::milliseconds dur = std::chrono::milliseconds(300);
|
||||
std::chrono::milliseconds dur = std::chrono::milliseconds(10);
|
||||
|
||||
while (i < 3) {
|
||||
int old_val, new_val;
|
||||
for (int i = 0; i < 10; i++) {
|
||||
for (int j = 0; j < 10; j++) {
|
||||
int old_val, new_val;
|
||||
|
||||
// mux test
|
||||
mtx.lock();
|
||||
old_val = *global_sp;
|
||||
std::this_thread::yield();
|
||||
(*global_sp)++;
|
||||
std::this_thread::yield();
|
||||
new_val = *global_sp;
|
||||
mtx.unlock();
|
||||
std::cout << "thread " << std::hex << std::this_thread::get_id() << ": " << i++ << " val= " << *global_sp << std::endl;
|
||||
TEST_ASSERT_TRUE(new_val == old_val + 1);
|
||||
// mux test
|
||||
mtx.lock();
|
||||
old_val = *global_sp_mtx;
|
||||
std::this_thread::yield();
|
||||
(*global_sp_mtx)++;
|
||||
std::this_thread::yield();
|
||||
new_val = *global_sp_mtx;
|
||||
mtx.unlock();
|
||||
std::cout << "thread " << std::hex << std::this_thread::get_id() << ": nrec " << i << " val= " << *global_sp_mtx << std::endl;
|
||||
TEST_ASSERT_EQUAL(old_val + 1, new_val);
|
||||
|
||||
// sleep_for test
|
||||
std::this_thread::sleep_for(dur);
|
||||
// sleep_for test
|
||||
std::this_thread::sleep_for(dur);
|
||||
|
||||
// recursive mux test
|
||||
recur_mtx.lock();
|
||||
recur_mtx.lock();
|
||||
old_val = *global_sp;
|
||||
std::this_thread::yield();
|
||||
(*global_sp)++;
|
||||
std::this_thread::yield();
|
||||
new_val = *global_sp;
|
||||
recur_mtx.unlock();
|
||||
recur_mtx.unlock();
|
||||
std::cout << "thread " << std::hex << std::this_thread::get_id() << ": " << i++ << " val= " << *global_sp << std::endl;
|
||||
TEST_ASSERT_TRUE(new_val == old_val + 1);
|
||||
// recursive mux test
|
||||
recur_mtx.lock();
|
||||
recur_mtx.lock();
|
||||
old_val = *global_sp_recur_mtx;
|
||||
std::this_thread::yield();
|
||||
(*global_sp_recur_mtx)++;
|
||||
std::this_thread::yield();
|
||||
new_val = *global_sp_recur_mtx;
|
||||
recur_mtx.unlock();
|
||||
recur_mtx.unlock();
|
||||
std::cout << "thread " << std::hex << std::this_thread::get_id() << ": rec " << i << " val= " << *global_sp_recur_mtx << std::endl;
|
||||
TEST_ASSERT_EQUAL(old_val + 1, new_val);
|
||||
}
|
||||
|
||||
// sleep_until test
|
||||
using std::chrono::system_clock;
|
||||
|
@ -65,7 +68,8 @@ static void thread_main()
|
|||
|
||||
TEST_CASE("pthread C++", "[pthread]")
|
||||
{
|
||||
global_sp.reset(new int(1));
|
||||
global_sp_mtx.reset(new int(1));
|
||||
global_sp_recur_mtx.reset(new int(-1000));
|
||||
|
||||
std::thread t1(thread_do_nothing);
|
||||
t1.join();
|
||||
|
@ -86,7 +90,8 @@ TEST_CASE("pthread C++", "[pthread]")
|
|||
t4.join();
|
||||
}
|
||||
|
||||
global_sp.reset(); // avoid reported leak
|
||||
global_sp_mtx.reset(); // avoid reported leak
|
||||
global_sp_recur_mtx.reset();
|
||||
}
|
||||
|
||||
static void task_test_sandbox()
|
||||
|
|
Loading…
Reference in a new issue