From 52c3a4d56a6bcd1f14d4fcbb61e5882b79e11b02 Mon Sep 17 00:00:00 2001 From: Illyoung Choi Date: Wed, 4 Sep 2024 13:19:53 -0700 Subject: [PATCH] Fix bput bug in setting staging dir --- cmd/subcmd/bput.go | 8 ++++---- commons/bundle_transfer.go | 25 ++++++++++++++++++------- 2 files changed, 22 insertions(+), 11 deletions(-) diff --git a/cmd/subcmd/bput.go b/cmd/subcmd/bput.go index 7bc97f3..66056b8 100644 --- a/cmd/subcmd/bput.go +++ b/cmd/subcmd/bput.go @@ -200,19 +200,19 @@ func (bput *BputCommand) Process() error { } // bundle root path - bundleRootPath := "/" - bundleRootPath, err = commons.GetCommonRootLocalDirPath(bput.sourcePaths) + localBundleRootPath := string(filepath.Separator) + localBundleRootPath, err = commons.GetCommonRootLocalDirPath(bput.sourcePaths) if err != nil { return xerrors.Errorf("failed to get a common root directory for source paths: %w", err) } if !bput.noRootFlagValues.NoRoot { // use parent dir - bundleRootPath = filepath.Dir(bundleRootPath) + localBundleRootPath = filepath.Dir(localBundleRootPath) } // bundle transfer manager - bput.bundleTransferManager = commons.NewBundleTransferManager(bput.filesystem, bput.transferReportManager, bput.targetPath, bundleRootPath, bput.bundleTransferFlagValues.MinFileNum, bput.bundleTransferFlagValues.MaxFileNum, bput.bundleTransferFlagValues.MaxFileSize, bput.parallelTransferFlagValues.SingleThread, bput.parallelTransferFlagValues.ThreadNumber, bput.parallelTransferFlagValues.RedirectToResource, bput.parallelTransferFlagValues.Icat, bput.bundleTransferFlagValues.LocalTempPath, bput.bundleTransferFlagValues.IRODSTempPath, bput.bundleTransferFlagValues.NoBulkRegistration, bput.progressFlagValues.ShowProgress, bput.progressFlagValues.ShowFullPath) + bput.bundleTransferManager = commons.NewBundleTransferManager(bput.filesystem, bput.transferReportManager, bput.targetPath, localBundleRootPath, bput.bundleTransferFlagValues.MinFileNum, bput.bundleTransferFlagValues.MaxFileNum, bput.bundleTransferFlagValues.MaxFileSize, bput.parallelTransferFlagValues.SingleThread, bput.parallelTransferFlagValues.ThreadNumber, bput.parallelTransferFlagValues.RedirectToResource, bput.parallelTransferFlagValues.Icat, bput.bundleTransferFlagValues.LocalTempPath, stagingDirPath, bput.bundleTransferFlagValues.NoBulkRegistration, bput.progressFlagValues.ShowProgress, bput.progressFlagValues.ShowFullPath) bput.bundleTransferManager.Start() // run diff --git a/commons/bundle_transfer.go b/commons/bundle_transfer.go index f353004..43c1cf1 100644 --- a/commons/bundle_transfer.go +++ b/commons/bundle_transfer.go @@ -130,13 +130,24 @@ func (bundle *Bundle) Add(sourceStat fs.FileInfo, sourcePath string) error { } func (bundle *Bundle) updateBundlePath() error { + logger := log.WithFields(log.Fields{ + "package": "commons", + "struct": "BundleTransferManager", + "function": "updateBundlePath", + }) + filename, err := bundle.GetBundleFilename() if err != nil { return xerrors.Errorf("failed to get bundle filename: %w", err) } + logger.Debugf("bundle local temp path %q, irods temp path %q", bundle.manager.localTempDirPath, bundle.manager.irodsTempDirPath) + bundle.LocalBundlePath = filepath.Join(bundle.manager.localTempDirPath, filename) - bundle.IRODSBundlePath = filepath.Join(bundle.manager.irodsTempDirPath, filename) + bundle.IRODSBundlePath = path.Join(bundle.manager.irodsTempDirPath, filename) + + logger.Debugf("bundle local path %q, irods path %q", bundle.LocalBundlePath, bundle.IRODSBundlePath) + return nil } @@ -160,7 +171,7 @@ type BundleTransferManager struct { nextBundleIndex int64 pendingBundles chan *Bundle bundles []*Bundle - bundleRootPath string + localBundleRootPath string minBundleFileNum int maxBundleFileNum int maxBundleFileSize int64 @@ -187,7 +198,7 @@ type BundleTransferManager struct { } // NewBundleTransferManager creates a new BundleTransferManager -func NewBundleTransferManager(fs *irodsclient_fs.FileSystem, transferReportManager *TransferReportManager, irodsDestPath string, bundleRootPath string, minBundleFileNum int, maxBundleFileNum int, maxBundleFileSize int64, singleThreaded bool, uploadThreadNum int, redirectToResource bool, useIcat bool, localTempDirPath string, irodsTempDirPath string, noBulkReg bool, showProgress bool, showFullPath bool) *BundleTransferManager { +func NewBundleTransferManager(fs *irodsclient_fs.FileSystem, transferReportManager *TransferReportManager, irodsDestPath string, localBundleRootPath string, minBundleFileNum int, maxBundleFileNum int, maxBundleFileSize int64, singleThreaded bool, uploadThreadNum int, redirectToResource bool, useIcat bool, localTempDirPath string, irodsTempDirPath string, noBulkReg bool, showProgress bool, showFullPath bool) *BundleTransferManager { cwd := GetCWD() home := GetHomeDir() zone := GetZone() @@ -201,7 +212,7 @@ func NewBundleTransferManager(fs *irodsclient_fs.FileSystem, transferReportManag nextBundleIndex: 0, pendingBundles: make(chan *Bundle, 100), bundles: []*Bundle{}, - bundleRootPath: "/", + localBundleRootPath: localBundleRootPath, minBundleFileNum: minBundleFileNum, maxBundleFileNum: maxBundleFileNum, maxBundleFileSize: maxBundleFileSize, @@ -260,9 +271,9 @@ func (manager *BundleTransferManager) progress(name string, processed int64, tot } func (manager *BundleTransferManager) GetTargetPath(localPath string) (string, error) { - relPath, err := filepath.Rel(manager.bundleRootPath, localPath) + relPath, err := filepath.Rel(manager.localBundleRootPath, localPath) if err != nil { - return "", xerrors.Errorf("failed to compute relative path %q to %q: %w", localPath, manager.bundleRootPath, err) + return "", xerrors.Errorf("failed to compute relative path %q to %q: %w", localPath, manager.localBundleRootPath, err) } return path.Join(manager.irodsDestPath, filepath.ToSlash(relPath)), nil @@ -841,7 +852,7 @@ func (manager *BundleTransferManager) processBundleTar(bundle *Bundle) error { entries[idx] = entry.LocalPath } - err := Tar(manager.bundleRootPath, entries, bundle.LocalBundlePath, callbackTar) + err := Tar(manager.localBundleRootPath, entries, bundle.LocalBundlePath, callbackTar) if err != nil { manager.progress(progressName, 0, totalFileNum, progress.UnitsDefault, true) return xerrors.Errorf("failed to create a tarball for bundle %d to %q: %w", bundle.Index, bundle.LocalBundlePath, err)