[libcamera-devel] [PATCH 2/2] test: threads: Add wait() timeout test

Niklas Söderlund niklas.soderlund at ragnatech.se
Mon Feb 10 22:13:27 CET 2020


Hi Laurent,

Thanks for your work.

On 2020-01-23 04:55:20 +0200, Laurent Pinchart wrote:
> Add a test case to wait with a timeout, testing both a too short and a
> long enough duration.
> 
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>

Reviewed-by: Niklas Söderlund <niklas.soderlund at ragnatech.se>

> ---
>  test/threads.cpp | 33 ++++++++++++++++++++++++++-------
>  1 file changed, 26 insertions(+), 7 deletions(-)
> 
> diff --git a/test/threads.cpp b/test/threads.cpp
> index 9a2d39dfd106..fc4b07cc6428 100644
> --- a/test/threads.cpp
> +++ b/test/threads.cpp
> @@ -15,24 +15,22 @@
>  using namespace std;
>  using namespace libcamera;
>  
> -class InstrumentedThread : public Thread
> +class DelayThread : public Thread
>  {
>  public:
> -	InstrumentedThread(unsigned int iterations)
> -		: iterations_(iterations)
> +	DelayThread(chrono::steady_clock::duration duration)
> +		: duration_(duration)
>  	{
>  	}
>  
>  protected:
>  	void run()
>  	{
> -		for (unsigned int i = 0; i < iterations_; ++i) {
> -			this_thread::sleep_for(chrono::milliseconds(50));
> -		}
> +		this_thread::sleep_for(duration_);
>  	}
>  
>  private:
> -	unsigned int iterations_;
> +	chrono::steady_clock::duration duration_;
>  };
>  
>  class ThreadTest : public Test
> @@ -82,6 +80,27 @@ protected:
>  
>  		delete thread;
>  
> +		/* Test waiting for completion with a timeout. */
> +		thread = new DelayThread(chrono::milliseconds(500));
> +		thread->start();
> +		thread->exit(0);
> +
> +		bool timeout = thread->wait(chrono::milliseconds(100));
> +
> +		if (!timeout) {
> +			cout << "Waiting for thread didn't time out" << endl;
> +			return TestFail;
> +		}
> +
> +		timeout = thread->wait(chrono::milliseconds(1000));
> +
> +		if (timeout) {
> +			cout << "Waiting for thread timed out" << endl;
> +			return TestFail;
> +		}
> +
> +		delete thread;
> +
>  		return TestPass;
>  	}
>  
> -- 
> Regards,
> 
> Laurent Pinchart
> 
> _______________________________________________
> libcamera-devel mailing list
> libcamera-devel at lists.libcamera.org
> https://lists.libcamera.org/listinfo/libcamera-devel

-- 
Regards,
Niklas Söderlund


More information about the libcamera-devel mailing list