build: fix linting issues reported by running golangci-lint with different GOOS

This commit is contained in:
albertony 2024-04-18 09:36:22 +02:00
parent 159e274921
commit 7ee22fcdf9
23 changed files with 124 additions and 46 deletions

View file

@ -3,4 +3,5 @@
//go:build plan9 || solaris || js //go:build plan9 || solaris || js
// Package azureblob provides an interface to the Microsoft Azure blob object storage system
package azureblob package azureblob

View file

@ -3,4 +3,5 @@
//go:build plan9 || js //go:build plan9 || js
// Package azurefiles provides an interface to Microsoft Azure Files
package azurefiles package azurefiles

View file

@ -3,4 +3,5 @@
//go:build plan9 || js //go:build plan9 || js
// Package cache implements a virtual provider to cache existing remotes.
package cache package cache

View file

@ -1,3 +1,6 @@
//go:build !plan9 && !js
// +build !plan9,!js
package cache package cache
import bolt "go.etcd.io/bbolt" import bolt "go.etcd.io/bbolt"

View file

@ -3,4 +3,5 @@
//go:build plan9 //go:build plan9
// Package hdfs provides an interface to the HDFS storage system.
package hdfs package hdfs

View file

@ -23,9 +23,9 @@ func (f *Fs) About(ctx context.Context) (*fs.Usage, error) {
} }
bs := int64(s.Bsize) // nolint: unconvert bs := int64(s.Bsize) // nolint: unconvert
usage := &fs.Usage{ usage := &fs.Usage{
Total: fs.NewUsageValue(bs * int64(s.Blocks)), // quota of bytes that can be used Total: fs.NewUsageValue(bs * int64(s.Blocks)), //nolint: unconvert // quota of bytes that can be used
Used: fs.NewUsageValue(bs * int64(s.Blocks-s.Bfree)), // bytes in use Used: fs.NewUsageValue(bs * int64(s.Blocks-s.Bfree)), //nolint: unconvert // bytes in use
Free: fs.NewUsageValue(bs * int64(s.Bavail)), // bytes which can be uploaded before reaching the quota Free: fs.NewUsageValue(bs * int64(s.Bavail)), //nolint: unconvert // bytes which can be uploaded before reaching the quota
} }
return usage, nil return usage, nil
} }

View file

@ -1,4 +1,4 @@
//go:build plan9 || js //go:build dragonfly || plan9 || js
package local package local

View file

@ -1,6 +1,7 @@
// The pkg/xattr module doesn't compile for openbsd or plan9
//go:build openbsd || plan9 //go:build openbsd || plan9
// The pkg/xattr module doesn't compile for openbsd or plan9
package local package local
import "github.com/rclone/rclone/fs" import "github.com/rclone/rclone/fs"

View file

@ -3,4 +3,5 @@
//go:build plan9 || solaris || js //go:build plan9 || solaris || js
// Package oracleobjectstorage provides an interface to the OCI object storage system.
package oracleobjectstorage package oracleobjectstorage

View file

@ -3,4 +3,6 @@
//go:build plan9 || js //go:build plan9 || js
// Package qingstor provides an interface to QingStor object storage
// Home: https://www.qingcloud.com/
package qingstor package qingstor

View file

@ -3,4 +3,5 @@
//go:build plan9 //go:build plan9
// Package sftp provides a filesystem interface using github.com/pkg/sftp
package sftp package sftp

View file

@ -1,3 +1,4 @@
//go:build plan9 //go:build plan9
// Package storj provides an interface to Storj decentralized object storage.
package storj package storj

View file

@ -3,4 +3,5 @@
//go:build plan9 || js //go:build plan9 || js
// Package cachestats provides the cachestats command.
package cachestats package cachestats

View file

@ -3,4 +3,5 @@
//go:build plan9 || js //go:build plan9 || js
// Package ncdu implements a text based user interface for exploring a remote
package ncdu package ncdu

View file

