Skip to content

Commit

Permalink
Merge pull request #2913 from liusdu/interative
Browse files Browse the repository at this point in the history
tiny fix iterative checkpoint test case
  • Loading branch information
hqhq authored May 8, 2021
2 parents f577072 + 23e3794 commit fc8a0d9
Show file tree
Hide file tree
Showing 3 changed files with 53 additions and 6 deletions.
30 changes: 28 additions & 2 deletions checkpoint.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ import (
"fmt"
"net"
"os"
"path/filepath"
"strconv"

criu "github.com/checkpoint-restore/go-criu/v5/rpc"
Expand Down Expand Up @@ -78,12 +79,37 @@ checkpointed.`,
},
}

func getCheckpointImagePath(context *cli.Context) string {
func prepareImagePaths(context *cli.Context) (string, string, error) {
imagePath := context.String("image-path")
if imagePath == "" {
imagePath = getDefaultImagePath(context)
}
return imagePath

if err := os.MkdirAll(imagePath, 0600); err != nil {
return "", "", err
}

parentPath := context.String("parent-path")
if parentPath == "" {
return imagePath, parentPath, nil
}

if filepath.IsAbs(parentPath) {
return "", "", errors.New("--parent-path must be relative")
}

realParent := filepath.Join(imagePath, parentPath)
fi, err := os.Stat(realParent)
if err == nil && !fi.IsDir() {
err = &os.PathError{Path: realParent, Err: unix.ENOTDIR}
}

if err != nil {
return "", "", fmt.Errorf("invalid --parent-path: %w", err)
}

return imagePath, parentPath, nil

}

func setPageServer(context *cli.Context, options *libcontainer.CriuOpts) {
Expand Down
7 changes: 4 additions & 3 deletions restore.go
Original file line number Diff line number Diff line change
Expand Up @@ -121,14 +121,15 @@ using the runc checkpoint command.`,
}

func criuOptions(context *cli.Context) *libcontainer.CriuOpts {
imagePath := getCheckpointImagePath(context)
if err := os.MkdirAll(imagePath, 0755); err != nil {
imagePath, parentPath, err := prepareImagePaths(context)
if err != nil {
fatal(err)
}

return &libcontainer.CriuOpts{
ImagesDirectory: imagePath,
WorkDirectory: context.String("work-path"),
ParentImage: context.String("parent-path"),
ParentImage: parentPath,
LeaveRunning: context.Bool("leave-running"),
TcpEstablished: context.Bool("tcp-established"),
ExternalUnixConnections: context.Bool("ext-unix-sk"),
Expand Down
22 changes: 21 additions & 1 deletion tests/integration/checkpoint.bats
Original file line number Diff line number Diff line change
Expand Up @@ -144,6 +144,23 @@ function simple_cr() {
simple_cr
}

@test "checkpoint --pre-dump (bad --parent-path)" {
runc run -d --console-socket "$CONSOLE_SOCKET" test_busybox
[ "$status" -eq 0 ]

testcontainer test_busybox running

# runc should fail with absolute parent image path.
runc --criu "$CRIU" checkpoint --parent-path "$(pwd)"/parent-dir --work-path ./work-dir --image-path ./image-dir test_busybox
[[ "${output}" == *"--parent-path"* ]]
[ "$status" -ne 0 ]

# runc should fail with invalid parent image path.
runc --criu "$CRIU" checkpoint --parent-path ./parent-dir --work-path ./work-dir --image-path ./image-dir test_busybox
[[ "${output}" == *"--parent-path"* ]]
[ "$status" -ne 0 ]
}

@test "checkpoint --pre-dump and restore" {
setup_pipes
runc_run_with_pipes test_busybox
Expand All @@ -159,10 +176,13 @@ function simple_cr() {
# checkpoint the running container
mkdir image-dir
mkdir work-dir
runc --criu "$CRIU" checkpoint --parent-path ./parent-dir --work-path ./work-dir --image-path ./image-dir test_busybox
runc --criu "$CRIU" checkpoint --parent-path ../parent-dir --work-path ./work-dir --image-path ./image-dir test_busybox
grep -B 5 Error ./work-dir/dump.log || true
[ "$status" -eq 0 ]

# check parent path is valid
[ -e ./image-dir/parent ]

# after checkpoint busybox is no longer running
testcontainer test_busybox checkpointed

Expand Down

0 comments on commit fc8a0d9

Please sign in to comment.