mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-16 15:41:16 +01:00
initial changes toward a new test script
Android has lots of games on a single device. My current test has one device per game. I'm hoping to fix that, and am starting with figuring out how the script and "device" instances will communicate.
This commit is contained in:
parent
e708b14c59
commit
53ce78e1ed
3 changed files with 76 additions and 2 deletions
|
@ -806,6 +806,7 @@ typedef enum {
|
||||||
,CMD_SMSTEST
|
,CMD_SMSTEST
|
||||||
,CMD_REMATCH_ON_OVER
|
,CMD_REMATCH_ON_OVER
|
||||||
,CMD_STATUS_SOCKET_NAME
|
,CMD_STATUS_SOCKET_NAME
|
||||||
|
,CMD_CMDS_SOCKET_NAME
|
||||||
,N_CMDS
|
,N_CMDS
|
||||||
} XwLinuxCmd;
|
} XwLinuxCmd;
|
||||||
|
|
||||||
|
@ -969,8 +970,8 @@ static CmdInfoRec CmdInfoRecs[] = {
|
||||||
|
|
||||||
,{ CMD_REMATCH_ON_OVER, false, "rematch-when-done", "Rematch games if they end" }
|
,{ CMD_REMATCH_ON_OVER, false, "rematch-when-done", "Rematch games if they end" }
|
||||||
,{ CMD_STATUS_SOCKET_NAME, true, "status-socket-name",
|
,{ CMD_STATUS_SOCKET_NAME, true, "status-socket-name",
|
||||||
"Unix domain socket to which to write status" }
|
"Unix domain socket to which to write status" },
|
||||||
|
{ CMD_CMDS_SOCKET_NAME, true, "cmd-socket-name", "Unix domain socket on which to listen for commands"},
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct option*
|
static struct option*
|
||||||
|
@ -2553,6 +2554,43 @@ writeStatus( const char* statusSocket, const char* dbName )
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
handle_gotcmd( GIOChannel* source, GIOCondition condition,
|
||||||
|
gpointer XP_UNUSED(data) )
|
||||||
|
{
|
||||||
|
// XP_LOGFF( "got something!!" );
|
||||||
|
gboolean keep = TRUE;
|
||||||
|
|
||||||
|
if ( 0 != (G_IO_IN & condition) ) {
|
||||||
|
int sock = g_io_channel_unix_get_fd( source );
|
||||||
|
char buf[1024];
|
||||||
|
ssize_t nread = read( sock, buf, sizeof(buf) );
|
||||||
|
buf[nread] = '\0';
|
||||||
|
XP_LOGFF( "read: %s", buf );
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( 0 != ((G_IO_HUP) & condition) ) {
|
||||||
|
XP_LOGFF( "got G_IO_HUP; returning FALSE" );
|
||||||
|
keep = FALSE;
|
||||||
|
} else if ( 0 != ((G_IO_ERR) & condition) ) {
|
||||||
|
XP_LOGFF( "got G_IO_ERR; returning FALSE" );
|
||||||
|
} else if ( 0 != ((G_IO_NVAL) & condition) ) {
|
||||||
|
XP_LOGFF( "got G_IO_NVAL; returning FALSE" );
|
||||||
|
} else {
|
||||||
|
XP_LOGFF( "something else: 0x%X", condition );
|
||||||
|
}
|
||||||
|
return keep;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
addCmdListener( LaunchParams* params )
|
||||||
|
{
|
||||||
|
if ( !!params->cmdsSocket ) {
|
||||||
|
int fifo = open( params->cmdsSocket, O_RDWR | O_NONBLOCK );
|
||||||
|
ADD_SOCKET( params, fifo, handle_gotcmd );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
main( int argc, char** argv )
|
main( int argc, char** argv )
|
||||||
{
|
{
|
||||||
|
@ -3143,12 +3181,18 @@ main( int argc, char** argv )
|
||||||
statusSocket = optarg;
|
statusSocket = optarg;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CMD_CMDS_SOCKET_NAME:
|
||||||
|
mainParams.cmdsSocket = optarg;
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
done = true;
|
done = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
addCmdListener( &mainParams );
|
||||||
|
|
||||||
/* add cur dir if dict search dir path is empty */
|
/* add cur dir if dict search dir path is empty */
|
||||||
if ( !mainParams.dictDirs ) {
|
if ( !mainParams.dictDirs ) {
|
||||||
mainParams.dictDirs = g_slist_append( mainParams.dictDirs, "./" );
|
mainParams.dictDirs = g_slist_append( mainParams.dictDirs, "./" );
|
||||||
|
|
|
@ -79,6 +79,8 @@ typedef struct _LaunchParams {
|
||||||
XP_Bool noAnonDevid;
|
XP_Bool noAnonDevid;
|
||||||
XP_UCHAR devIDStore[32];
|
XP_UCHAR devIDStore[32];
|
||||||
#endif
|
#endif
|
||||||
|
const char* cmdsSocket;
|
||||||
|
|
||||||
VTableMgr* vtMgr;
|
VTableMgr* vtMgr;
|
||||||
DictMgrCtxt* dictMgr;
|
DictMgrCtxt* dictMgr;
|
||||||
XW_DUtilCtxt* dutil;
|
XW_DUtilCtxt* dutil;
|
||||||
|
|
28
xwords4/linux/scripts/manygames.py
Executable file
28
xwords4/linux/scripts/manygames.py
Executable file
|
@ -0,0 +1,28 @@
|
||||||
|
#!/usr/bin/python3
|
||||||
|
|
||||||
|
import os, subprocess, time
|
||||||
|
|
||||||
|
gFIFO_NAME = '/tmp/fifo'
|
||||||
|
|
||||||
|
def main():
|
||||||
|
os.mkfifo(gFIFO_NAME)
|
||||||
|
# mkfifo
|
||||||
|
|
||||||
|
# launch app in background
|
||||||
|
args = ['./obj_linux_memdbg/xwords', '--cmd-socket-name', gFIFO_NAME ]
|
||||||
|
subprocess.Popen(args, stdout = subprocess.DEVNULL)
|
||||||
|
|
||||||
|
# Loop writing to fifo
|
||||||
|
for ii in range(5):
|
||||||
|
time.sleep(2)
|
||||||
|
print('calling open')
|
||||||
|
fifo_out = open( gFIFO_NAME, 'w' )
|
||||||
|
print('open DONE')
|
||||||
|
fifo_out.write( 'message {}'.format(ii) )
|
||||||
|
fifo_out.close()
|
||||||
|
|
||||||
|
# Kill app
|
||||||
|
|
||||||
|
##############################################################################
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
Loading…
Reference in a new issue