rgw/admin: fix tests for quincy

Signed-off-by: Sven Anderson <sven@redhat.com>
This commit is contained in:
Sven Anderson 2022-05-17 19:06:28 +02:00 committed by mergify[bot]
parent 68ebb0520a
commit 005aa73667
2 changed files with 43 additions and 11 deletions

37
internal/util/util.go Normal file
View File

@ -0,0 +1,37 @@
package util
import "os"
// CephVersion type
type CephVersion int
// Enum of known CephVersions
const (
CephNautilus CephVersion = 14 + iota
CephOctopus
CephPacific
CephQuincy
CephUnknown
)
// CurrentCephVersion is the current Ceph version
func CurrentCephVersion() CephVersion {
vname := os.Getenv("CEPH_VERSION")
return CephVersionOfString(vname)
}
// CephVersionOfString converts a string to CephVersion
func CephVersionOfString(vname string) CephVersion {
switch vname {
case "nautilus":
return CephNautilus
case "octopus":
return CephOctopus
case "pacific":
return CephPacific
case "quincy":
return CephQuincy
default:
return CephUnknown
}
}

View File

@ -4,21 +4,13 @@ import (
"context" "context"
"errors" "errors"
"net/http" "net/http"
"os"
"testing" "testing"
"github.com/ceph/go-ceph/internal/util"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/assert"
) )
func skipIfQuincy(t *testing.T) {
vname := os.Getenv("CEPH_VERSION")
if vname == "quincy" {
t.Skipf("disabled on ceph %s", vname)
}
}
func (suite *RadosGWTestSuite) TestBucket() { func (suite *RadosGWTestSuite) TestBucket() {
skipIfQuincy(suite.T())
suite.SetupConnection() suite.SetupConnection()
co, err := New(suite.endpoint, suite.accessKey, suite.secretKey, newDebugHTTPClient(http.DefaultClient)) co, err := New(suite.endpoint, suite.accessKey, suite.secretKey, newDebugHTTPClient(http.DefaultClient))
assert.NoError(suite.T(), err) assert.NoError(suite.T(), err)
@ -60,7 +52,10 @@ func (suite *RadosGWTestSuite) TestBucket() {
suite.T().Run("remove non-existing bucket", func(t *testing.T) { suite.T().Run("remove non-existing bucket", func(t *testing.T) {
err := co.RemoveBucket(context.Background(), Bucket{Bucket: "foo"}) err := co.RemoveBucket(context.Background(), Bucket{Bucket: "foo"})
assert.Error(suite.T(), err) assert.Error(suite.T(), err)
// TODO: report to rgw team, this should return NoSuchBucket? if util.CurrentCephVersion() <= util.CephOctopus {
assert.True(suite.T(), errors.Is(err, ErrNoSuchKey)) assert.True(suite.T(), errors.Is(err, ErrNoSuchKey))
} else {
assert.True(suite.T(), errors.Is(err, ErrNoSuchBucket))
}
}) })
} }