[CRIU] [PATCH 2/3] test: app-emu -- job: Fix comparison
Cyrill Gorcunov
gorcunov at openvz.org
Tue May 7 04:23:35 EDT 2013
On Tue, May 07, 2013 at 12:01:43PM +0400, Andrew Vagin wrote:
> On Mon, May 06, 2013 at 11:34:32PM +0400, Cyrill Gorcunov wrote:
> > On Mon, May 06, 2013 at 11:18:57PM +0400, Andrey Wagin wrote:
> > > On May 6, 2013 7:13 PM, "Cyrill Gorcunov" <gorcunov at openvz.org> wrote:
> > > >
> > > > Since we're migrating session leader here,
> > > > test for session has not been changed instead.
> > >
> > > In this case the test doesn't wait c/r. I don't like when sleep is used
> > > for synchronization instead of sending a signal.
> >
> > It does wait. Maybe in somehow weird way (ie by sleeps) but still. The main
> > expect script writes pid
> >
> > system ../../../crtools dump -v 4 -D ./dump -o dump.log -j -t $pid
> > system echo "$pid" > ./dump/pid.pid
> >
> > once dump complete, then restore stage initiated.
>
> Look at the attached patch.
Will you be fine with this one?
---
From: Andrew Vagin <avagin at parallels.com>
Subject: [PATCH] test: app-emu -- job: Fix comparison and wait for restore complete by a signal
Since we're migrating session leader here, test for session has not
been changed instead.
[gorcunov@: Add small sleep into expect script]
Signed-off-by: Andrew Vagin <avagin at parallels.com>
Signed-off-by: Cyrill Gorcunov <gorcunov at openvz.org>
---
test/app-emu/job/job.c | 36 +++++++++++++++++++++++-------------
test/app-emu/job/job.exp | 6 ++++++
2 files changed, 29 insertions(+), 13 deletions(-)
diff --git a/test/app-emu/job/job.c b/test/app-emu/job/job.c
index e01480a..44858a7 100644
--- a/test/app-emu/job/job.c
+++ b/test/app-emu/job/job.c
@@ -14,15 +14,27 @@
#include <dirent.h>
+static int stop = 0;
+
+void sighandler(int sig)
+{
+ stop = 1;
+}
+
int main(int argc, char *argv[])
{
int pid, gid, sid;
int tty_sid, tty_gid;
int fd = fileno(stdout);
char buf[32];
- int c = 0;
struct dirent *de;
DIR *fd_dir;
+ sigset_t bmask, cmask;
+
+ if (signal(SIGTERM, sighandler)) {
+ printf("Unable to set a signal handler: %m\n");
+ return 1;
+ }
if (!isatty(fd)) {
printf("stdout is not tty\n");
@@ -70,21 +82,19 @@ int main(int argc, char *argv[])
}
printf("stdout gid = %d\n", tty_gid);
+ sigemptyset(&cmask);
+ sigemptyset(&bmask);
+ sigaddset(&bmask, SIGTERM);
+
+ sigprocmask(SIG_SETMASK, &bmask, NULL);
+
printf("READY\n");
- c = 0;
- while (1) {
- sleep(1);
- if (c++ > 10) {
- printf("Too long for restore\n");
- exit(-1);
- }
+ while (!stop)
+ sigsuspend(&cmask);
- if (getsid(pid) != sid) {
- printf("ALIVE\n");
- break;
- }
- }
+ if (getsid(pid) == sid)
+ printf("ALIVE\n");
return 0;
}
diff --git a/test/app-emu/job/job.exp b/test/app-emu/job/job.exp
index cf743e8..1b4dcbd 100755
--- a/test/app-emu/job/job.exp
+++ b/test/app-emu/job/job.exp
@@ -38,6 +38,12 @@ switch $current {
}
spawn ../../../crtools restore -v 4 -D ./dump -o restore.log -j -t $pid
+ #
+ # spawn doesn't wait for restore to complete, so
+ # add some sleep here. Still better would be to
+ # rewrite this test completely.
+ sleep 2
+ system kill -15 $pid
expect "ALIVE" {
puts "PASS"
--
1.8.1.4
More information about the CRIU
mailing list