@ -3,9 +3,10 @@
//go:build plan9 //go:build plan9
// Package ftp implements an FTP server for rclone
package ftp package ftp
import "github.com/spf13/cobra" import "github.com/spf13/cobra"
// Command definition is nil to show not implemented // Command definition is nil to show not implemented
var Command *cobra.Command = nil var Command *cobra.Command

View file

@ -3,9 +3,10 @@
//go:build plan9 //go:build plan9
// Package sftp implements an SFTP server to serve an rclone VFS
package sftp package sftp
import "github.com/spf13/cobra" import "github.com/spf13/cobra"
// Command definition is nil to show not implemented // Command definition is nil to show not implemented
var Command *cobra.Command = nil var Command *cobra.Command

View file

@ -2,7 +2,7 @@
package fserrors package fserrors
// IsErrNoSpace() on plan9 returns false because // IsErrNoSpace on plan9 returns false because
// plan9 does not support syscall.ENOSPC error. // plan9 does not support syscall.ENOSPC error.
func IsErrNoSpace(cause error) (isNoSpc bool) { func IsErrNoSpace(cause error) (isNoSpc bool) {
isNoSpc = false isNoSpc = false

View file

@ -0,0 +1,74 @@
//go:build !plan9
// +build !plan9
package fserrors
import (
"fmt"
"net"
"net/url"
"os"
"syscall"
"testing"
"github.com/stretchr/testify/assert"
)
// make a plausible network error with the underlying errno
func makeNetErr(errno syscall.Errno) error {
return &net.OpError{
Op: "write",
Net: "tcp",
Source: &net.TCPAddr{IP: net.ParseIP("127.0.0.1"), Port: 123},
Addr: &net.TCPAddr{IP: net.ParseIP("127.0.0.1"), Port: 8080},
Err: &os.SyscallError{
Syscall: "write",
Err: errno,
},
}
}
func TestWithSyscallCause(t *testing.T) {
for i, test := range []struct {
err error
wantRetriable bool
wantErr error
}{
{makeNetErr(syscall.EAGAIN), true, syscall.EAGAIN},
{makeNetErr(syscall.Errno(123123123)), false, syscall.Errno(123123123)},
} {
gotRetriable, gotErr := Cause(test.err)
what := fmt.Sprintf("test #%d: %v", i, test.err)
assert.Equal(t, test.wantErr, gotErr, what)
assert.Equal(t, test.wantRetriable, gotRetriable, what)
}
}
func TestWithSyscallShouldRetry(t *testing.T) {
for i, test := range []struct {
err error
want bool
}{
{makeNetErr(syscall.EAGAIN), true},
{makeNetErr(syscall.Errno(123123123)), false},
{
wrap(&url.Error{
Op: "post",
URL: "http://localhost/",
Err: makeNetErr(syscall.EPIPE),
}, "potato error"),
true,
},
{
wrap(&url.Error{
Op: "post",
URL: "http://localhost/",
Err: makeNetErr(syscall.Errno(123123123)),
}, "listing error"),
false,
},
} {
got := ShouldRetry(test.err)
assert.Equal(t, test.want, got, fmt.Sprintf("test #%d: %v", i, test.err))
}
}

View file

@ -5,10 +5,7 @@ import (
"errors" "errors"
"fmt" "fmt"
"io" "io"
"net"
"net/url" "net/url"
"os"
"syscall"
"testing" "testing"
"time" "time"
@ -41,20 +38,6 @@ func wrap(err error, message string) error {
var errUseOfClosedNetworkConnection = errors.New("use of closed network connection") var errUseOfClosedNetworkConnection = errors.New("use of closed network connection")
// make a plausible network error with the underlying errno
func makeNetErr(errno syscall.Errno) error {
return &net.OpError{
Op: "write",
Net: "tcp",
Source: &net.TCPAddr{IP: net.ParseIP("127.0.0.1"), Port: 123},
Addr: &net.TCPAddr{IP: net.ParseIP("127.0.0.1"), Port: 8080},
Err: &os.SyscallError{
Syscall: "write",
Err: errno,
},
}
}
type myError1 struct { type myError1 struct {
Err error Err error
} }
@ -121,8 +104,6 @@ func TestCause(t *testing.T) {
{fmt.Errorf("potato: %w", errPotato), false, errPotato}, {fmt.Errorf("potato: %w", errPotato), false, errPotato},
{fmt.Errorf("potato2: %w", wrap(errPotato, "potato")), false, errPotato}, {fmt.Errorf("potato2: %w", wrap(errPotato, "potato")), false, errPotato},
{errUseOfClosedNetworkConnection, false, errUseOfClosedNetworkConnection}, {errUseOfClosedNetworkConnection, false, errUseOfClosedNetworkConnection},
{makeNetErr(syscall.EAGAIN), true, syscall.EAGAIN},
{makeNetErr(syscall.Errno(123123123)), false, syscall.Errno(123123123)},
{eNil1, false, eNil1}, {eNil1, false, eNil1},
{eNil2, false, eNil2.Err}, {eNil2, false, eNil2.Err},
{myError1{io.EOF}, false, io.EOF}, {myError1{io.EOF}, false, io.EOF},
@ -151,27 +132,9 @@ func TestShouldRetry(t *testing.T) {
{fmt.Errorf("connection: %w", errUseOfClosedNetworkConnection), true}, {fmt.Errorf("connection: %w", errUseOfClosedNetworkConnection), true},
{io.EOF, true}, {io.EOF, true},
{io.ErrUnexpectedEOF, true}, {io.ErrUnexpectedEOF, true},
{makeNetErr(syscall.EAGAIN), true},
{makeNetErr(syscall.Errno(123123123)), false},
{&url.Error{Op: "post", URL: "/", Err: io.EOF}, true}, {&url.Error{Op: "post", URL: "/", Err: io.EOF}, true},
{&url.Error{Op: "post", URL: "/", Err: errUseOfClosedNetworkConnection}, true}, {&url.Error{Op: "post", URL: "/", Err: errUseOfClosedNetworkConnection}, true},
{&url.Error{Op: "post", URL: "/", Err: fmt.Errorf("net/http: HTTP/1.x transport connection broken: %v", fmt.Errorf("http: ContentLength=%d with Body length %d", 100663336, 99590598))}, true}, {&url.Error{Op: "post", URL: "/", Err: fmt.Errorf("net/http: HTTP/1.x transport connection broken: %v", fmt.Errorf("http: ContentLength=%d with Body length %d", 100663336, 99590598))}, true},
{
wrap(&url.Error{
Op: "post",
URL: "http://localhost/",
Err: makeNetErr(syscall.EPIPE),
}, "potato error"),
true,
},
{
wrap(&url.Error{
Op: "post",
URL: "http://localhost/",
Err: makeNetErr(syscall.Errno(123123123)),
}, "listing error"),
false,
},
} { } {
got := ShouldRetry(test.err) got := ShouldRetry(test.err)
assert.Equal(t, test.want, got, fmt.Sprintf("test #%d: %v", i, test.err)) assert.Equal(t, test.want, got, fmt.Sprintf("test #%d: %v", i, test.err))

View file

@ -1,3 +1,6 @@
//go:build !plan9
// +build !plan9
package logger_test package logger_test
import ( import (

View file

@ -1,5 +1,6 @@
//go:build plan9 || js //go:build plan9 || js
// Package kv provides key/value database.
package kv package kv
import ( import (

View file

@ -0,0 +1,20 @@
//go:build !linux && !darwin && !freebsd && !windows
// +build !linux,!darwin,!freebsd,!windows
package vfstest
import (
"errors"
"runtime"
"testing"
)
// TestWriteFileDoubleClose tests double close on write
func TestWriteFileDoubleClose(t *testing.T) {
t.Skip("not supported on " + runtime.GOOS)
}
// writeTestDup performs the platform-specific implementation of the dup() unix
func writeTestDup(oldfd uintptr) (uintptr, error) {
return 0, errors.New("not supported on " + runtime.GOOS)
}

View file

@ -1,4 +1,4 @@
//go:build !linux && !darwin && !freebsd //go:build windows
package vfstest package vfstest