2018-05-20 00:14:17 -07:00
# include <cpp-utils/process/subprocess.h>
# include <gtest/gtest.h>
2019-03-23 22:01:26 -07:00
# include <boost/filesystem.hpp>
2018-05-20 00:14:17 -07:00
2019-02-28 02:29:10 -08:00
# include <cpp-utils/lock/ConditionBarrier.h>
2019-03-23 22:01:26 -07:00
# include "my-gtest-main.h"
2019-02-28 02:29:10 -08:00
2018-05-20 00:14:17 -07:00
using cpputils : : Subprocess ;
using cpputils : : SubprocessError ;
2019-03-23 22:01:26 -07:00
using std : : string ;
namespace bf = boost : : filesystem ;
2018-05-20 00:14:17 -07:00
2018-07-08 19:34:08 -07:00
namespace {
std : : string exit_with_message_and_status ( const char * message , int status ) {
# if defined(_MSC_VER)
2019-03-23 22:01:26 -07:00
auto executable = get_executable ( ) . parent_path ( ) / " cpp-utils-test_exit_status.exe " ;
2018-07-08 19:34:08 -07:00
# else
2019-03-23 22:01:26 -07:00
auto executable = get_executable ( ) . parent_path ( ) / " cpp-utils-test_exit_status " ;
2018-07-08 19:34:08 -07:00
# endif
2019-03-23 22:01:26 -07:00
if ( ! bf : : exists ( executable ) ) {
throw std : : runtime_error ( executable . string ( ) + " not found. " ) ;
}
return executable . string ( ) + " \" " + message + " \" " + std : : to_string ( status ) ;
2018-07-08 19:34:08 -07:00
}
}
2018-05-20 00:14:17 -07:00
TEST ( SubprocessTest , CheckCall_success_output ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( " hello " , Subprocess : : check_call ( exit_with_message_and_status ( " hello " , 0 ) ) . output ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , CheckCall_successwithemptyoutput_output ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( " " , Subprocess : : check_call ( exit_with_message_and_status ( " " , 0 ) ) . output ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , CheckCall_success_exitcode ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( 0 , Subprocess : : check_call ( exit_with_message_and_status ( " hello " , 0 ) ) . exitcode ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , CheckCall_successwithemptyoutput_exitcode ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( 0 , Subprocess : : check_call ( exit_with_message_and_status ( " " , 0 ) ) . exitcode ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , CheckCall_error ) {
EXPECT_THROW (
2018-07-08 19:34:08 -07:00
Subprocess : : check_call ( exit_with_message_and_status ( " " , 1 ) ) ,
2018-05-20 00:14:17 -07:00
SubprocessError
) ;
}
TEST ( SubprocessTest , CheckCall_error5 ) {
EXPECT_THROW (
2018-07-08 19:34:08 -07:00
Subprocess : : check_call ( exit_with_message_and_status ( " " , 5 ) ) ,
2018-05-20 00:14:17 -07:00
SubprocessError
) ;
}
TEST ( SubprocessTest , CheckCall_errorwithoutput ) {
EXPECT_THROW (
2018-07-08 19:34:08 -07:00
Subprocess : : check_call ( exit_with_message_and_status ( " hello " , 1 ) ) ,
2018-05-20 00:14:17 -07:00
SubprocessError
) ;
}
TEST ( SubprocessTest , CheckCall_error5withoutput ) {
EXPECT_THROW (
2018-07-08 19:34:08 -07:00
Subprocess : : check_call ( exit_with_message_and_status ( " hello " , 5 ) ) ,
2018-05-20 00:14:17 -07:00
SubprocessError
) ;
}
TEST ( SubprocessTest , Call_success_exitcode ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( 0 , Subprocess : : call ( exit_with_message_and_status ( " hello " , 0 ) ) . exitcode ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , Call_success_output ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( " hello " , Subprocess : : call ( exit_with_message_and_status ( " hello " , 0 ) ) . output ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , Call_error_exitcode ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( 1 , Subprocess : : call ( exit_with_message_and_status ( " " , 1 ) ) . exitcode ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , Call_error_output ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( " " , Subprocess : : call ( exit_with_message_and_status ( " " , 1 ) ) . output ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , Call_error5_exitcode ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( 5 , Subprocess : : call ( exit_with_message_and_status ( " " , 5 ) ) . exitcode ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , Call_error5_output ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( " " , Subprocess : : call ( exit_with_message_and_status ( " " , 1 ) ) . output ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , Call_errorwithoutput_output ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( " hello " , Subprocess : : call ( exit_with_message_and_status ( " hello " , 1 ) ) . output ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , Call_errorwithoutput_exitcode ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( 1 , Subprocess : : call ( exit_with_message_and_status ( " hello " , 1 ) ) . exitcode ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , Call_error5withoutput_output ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( " hello " , Subprocess : : call ( exit_with_message_and_status ( " hello " , 5 ) ) . output ) ;
2018-05-20 00:14:17 -07:00
}
TEST ( SubprocessTest , Call_error5withoutput_exitcode ) {
2018-07-08 19:34:08 -07:00
EXPECT_EQ ( 5 , Subprocess : : call ( exit_with_message_and_status ( " hello " , 5 ) ) . exitcode ) ;
2018-05-20 00:14:17 -07:00
}
2019-02-28 02:29:10 -08:00
// TODO Move this test to a test suite for ThreadSystem/LoopThread
# include <cpp-utils/thread/LoopThread.h>
TEST ( SubprocessTest , CallFromThreadSystemThread ) {
cpputils : : ConditionBarrier barrier ;
cpputils : : LoopThread thread (
[ & barrier ] ( ) {
auto result = Subprocess : : check_call ( exit_with_message_and_status ( " hello " , 0 ) ) ;
EXPECT_EQ ( 0 , result . exitcode ) ;
EXPECT_EQ ( " hello " , result . output ) ;
barrier . release ( ) ;
return false ; // don't run loop again
} ,
" child_thread "
) ;
thread . start ( ) ;
barrier . wait ( ) ;
thread . stop ( ) ; // just to make sure it's stopped before the test exits. Returning false above should already stop it, but we don't know when exactly. thread.stop() will block until it's actually stopped.
}