mirror of
https://gitee.com/houstudio/Cdroid.git
synced 2024-12-02 12:17:46 +08:00
280 lines
6.7 KiB
C++
Executable File
280 lines
6.7 KiB
C++
Executable File
#include <gtest/gtest.h>
|
|
#include <cdroid.h>
|
|
#include <ngl_os.h>
|
|
#include <sys/time.h>
|
|
#include <core/systemclock.h>
|
|
#include <cdlog.h>
|
|
#include <functional>
|
|
#include <thread>
|
|
#include <core/uieventsource.h>
|
|
#include <core/handler.h>
|
|
#include <sys/timerfd.h>
|
|
#include <unistd.h>
|
|
#include <time.h>
|
|
|
|
class LOOPER:public testing::Test{
|
|
|
|
public :
|
|
virtual void SetUp(){
|
|
}
|
|
virtual void TearDown(){
|
|
LOGD("\r\n\r\n");
|
|
}
|
|
};
|
|
|
|
class MyRunner{
|
|
public:
|
|
int key;
|
|
std::function<void()>run;
|
|
MyRunner(){}
|
|
MyRunner(const std::function<void()>a){}
|
|
void operator=(const std::function<void()>&a){
|
|
run=a;
|
|
}
|
|
void test(int i){
|
|
LOGD("i=%d",i);
|
|
}
|
|
virtual void post(Runnable&){
|
|
LOGD("post(Runnable&)");
|
|
}
|
|
void post(const Runnable&a){
|
|
LOGD("post(const Runnable&)");
|
|
Runnable aa=a;
|
|
post(aa);
|
|
}
|
|
void post(const std::function<void()>&a){
|
|
LOGD("post(const const std::function<void()>&)");
|
|
Runnable aaa;
|
|
aaa=a;
|
|
post(aaa);
|
|
}
|
|
};
|
|
class YouRunner:public MyRunner{
|
|
public:
|
|
YouRunner():MyRunner(){}
|
|
YouRunner(const std::function<void()>a):MyRunner(a){};
|
|
};
|
|
TEST_F(LOOPER,function){
|
|
YouRunner r(std::bind(&LOOPER::SetUp,this));
|
|
Runnable rrr;
|
|
r.post(Runnable([](){}));
|
|
r.post(Runnable([](){}));
|
|
r.post(std::bind(&LOOPER::SetUp,this));
|
|
typedef std::function<void()>aaaa;
|
|
}
|
|
|
|
class TestHandler:public MessageHandler{
|
|
int count;
|
|
public:
|
|
TestHandler(){count=0;}
|
|
void handleMessage(Message&msg)override{
|
|
count++;printf("handleMessage(%d)\r\n",msg.what);
|
|
}
|
|
int getCount()const{return count;}
|
|
};
|
|
|
|
TEST_F(LOOPER,pollonce){
|
|
Looper loop(false);
|
|
int64_t t1=SystemClock::uptimeMillis();
|
|
loop.pollOnce(1000);
|
|
int64_t t2=SystemClock::uptimeMillis();
|
|
ASSERT_TRUE((t2-t1)>=1000&&(t2-t2)<1005);
|
|
}
|
|
|
|
TEST_F(LOOPER,sendMessage){
|
|
Looper loop(false);
|
|
Message msg(100);
|
|
int processed=0;
|
|
TestHandler ft;
|
|
loop.sendMessage(&ft,msg);
|
|
loop.pollOnce(10);
|
|
ASSERT_EQ(ft.getCount(),1);
|
|
}
|
|
|
|
TEST_F(LOOPER,sendMessageDelay){
|
|
Looper loop(false);
|
|
Message msg(100);
|
|
TestHandler ft;
|
|
int64_t t1=SystemClock::uptimeMillis();
|
|
loop.sendMessageDelayed(1000,&ft,msg);
|
|
while(!ft.getCount()) loop.pollOnce(10);
|
|
int64_t t2=SystemClock::uptimeMillis();
|
|
ASSERT_TRUE((t2-t1)>=1000&&(t2-t2)<1005);
|
|
}
|
|
|
|
TEST_F(LOOPER,removeMessage){
|
|
Looper loop(false);
|
|
Message msg(100),msg2(200);
|
|
TestHandler ft;
|
|
int64_t t2,t1=SystemClock::uptimeMillis();
|
|
loop.sendMessageDelayed(1000,&ft,msg);
|
|
loop.sendMessageDelayed(1000,&ft,msg2);
|
|
t2=t1;
|
|
loop.removeMessages(&ft,100);
|
|
while(t2-t1<1100){
|
|
loop.pollOnce(10);
|
|
t2=SystemClock::uptimeMillis();
|
|
}
|
|
ASSERT_EQ(ft.getCount(),1);
|
|
}
|
|
|
|
class TestRunner:public Runnable{
|
|
private:
|
|
int mCount;
|
|
public:
|
|
TestRunner():Runnable(){
|
|
mCount=0;
|
|
(*mFunctor)=std::bind(&TestRunner::doit,this);
|
|
}
|
|
void doit(){
|
|
mCount++;
|
|
LOGD("mCount=%d",mCount);
|
|
}
|
|
};
|
|
TEST_F(LOOPER,eventhandler){
|
|
UIEventSource*handler=new UIEventSource(nullptr,nullptr);
|
|
Runnable run([]{});
|
|
handler->postDelayed(run,10);
|
|
bool rc=handler->removeCallbacks(run);
|
|
ASSERT_TRUE(rc);
|
|
|
|
Runnable run2(run);
|
|
Runnable run3;
|
|
run3=run;
|
|
handler->postDelayed(run2,10);
|
|
rc=handler->removeCallbacks(run2);
|
|
ASSERT_TRUE(rc);
|
|
|
|
handler->postDelayed(run,10);
|
|
rc=handler->removeCallbacks(run3);
|
|
ASSERT_TRUE(rc);
|
|
|
|
rc=handler->removeCallbacks(run3);
|
|
ASSERT_FALSE(rc);
|
|
}
|
|
|
|
TEST_F(LOOPER,loop){
|
|
Looper loop(false);
|
|
//UIEventSource*handler=new UIEventSource(nullptr,nullptr);
|
|
//loop.addEventHandler(handler);
|
|
Handler handler;
|
|
TestRunner run;
|
|
int count=0;
|
|
ASSERT_TRUE((bool)run);
|
|
ASSERT_FALSE(run==nullptr);
|
|
ASSERT_TRUE(run!=nullptr);
|
|
run();
|
|
handler.postDelayed(run,10);
|
|
while(1)loop.pollAll(100);
|
|
}
|
|
|
|
class MyHandler:public Handler{
|
|
public:
|
|
void handleMessage(Message&msg)override{
|
|
LOGD("rcv msg %d",msg.what);
|
|
}
|
|
void handleIdle(){
|
|
LOGD("idle");
|
|
}
|
|
~MyHandler(){
|
|
LOGD("MyHandler destroied!");
|
|
}
|
|
};
|
|
|
|
TEST_F(LOOPER,handler){
|
|
Looper *loop= Looper::getDefault();
|
|
Handler *handler=new MyHandler();
|
|
handler->sendEmptyMessage(1);
|
|
handler->sendEmptyMessageDelayed(2,20);
|
|
Runnable cbk([](){LOGD("---");});
|
|
handler->postDelayed(cbk,30);
|
|
int count=0;
|
|
while(count++<3)
|
|
loop->pollAll(10);
|
|
loop->removeHandler(handler);
|
|
while(count++<6)loop->pollAll(10);
|
|
}
|
|
|
|
TEST_F(LOOPER,asyncmsg){
|
|
Looper *loop= Looper::getDefault();
|
|
Handler *handler=new MyHandler();
|
|
handler->sendEmptyMessage(1);
|
|
handler->sendEmptyMessageDelayed(2,20);
|
|
Runnable cbk([](){LOGD("---");});
|
|
handler->postDelayed(cbk,30);
|
|
std::thread th([&](){
|
|
Message msg;
|
|
msg.what=0;
|
|
while(1){
|
|
loop->sendMessageDelayed(10,handler,msg);
|
|
msg.what++;
|
|
usleep(100);
|
|
}
|
|
});
|
|
th.detach();
|
|
while(1)loop->pollAll(10);
|
|
}
|
|
|
|
static void ms2timespec(int ms, struct timespec *ts){
|
|
ts->tv_sec = ms / 1000;
|
|
ts->tv_nsec = (ms % 1000) * 1000000;
|
|
}
|
|
|
|
static int fdcallback(int fd, int events, void* data){
|
|
uint64_t count;
|
|
int *loops=(int*)data;
|
|
struct timespec cur;
|
|
clock_gettime(CLOCK_MONOTONIC,&cur);
|
|
if(events&Looper::EVENT_INPUT)
|
|
::read(fd, &count, sizeof(uint64_t));
|
|
if(*loops>20){
|
|
struct itimerspec new_value={{0,0},{0,0}};
|
|
timerfd_settime(fd,0,&new_value, NULL);
|
|
Looper::getDefault()->removeFd(fd);
|
|
}
|
|
return 1;
|
|
}
|
|
|
|
TEST_F(LOOPER,timerfd){
|
|
#define INTERVAL 200 //ms
|
|
Looper*loop= Looper::getDefault();
|
|
int loops=0;
|
|
struct itimerspec new_value={{0,0},{0,0}};
|
|
ms2timespec(INTERVAL,&new_value.it_value);
|
|
ms2timespec(INTERVAL,&new_value.it_interval);
|
|
int fd=timerfd_create(CLOCK_MONOTONIC, TFD_NONBLOCK | TFD_CLOEXEC);
|
|
|
|
int rc=timerfd_settime(fd, 0/*TFD_TIMER_ABSTIME*/, &new_value,NULL);
|
|
loop->addFd(fd,0,Looper::EVENT_INPUT,fdcallback,&loops);
|
|
while(1)loop->pollAll(10);
|
|
}
|
|
|
|
TEST_F(LOOPER,timerfd2){
|
|
#define INTERVAL 200 //ms
|
|
App app;
|
|
int loops=0;
|
|
Looper*loop= Looper::getDefault();
|
|
struct itimerspec new_value={{0,0},{0,0}};
|
|
|
|
ms2timespec(INTERVAL,&new_value.it_value);
|
|
ms2timespec(INTERVAL,&new_value.it_interval);
|
|
int fd=timerfd_create(CLOCK_MONOTONIC, TFD_NONBLOCK | TFD_CLOEXEC);
|
|
|
|
int rc=timerfd_settime(fd, 0/*TFD_TIMER_ABSTIME*/, &new_value, NULL);
|
|
loop->addFd(fd,0,Looper::EVENT_INPUT,fdcallback,&loops);
|
|
Window*w = new Window(0,0,-1,-1);
|
|
Button*btn= new Button("Test",200,200);
|
|
w->addView(btn);
|
|
int color=11,color2=0;
|
|
Runnable run={[&](){
|
|
btn->setBackgroundColor(0xFF000000|color|(color2<<8));
|
|
color+=8;color2+=4;
|
|
w->postDelayed(run,100);
|
|
}};
|
|
w->postDelayed(run,100);
|
|
btn->setOnClickListener([](View&v){
|
|
printf("button clicked \r\n");
|
|
});
|
|
app.exec();
|
|
}
|