From 3805a470a9ea46c2e56a299f799d55276d5e3a9a Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Mon, 27 Nov 2023 20:16:59 +0800 Subject: [PATCH 1/6] Enable dupword linter. Signed-off-by: Xun Jiang --- golangci.yaml | 1 + pkg/apis/velero/v1/labels_annotations.go | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/golangci.yaml b/golangci.yaml index bdd7b5d068..31ea6a55da 100644 --- a/golangci.yaml +++ b/golangci.yaml @@ -326,6 +326,7 @@ linters: - unused - usestdlibvars - whitespace + - dupword fast: false diff --git a/pkg/apis/velero/v1/labels_annotations.go b/pkg/apis/velero/v1/labels_annotations.go index 675546ef95..08b6b24405 100644 --- a/pkg/apis/velero/v1/labels_annotations.go +++ b/pkg/apis/velero/v1/labels_annotations.go @@ -83,7 +83,7 @@ const ( // AsyncOperationIDLabel is the label key used to identify the async operation ID AsyncOperationIDLabel = "velero.io/async-operation-id" - // PVCNameLabel is the label key used to identify the the PVC's namespace and name. + // PVCNameLabel is the label key used to identify the PVC's namespace and name. // The format is /. PVCNamespaceNameLabel = "velero.io/pvc-namespace-name" From cddc11e0006f1a1d8d8e71136a492668fc4ed08e Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Mon, 27 Nov 2023 20:41:22 +0800 Subject: [PATCH 2/6] Enable linter errchkjson. Signed-off-by: Xun Jiang --- golangci.yaml | 1 + pkg/backup/backup.go | 7 ++++++- pkg/cmd/util/output/describe.go | 2 +- pkg/controller/backup_deletion_controller.go | 5 ++++- pkg/datamover/dataupload_delete_action.go | 7 +++++-- 5 files changed, 17 insertions(+), 5 deletions(-) diff --git a/golangci.yaml b/golangci.yaml index 31ea6a55da..3e6a8b568c 100644 --- a/golangci.yaml +++ b/golangci.yaml @@ -327,6 +327,7 @@ linters: - usestdlibvars - whitespace - dupword + - errchkjson fast: false diff --git a/pkg/backup/backup.go b/pkg/backup/backup.go index 70fbf01379..397453df09 100644 --- a/pkg/backup/backup.go +++ b/pkg/backup/backup.go @@ -438,8 +438,13 @@ func (kb *kubernetesBackupper) BackupWithResolvers(log logrus.FieldLogger, if err := kube.PatchResource(backupRequest.Backup, updated, kb.kbClient); err != nil { log.WithError(errors.WithStack((err))).Warn("Got error trying to update backup's status.progress and hook status") } - skippedPVSummary, _ := json.Marshal(backupRequest.SkippedPVTracker.Summary()) + + var skippedPVSummary []byte + if skippedPVSummary, err = json.Marshal(backupRequest.SkippedPVTracker.Summary()); err != nil { + log.WithError(errors.WithStack(err)).Warn("Fail to generate skipped PV summary.") + } log.Infof("Summary for skipped PVs: %s", skippedPVSummary) + backupRequest.Status.Progress = &velerov1api.BackupProgress{TotalItems: len(backupRequest.BackedUpItems), ItemsBackedUp: len(backupRequest.BackedUpItems)} log.WithField("progress", "").Infof("Backed up a total of %d items", len(backupRequest.BackedUpItems)) diff --git a/pkg/cmd/util/output/describe.go b/pkg/cmd/util/output/describe.go index d4f6e9e4f1..464ffa1470 100644 --- a/pkg/cmd/util/output/describe.go +++ b/pkg/cmd/util/output/describe.go @@ -164,6 +164,6 @@ func (d *StructuredDescriber) JSONEncode() string { encoder := json.NewEncoder(byteBuffer) encoder.SetEscapeHTML(false) encoder.SetIndent("", " ") - _ = encoder.Encode(d.output) + encoder.Encode(d.output) return byteBuffer.String() } diff --git a/pkg/controller/backup_deletion_controller.go b/pkg/controller/backup_deletion_controller.go index af439b834f..5c60ecf431 100644 --- a/pkg/controller/backup_deletion_controller.go +++ b/pkg/controller/backup_deletion_controller.go @@ -544,7 +544,10 @@ func (r *backupDeletionReconciler) deleteMovedSnapshots(ctx context.Context, bac for i := range list.Items { cm := list.Items[i] snapshot := repository.SnapshotIdentifier{} - b, _ := json.Marshal(cm.Data) + b, err := json.Marshal(cm.Data) + if err != nil { + r.logger.WithError(err).Infof("Fail to encode JSON: %v", cm.Data) + } if err := json.Unmarshal(b, &snapshot); err != nil { errs = append(errs, errors.Wrapf(err, "failed to unmarshal snapshot info")) continue diff --git a/pkg/datamover/dataupload_delete_action.go b/pkg/datamover/dataupload_delete_action.go index 7810979290..3fb3941c1a 100644 --- a/pkg/datamover/dataupload_delete_action.go +++ b/pkg/datamover/dataupload_delete_action.go @@ -58,9 +58,12 @@ func genConfigmap(bak *velerov1.Backup, du velerov2alpha1.DataUpload) *corev1api SnapshotID: du.Status.SnapshotID, RepositoryType: GetUploaderType(du.Spec.DataMover), } - b, _ := json.Marshal(snapshot) + b, err := json.Marshal(snapshot) + if err != nil { + return nil + } data := make(map[string]string) - _ = json.Unmarshal(b, &data) + json.Unmarshal(b, &data) return &corev1api.ConfigMap{ TypeMeta: metav1.TypeMeta{ APIVersion: corev1api.SchemeGroupVersion.String(), From dbd1a12d9f224f80eb1cf9105c1602e18b25fbd6 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Tue, 28 Nov 2023 10:39:16 +0800 Subject: [PATCH 3/6] Add nilerr and ginkgolinter linter. Signed-off-by: Xun Jiang --- golangci.yaml | 2 ++ pkg/controller/data_download_controller.go | 1 + pkg/podvolume/restorer.go | 1 + 3 files changed, 4 insertions(+) diff --git a/golangci.yaml b/golangci.yaml index 3e6a8b568c..48353ef6fc 100644 --- a/golangci.yaml +++ b/golangci.yaml @@ -328,6 +328,8 @@ linters: - whitespace - dupword - errchkjson + - ginkgolinter + - nilerr fast: false diff --git a/pkg/controller/data_download_controller.go b/pkg/controller/data_download_controller.go index 065c48a5f4..e09bac1f51 100644 --- a/pkg/controller/data_download_controller.go +++ b/pkg/controller/data_download_controller.go @@ -151,6 +151,7 @@ func (r *DataDownloadReconciler) Reconcile(ctx context.Context, req ctrl.Request log.Info("Data download starting") if _, err := r.getTargetPVC(ctx, dd); err != nil { + log.WithField("error", err).Debugf("Cannot find target PVC for DataDownload yet. Retry later.") return ctrl.Result{Requeue: true}, nil } diff --git a/pkg/podvolume/restorer.go b/pkg/podvolume/restorer.go index d54a7e66cd..e88f704322 100644 --- a/pkg/podvolume/restorer.go +++ b/pkg/podvolume/restorer.go @@ -199,6 +199,7 @@ func (r *restorer) RestorePodVolumes(data RestoreData) []error { err = kube.IsPodScheduled(newObj) if err != nil { + r.log.WithField("error", err).Debugf("Pod %s/%s is not scheduled yet", newObj.GetNamespace(), newObj.GetName()) return false, nil } return true, nil From ec03d1ebce5f7d371ab0aeab707d75d64f339b7b Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Tue, 28 Nov 2023 10:57:35 +0800 Subject: [PATCH 4/6] Add noctx linter. Signed-off-by: Xun Jiang --- golangci.yaml | 1 + pkg/cmd/util/downloadrequest/downloadrequest.go | 2 +- 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/golangci.yaml b/golangci.yaml index 48353ef6fc..d3de5a0b35 100644 --- a/golangci.yaml +++ b/golangci.yaml @@ -330,6 +330,7 @@ linters: - errchkjson - ginkgolinter - nilerr + - noctx fast: false diff --git a/pkg/cmd/util/downloadrequest/downloadrequest.go b/pkg/cmd/util/downloadrequest/downloadrequest.go index 76b15a0199..b7a016bb9c 100644 --- a/pkg/cmd/util/downloadrequest/downloadrequest.go +++ b/pkg/cmd/util/downloadrequest/downloadrequest.go @@ -123,7 +123,7 @@ func Stream(ctx context.Context, kbClient kbclient.Client, namespace, name strin ExpectContinueTimeout: defaultTransport.ExpectContinueTimeout, } - httpReq, err := http.NewRequest(http.MethodGet, created.Status.DownloadURL, nil) + httpReq, err := http.NewRequestWithContext(ctx, http.MethodGet, created.Status.DownloadURL, nil) if err != nil { return err } From d70535b6d28727278b516708e591d802ffa586ae Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Tue, 28 Nov 2023 12:26:13 +0800 Subject: [PATCH 5/6] Add nolintlint linter. Signed-off-by: Xun Jiang --- golangci.yaml | 1 + pkg/plugin/clientmgmt/process/client_builder.go | 2 +- pkg/restic/command.go | 2 +- 3 files changed, 3 insertions(+), 2 deletions(-) diff --git a/golangci.yaml b/golangci.yaml index d3de5a0b35..88b3b77237 100644 --- a/golangci.yaml +++ b/golangci.yaml @@ -331,6 +331,7 @@ linters: - ginkgolinter - nilerr - noctx + - nolintlint fast: false diff --git a/pkg/plugin/clientmgmt/process/client_builder.go b/pkg/plugin/clientmgmt/process/client_builder.go index 38c350f033..d414457796 100644 --- a/pkg/plugin/clientmgmt/process/client_builder.go +++ b/pkg/plugin/clientmgmt/process/client_builder.go @@ -80,7 +80,7 @@ func (b *clientBuilder) clientConfig() *hcplugin.ClientConfig { string(common.PluginKindDeleteItemAction): framework.NewDeleteItemActionPlugin(common.ClientLogger(b.clientLogger)), }, Logger: b.pluginLogger, - Cmd: exec.Command(b.commandName, b.commandArgs...), //nolint + Cmd: exec.Command(b.commandName, b.commandArgs...), //nolint:gosec // Internal call. No need to check the command line. } } diff --git a/pkg/restic/command.go b/pkg/restic/command.go index a484a53161..ef0ba56553 100644 --- a/pkg/restic/command.go +++ b/pkg/restic/command.go @@ -77,7 +77,7 @@ func (c *Command) String() string { // Cmd returns an exec.Cmd for the command. func (c *Command) Cmd() *exec.Cmd { parts := c.StringSlice() - cmd := exec.Command(parts[0], parts[1:]...) //nolint + cmd := exec.Command(parts[0], parts[1:]...) //nolint:gosec // Internal call. No need to check the parameter. cmd.Dir = c.Dir if len(c.Env) > 0 { From f5c159ce56d7ed0c9a8d406c65de9798145b97c9 Mon Sep 17 00:00:00 2001 From: Xun Jiang Date: Tue, 28 Nov 2023 15:23:13 +0800 Subject: [PATCH 6/6] Resolve linter issues. Signed-off-by: Xun Jiang --- changelogs/unreleased/7151-blackpiglet | 1 + hack/build-image/Dockerfile | 2 +- pkg/archive/extractor.go | 2 +- pkg/backup/backup.go | 6 +++--- pkg/builder/server_status_request_builder.go | 2 +- pkg/cmd/cli/nodeagent/server.go | 2 +- pkg/cmd/server/server.go | 2 +- pkg/cmd/util/downloadrequest/downloadrequest.go | 2 +- pkg/cmd/util/output/describe.go | 7 ++++++- pkg/controller/backup_controller.go | 2 +- pkg/controller/backup_deletion_controller.go | 3 ++- pkg/controller/pod_volume_restore_controller.go | 2 +- pkg/datamover/dataupload_delete_action.go | 4 +++- pkg/metrics/metrics.go | 2 +- pkg/repository/config/aws.go | 2 +- pkg/repository/config/gcp.go | 2 +- pkg/repository/keys/keys.go | 2 +- pkg/restore/restore.go | 6 +++--- pkg/uploader/kopia/progress.go | 2 +- 19 files changed, 31 insertions(+), 22 deletions(-) create mode 100644 changelogs/unreleased/7151-blackpiglet diff --git a/changelogs/unreleased/7151-blackpiglet b/changelogs/unreleased/7151-blackpiglet new file mode 100644 index 0000000000..6548832b16 --- /dev/null +++ b/changelogs/unreleased/7151-blackpiglet @@ -0,0 +1 @@ +Add more linters part 2. \ No newline at end of file diff --git a/hack/build-image/Dockerfile b/hack/build-image/Dockerfile index e2166b39f2..5a7bbc6f52 100644 --- a/hack/build-image/Dockerfile +++ b/hack/build-image/Dockerfile @@ -56,7 +56,7 @@ RUN wget --quiet https://github.com/goreleaser/goreleaser/releases/download/v1.1 chmod +x /usr/bin/goreleaser # get golangci-lint -RUN curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.51.0 +RUN curl -sSfL https://raw.githubusercontent.com/golangci/golangci-lint/master/install.sh | sh -s -- -b $(go env GOPATH)/bin v1.54.2 # install kubectl RUN curl -LO https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl diff --git a/pkg/archive/extractor.go b/pkg/archive/extractor.go index 7129b4e755..87d9ab413c 100644 --- a/pkg/archive/extractor.go +++ b/pkg/archive/extractor.go @@ -84,7 +84,7 @@ func (e *Extractor) readBackup(tarRdr *tar.Reader) (string, error) { return "", err } - target := filepath.Join(dir, header.Name) //nolint:gosec + target := filepath.Join(dir, header.Name) //nolint:gosec // Internal usage. No need to check. switch header.Typeflag { case tar.TypeDir: diff --git a/pkg/backup/backup.go b/pkg/backup/backup.go index 397453df09..67e20acb0e 100644 --- a/pkg/backup/backup.go +++ b/pkg/backup/backup.go @@ -439,11 +439,11 @@ func (kb *kubernetesBackupper) BackupWithResolvers(log logrus.FieldLogger, log.WithError(errors.WithStack((err))).Warn("Got error trying to update backup's status.progress and hook status") } - var skippedPVSummary []byte - if skippedPVSummary, err = json.Marshal(backupRequest.SkippedPVTracker.Summary()); err != nil { + if skippedPVSummary, err := json.Marshal(backupRequest.SkippedPVTracker.Summary()); err != nil { log.WithError(errors.WithStack(err)).Warn("Fail to generate skipped PV summary.") + } else { + log.Infof("Summary for skipped PVs: %s", skippedPVSummary) } - log.Infof("Summary for skipped PVs: %s", skippedPVSummary) backupRequest.Status.Progress = &velerov1api.BackupProgress{TotalItems: len(backupRequest.BackedUpItems), ItemsBackedUp: len(backupRequest.BackedUpItems)} log.WithField("progress", "").Infof("Backed up a total of %d items", len(backupRequest.BackedUpItems)) diff --git a/pkg/builder/server_status_request_builder.go b/pkg/builder/server_status_request_builder.go index 9dcf9cfb66..bc88767180 100644 --- a/pkg/builder/server_status_request_builder.go +++ b/pkg/builder/server_status_request_builder.go @@ -29,7 +29,7 @@ type ServerStatusRequestBuilder struct { object *velerov1api.ServerStatusRequest } -// ForServerStatusRequest is the constructor for for a ServerStatusRequestBuilder. +// ForServerStatusRequest is the constructor for a ServerStatusRequestBuilder. func ForServerStatusRequest(ns, name, resourceVersion string) *ServerStatusRequestBuilder { return &ServerStatusRequestBuilder{ object: &velerov1api.ServerStatusRequest{ diff --git a/pkg/cmd/cli/nodeagent/server.go b/pkg/cmd/cli/nodeagent/server.go index 84e5612703..08de07f765 100644 --- a/pkg/cmd/cli/nodeagent/server.go +++ b/pkg/cmd/cli/nodeagent/server.go @@ -486,7 +486,7 @@ func (s *nodeAgentServer) getDataPathConcurrentNum(defaultNum int) int { concurrentNum := math.MaxInt32 for _, rule := range configs.DataPathConcurrency.PerNodeConfig { - selector, err := metav1.LabelSelectorAsSelector(&rule.NodeSelector) + selector, err := metav1.LabelSelectorAsSelector(&(rule.NodeSelector)) if err != nil { s.logger.WithError(err).Warnf("Failed to parse rule with label selector %s, skip it", rule.NodeSelector.String()) continue diff --git a/pkg/cmd/server/server.go b/pkg/cmd/server/server.go index ca8c49c3ce..5098a7b13f 100644 --- a/pkg/cmd/server/server.go +++ b/pkg/cmd/server/server.go @@ -248,7 +248,7 @@ type server struct { discoveryHelper velerodiscovery.Helper dynamicClient dynamic.Interface // controller-runtime client. the difference from the controller-manager's client - // is that the the controller-manager's client is limited to list namespaced-scoped + // is that the controller-manager's client is limited to list namespaced-scoped // resources in the namespace where Velero is installed, or the cluster-scoped // resources. The crClient doesn't have the limitation. crClient ctrlclient.Client diff --git a/pkg/cmd/util/downloadrequest/downloadrequest.go b/pkg/cmd/util/downloadrequest/downloadrequest.go index b7a016bb9c..9595c76259 100644 --- a/pkg/cmd/util/downloadrequest/downloadrequest.go +++ b/pkg/cmd/util/downloadrequest/downloadrequest.go @@ -111,7 +111,7 @@ func Stream(ctx context.Context, kbClient kbclient.Client, namespace, name strin httpClient := new(http.Client) httpClient.Transport = &http.Transport{ TLSClientConfig: &tls.Config{ - InsecureSkipVerify: insecureSkipTLSVerify, //nolint:gosec + InsecureSkipVerify: insecureSkipTLSVerify, //nolint:gosec // This parameter is useful for some scenarios. RootCAs: caPool, }, IdleConnTimeout: timeout, diff --git a/pkg/cmd/util/output/describe.go b/pkg/cmd/util/output/describe.go index 464ffa1470..c0ec080281 100644 --- a/pkg/cmd/util/output/describe.go +++ b/pkg/cmd/util/output/describe.go @@ -164,6 +164,11 @@ func (d *StructuredDescriber) JSONEncode() string { encoder := json.NewEncoder(byteBuffer) encoder.SetEscapeHTML(false) encoder.SetIndent("", " ") - encoder.Encode(d.output) + + err := encoder.Encode(d.output) + if err != nil { + fmt.Printf("fail to encode %s", err.Error()) + return "" + } return byteBuffer.String() } diff --git a/pkg/controller/backup_controller.go b/pkg/controller/backup_controller.go index e8a8c2eec8..bfbacc5418 100644 --- a/pkg/controller/backup_controller.go +++ b/pkg/controller/backup_controller.go @@ -1080,7 +1080,7 @@ func generateVolumeInfoForCSIVolumeSnapshot(backup *pkgbackup.Request, csiVolume SnapshotDataMoved: false, PreserveLocalSnapshot: true, OperationID: operation.Spec.OperationID, - StartTimestamp: &volumeSnapshot.CreationTimestamp, + StartTimestamp: &(volumeSnapshot.CreationTimestamp), CSISnapshotInfo: volume.CSISnapshotInfo{ VSCName: *volumeSnapshot.Status.BoundVolumeSnapshotContentName, Size: size, diff --git a/pkg/controller/backup_deletion_controller.go b/pkg/controller/backup_deletion_controller.go index 5c60ecf431..1b78734e2f 100644 --- a/pkg/controller/backup_deletion_controller.go +++ b/pkg/controller/backup_deletion_controller.go @@ -546,7 +546,8 @@ func (r *backupDeletionReconciler) deleteMovedSnapshots(ctx context.Context, bac snapshot := repository.SnapshotIdentifier{} b, err := json.Marshal(cm.Data) if err != nil { - r.logger.WithError(err).Infof("Fail to encode JSON: %v", cm.Data) + errs = append(errs, errors.Wrapf(err, "fail to marshal the snapshot info into JSON")) + continue } if err := json.Unmarshal(b, &snapshot); err != nil { errs = append(errs, errors.Wrapf(err, "failed to unmarshal snapshot info")) diff --git a/pkg/controller/pod_volume_restore_controller.go b/pkg/controller/pod_volume_restore_controller.go index 34d6c65511..eda541fc19 100644 --- a/pkg/controller/pod_volume_restore_controller.go +++ b/pkg/controller/pod_volume_restore_controller.go @@ -303,7 +303,7 @@ func (c *PodVolumeRestoreReconciler) OnDataPathCompleted(ctx context.Context, na // Write a done file with name= into the just-created .velero dir // within the volume. The velero init container on the pod is waiting // for this file to exist in each restored volume before completing. - if err := os.WriteFile(filepath.Join(volumePath, ".velero", string(restoreUID)), nil, 0644); err != nil { //nolint:gosec + if err := os.WriteFile(filepath.Join(volumePath, ".velero", string(restoreUID)), nil, 0644); err != nil { //nolint:gosec // Internal usage. No need to check. _, _ = c.errorOut(ctx, &pvr, err, "error writing done file", log) return } diff --git a/pkg/datamover/dataupload_delete_action.go b/pkg/datamover/dataupload_delete_action.go index 3fb3941c1a..f226c19672 100644 --- a/pkg/datamover/dataupload_delete_action.go +++ b/pkg/datamover/dataupload_delete_action.go @@ -63,7 +63,9 @@ func genConfigmap(bak *velerov1.Backup, du velerov2alpha1.DataUpload) *corev1api return nil } data := make(map[string]string) - json.Unmarshal(b, &data) + if err := json.Unmarshal(b, &data); err != nil { + return nil + } return &corev1api.ConfigMap{ TypeMeta: metav1.TypeMeta{ APIVersion: corev1api.SchemeGroupVersion.String(), diff --git a/pkg/metrics/metrics.go b/pkg/metrics/metrics.go index 593d642fd0..b1bcaf765a 100644 --- a/pkg/metrics/metrics.go +++ b/pkg/metrics/metrics.go @@ -69,7 +69,7 @@ const ( // data mover metrics DataUploadSuccessTotal = "data_upload_success_total" DataUploadFailureTotal = "data_upload_failure_total" - DataUploadCancelTotal = "data_upload_cancel_total" + DataUploadCancelTotal = "data_upload_cancel_total" //nolint:gosec // Not a hard code secret. DataDownloadSuccessTotal = "data_download_success_total" DataDownloadFailureTotal = "data_download_failure_total" DataDownloadCancelTotal = "data_download_cancel_total" diff --git a/pkg/repository/config/aws.go b/pkg/repository/config/aws.go index d7208068fa..6cb87f0a62 100644 --- a/pkg/repository/config/aws.go +++ b/pkg/repository/config/aws.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -//nolint:gosec +//nolint:gosec // Internal usage. No need to check. package config import ( diff --git a/pkg/repository/config/gcp.go b/pkg/repository/config/gcp.go index 8beb8a016c..809d74d254 100644 --- a/pkg/repository/config/gcp.go +++ b/pkg/repository/config/gcp.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -//nolint:gosec +//nolint:gosec // Internal usage. No need to check. package config import "os" diff --git a/pkg/repository/keys/keys.go b/pkg/repository/keys/keys.go index 48d3bd75ca..21423afe09 100644 --- a/pkg/repository/keys/keys.go +++ b/pkg/repository/keys/keys.go @@ -14,7 +14,7 @@ See the License for the specific language governing permissions and limitations under the License. */ -//nolint:gosec +//nolint:gosec // Internal call. No need to check. package keys import ( diff --git a/pkg/restore/restore.go b/pkg/restore/restore.go index 98fbff01dd..57a6156efb 100644 --- a/pkg/restore/restore.go +++ b/pkg/restore/restore.go @@ -1900,7 +1900,7 @@ func shouldRenamePV(ctx *restoreContext, obj *unstructured.Unstructured, client // remapClaimRefNS remaps a PersistentVolume's claimRef.Namespace based on a // restore's NamespaceMappings, if necessary. Returns true if the namespace was // remapped, false if it was not required. -func remapClaimRefNS(ctx *restoreContext, obj *unstructured.Unstructured) (bool, error) { //nolint:unparam +func remapClaimRefNS(ctx *restoreContext, obj *unstructured.Unstructured) (bool, error) { //nolint:unparam // ignore the result 0 (bool) is never used warning. if len(ctx.restore.Spec.NamespaceMapping) == 0 { ctx.log.Debug("Persistent volume does not need to have the claimRef.namespace remapped because restore is not remapping any namespaces") return false, nil @@ -2315,7 +2315,7 @@ func (ctx *restoreContext) getOrderedResourceCollection( // getSelectedRestoreableItems applies Kubernetes selectors on individual items // of each resource type to create a list of items which will be actually // restored. -func (ctx *restoreContext) getSelectedRestoreableItems(resource string, namespaceMapping map[string]string, originalNamespace string, items []string) (restoreableResource, results.Result, results.Result) { +func (ctx *restoreContext) getSelectedRestoreableItems(resource string, namespaceMapping map[string]string, originalNamespace string, items []string) (restoreableResource, results.Result, results.Result) { //nolint:unparam // Ignore the warnings is always nil warning. warnings, errs := results.Result{}, results.Result{} restorable := restoreableResource{ @@ -2430,7 +2430,7 @@ func removeRestoreLabels(obj metav1.Object) { } // updates the backup/restore labels -func (ctx *restoreContext) updateBackupRestoreLabels(fromCluster, fromClusterWithLabels *unstructured.Unstructured, namespace string, resourceClient client.Dynamic) (warnings, errs results.Result) { +func (ctx *restoreContext) updateBackupRestoreLabels(fromCluster, fromClusterWithLabels *unstructured.Unstructured, namespace string, resourceClient client.Dynamic) (warnings, errs results.Result) { //nolint:unparam // Ignore the warnings is nil warning. patchBytes, err := generatePatch(fromCluster, fromClusterWithLabels) if err != nil { ctx.log.Errorf("error generating patch for %s %s: %v", fromCluster.GroupVersionKind().Kind, kube.NamespaceAndName(fromCluster), err) diff --git a/pkg/uploader/kopia/progress.go b/pkg/uploader/kopia/progress.go index fab980a64e..6b38b6da51 100644 --- a/pkg/uploader/kopia/progress.go +++ b/pkg/uploader/kopia/progress.go @@ -33,7 +33,7 @@ type Throttle struct { func (t *Throttle) ShouldOutput() bool { nextOutputTimeUnixNano := atomic.LoadInt64(&t.throttle) - if nowNano := time.Now().UnixNano(); nowNano > nextOutputTimeUnixNano { //nolint:forbidigo + if nowNano := time.Now().UnixNano(); nowNano > nextOutputTimeUnixNano { if atomic.CompareAndSwapInt64(&t.throttle, nextOutputTimeUnixNano, nowNano+t.interval.Nanoseconds()) { return true }