From 28bb26856325f973c56b19ac9d2939d81abd9ca6 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 6 Jul 2024 02:31:01 +0000 Subject: [PATCH] fix(deps): update patch digest dependencies --- go.mod | 4 +-- go.sum | 4 +-- .../longhorn/go-common-libs/io/file.go | 32 ++++++++++++++++--- vendor/modules.txt | 2 +- 4 files changed, 33 insertions(+), 9 deletions(-) diff --git a/go.mod b/go.mod index 8274240..05023af 100644 --- a/go.mod +++ b/go.mod @@ -2,11 +2,11 @@ module github.com/longhorn/go-spdk-helper go 1.22.0 -toolchain go1.22.4 +toolchain go1.22.5 require ( github.com/c9s/goprocinfo v0.0.0-20210130143923-c95fcf8c64a8 - github.com/longhorn/go-common-libs v0.0.0-20240627075631-d78642cff5e1 + github.com/longhorn/go-common-libs v0.0.0-20240702014532-ad3e7f0caf5c github.com/longhorn/nsfilelock v0.0.0-20200723175406-fa7c83ad0003 github.com/pkg/errors v0.9.1 github.com/sirupsen/logrus v1.9.3 diff --git a/go.sum b/go.sum index 06e13b2..57e98ae 100644 --- a/go.sum +++ b/go.sum @@ -18,8 +18,8 @@ github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= -github.com/longhorn/go-common-libs v0.0.0-20240627075631-d78642cff5e1 h1:VGSNK9AEL6r9UocxZ0LoFPv1mn/jcstEc3LDS3GedZk= -github.com/longhorn/go-common-libs v0.0.0-20240627075631-d78642cff5e1/go.mod h1:wpLEAlsDCnqBA7QfZg0gxYeR8MmLbWHbdidWYwnRbyM= +github.com/longhorn/go-common-libs v0.0.0-20240702014532-ad3e7f0caf5c h1:DQvBkqE7Ge3/8kIHMujCVQzDoROgFS7TOPwyShfuLBA= +github.com/longhorn/go-common-libs v0.0.0-20240702014532-ad3e7f0caf5c/go.mod h1:wpLEAlsDCnqBA7QfZg0gxYeR8MmLbWHbdidWYwnRbyM= github.com/longhorn/nsfilelock v0.0.0-20200723175406-fa7c83ad0003 h1:Jw9uANsGcHTxp6HcC++/vN17LfeuDmozHI2j6DoZf5E= github.com/longhorn/nsfilelock v0.0.0-20200723175406-fa7c83ad0003/go.mod h1:0CLeXlf59Lg6C0kjLSDf47ft73Dh37CwymYRKWwAn04= github.com/mitchellh/go-ps v1.0.0 h1:i6ampVEEF4wQFF+bkYfwYgY+F/uYJDktmvLPf7qIgjc= diff --git a/vendor/github.com/longhorn/go-common-libs/io/file.go b/vendor/github.com/longhorn/go-common-libs/io/file.go index 9bd9d4c..d4ad1c0 100644 --- a/vendor/github.com/longhorn/go-common-libs/io/file.go +++ b/vendor/github.com/longhorn/go-common-libs/io/file.go @@ -327,7 +327,8 @@ func IsDirectoryEmpty(directory string) (bool, error) { return false, nil } -// CheckIsFileSizeSame verifies if all files in the provided paths have the same size. +// CheckIsFileSizeSame verifies if all files in the provided paths have the same +// apparent and actual size. // It returns an error if any file is a directory, does not exist, or has a different size. func CheckIsFileSizeSame(paths ...string) error { referenceInfo, err := os.Stat(paths[0]) @@ -339,7 +340,12 @@ func CheckIsFileSizeSame(paths ...string) error { return errors.Errorf("file %v is a directory", paths[0]) } - referenceSize := referenceInfo.Size() + referenceApparentSize := referenceInfo.Size() + + referenceActualSize, err := getFileBlockSizeEstimate(paths[0]) + if err != nil { + return err + } for _, path := range paths { fileInfo, err := os.Stat(path) @@ -352,10 +358,28 @@ func CheckIsFileSizeSame(paths ...string) error { } - if fileInfo.Size() != referenceSize { - return errors.Errorf("file %v size %v is not equal to %v", path, fileInfo.Size(), referenceSize) + if fileInfo.Size() != referenceApparentSize { + return errors.Errorf("file %v apparent size %v is not equal to %v", path, fileInfo.Size(), referenceApparentSize) + } + + actualSize, err := getFileBlockSizeEstimate(path) + if err != nil { + return err + } + + if actualSize != referenceActualSize { + return errors.Errorf("file %v actual size %v is not equal to %v", path, actualSize, referenceActualSize) } } return nil } + +func getFileBlockSizeEstimate(path string) (uint64, error) { + var stat syscall.Stat_t + if err := syscall.Stat(path, &stat); err != nil { + return 0, err + } + + return uint64(stat.Blocks) * uint64(stat.Blksize), nil +} diff --git a/vendor/modules.txt b/vendor/modules.txt index f9598da..cd1b76d 100644 --- a/vendor/modules.txt +++ b/vendor/modules.txt @@ -17,7 +17,7 @@ github.com/kr/pretty # github.com/kr/text v0.2.0 ## explicit github.com/kr/text -# github.com/longhorn/go-common-libs v0.0.0-20240627075631-d78642cff5e1 +# github.com/longhorn/go-common-libs v0.0.0-20240702014532-ad3e7f0caf5c ## explicit; go 1.22.0 github.com/longhorn/go-common-libs/exec github.com/longhorn/go-common-libs/io