Files
podman/libpod/runtime_migrate_linux.go
Kir Kolyshkin 7f7b35356f Replace os.Is* error checks with errors.Is
Using os.Is{Exist,NotExist,Permission} checks is not recommended in the
new code (see official documentation). While using it in the existing
code is OK, it may still result in a subtle errors later (for a specific
example of that, see [1]).

Replace those with errors.Is.

Generated by:

	gofmt -r 'os.IsExist(a) -> errors.Is(a, os.ErrExist)' -w .
	gofmt -r 'os.IsNotExist(a) -> errors.Is(a, os.ErrNotExist)' -w .
	gofmt -r 'os.IsPermission(a) -> errors.Is(a, os.ErrPermission)' -w .
	goimports -w .
	git diff vendor test/tools/vendor | patch -p1 -R

[1]: https://github.com/opencontainers/runc/pull/5061
Signed-off-by: Kir Kolyshkin <kolyshkin@gmail.com>
2026-05-21 13:09:42 -07:00

50 lines
1.2 KiB
Go

//go:build !remote
package libpod
import (
"errors"
"fmt"
"os"
"strconv"
"syscall"
"github.com/sirupsen/logrus"
"go.podman.io/podman/v6/pkg/rootless"
"go.podman.io/podman/v6/pkg/util"
)
func (r *Runtime) stopPauseProcess() error {
if rootless.IsRootless() {
stateDir, err := util.GetRootlessStateDir()
if err != nil {
return fmt.Errorf("could not get rootless state directory: %w", err)
}
nsHandlesPath := rootless.GetNamespaceHandlesPath(stateDir)
if err := os.Remove(nsHandlesPath); err != nil && !errors.Is(err, os.ErrNotExist) {
logrus.Warnf("Failed to remove namespace handles file %s: %v", nsHandlesPath, err)
}
pausePidPath := rootless.GetPausePidPath(stateDir)
data, err := os.ReadFile(pausePidPath)
if err != nil {
if errors.Is(err, os.ErrNotExist) {
return nil
}
return fmt.Errorf("cannot read pause process pid file: %w", err)
}
pausePid, err := strconv.Atoi(string(data))
if err != nil {
return fmt.Errorf("cannot parse pause pid file %s: %w", pausePidPath, err)
}
if err := os.Remove(pausePidPath); err != nil {
return fmt.Errorf("cannot delete pause pid file %s: %w", pausePidPath, err)
}
if err := syscall.Kill(pausePid, syscall.SIGKILL); err != nil {
return err
}
}
return nil
}