mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-29 13:49:28 +08:00

* MF-1348 - Add go-kit transport level logging Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix reviews Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix reviews Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix merge Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix remark Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix go test flags Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use httputil errors in things and http service Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix SDK tests Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use httputil errors in certs and provision service Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use httputil errors in consumers service Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * General renaming and add ErrMissingToken Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Rename httputil -> apiutil and use errors in users servive Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Use apiutil errors in auth, bootstrap, readers, things and twins Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Replace errors.Contain by comparison Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix remarks Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Simplify validateID Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Simplify validateID Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Simplify and rename ExtractAuthToken -> ExtractBearerToken Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix readers Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix auth key test and remarks Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Improve comment Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Simplify validateUUID check Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> * Fix typo Signed-off-by: Manuel Imperiale <manuel.imperiale@gmail.com> Co-authored-by: Dušan Borovčanin <dusan.borovcanin@mainflux.com>
299 lines
5.2 KiB
Go
299 lines
5.2 KiB
Go
package api
|
|
|
|
import (
|
|
"fmt"
|
|
"testing"
|
|
|
|
"github.com/mainflux/mainflux/bootstrap"
|
|
"github.com/mainflux/mainflux/internal/apiutil"
|
|
"github.com/stretchr/testify/assert"
|
|
)
|
|
|
|
func TestAddReqValidation(t *testing.T) {
|
|
cases := []struct {
|
|
desc string
|
|
token string
|
|
externalID string
|
|
externalKey string
|
|
err error
|
|
}{
|
|
{
|
|
desc: "empty key",
|
|
token: "",
|
|
externalID: "external-id",
|
|
externalKey: "external-key",
|
|
err: apiutil.ErrBearerToken,
|
|
},
|
|
{
|
|
desc: "empty external ID",
|
|
token: "token",
|
|
externalID: "",
|
|
externalKey: "external-key",
|
|
err: apiutil.ErrMissingID,
|
|
},
|
|
{
|
|
desc: "empty external key",
|
|
token: "token",
|
|
externalID: "external-id",
|
|
externalKey: "",
|
|
err: apiutil.ErrBearerKey,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
req := addReq{
|
|
token: tc.token,
|
|
ExternalID: tc.externalID,
|
|
ExternalKey: tc.externalKey,
|
|
}
|
|
|
|
err := req.validate()
|
|
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestEntityReqValidation(t *testing.T) {
|
|
cases := []struct {
|
|
desc string
|
|
key string
|
|
id string
|
|
err error
|
|
}{
|
|
{
|
|
desc: "empty key",
|
|
key: "",
|
|
id: "id",
|
|
err: apiutil.ErrBearerKey,
|
|
},
|
|
{
|
|
desc: "empty id",
|
|
key: "key",
|
|
id: "",
|
|
err: apiutil.ErrMissingID,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
req := entityReq{
|
|
key: tc.key,
|
|
}
|
|
|
|
err := req.validate()
|
|
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestUpdateReqValidation(t *testing.T) {
|
|
cases := []struct {
|
|
desc string
|
|
key string
|
|
id string
|
|
err error
|
|
}{
|
|
{
|
|
desc: "empty key",
|
|
key: "",
|
|
id: "id",
|
|
err: apiutil.ErrBearerKey,
|
|
},
|
|
{
|
|
desc: "empty id",
|
|
key: "key",
|
|
id: "",
|
|
err: apiutil.ErrMissingID,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
req := updateReq{
|
|
key: tc.key,
|
|
id: tc.id,
|
|
}
|
|
|
|
err := req.validate()
|
|
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestUpdateCertReqValidation(t *testing.T) {
|
|
cases := []struct {
|
|
desc string
|
|
key string
|
|
thingID string
|
|
err error
|
|
}{
|
|
{
|
|
desc: "empty key",
|
|
key: "",
|
|
thingID: "thingID",
|
|
err: apiutil.ErrBearerKey,
|
|
},
|
|
{
|
|
desc: "empty thing id",
|
|
key: "key",
|
|
thingID: "",
|
|
err: apiutil.ErrMissingID,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
req := updateCertReq{
|
|
key: tc.key,
|
|
thingID: tc.thingID,
|
|
}
|
|
|
|
err := req.validate()
|
|
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestUpdateConnReqValidation(t *testing.T) {
|
|
cases := []struct {
|
|
desc string
|
|
key string
|
|
id string
|
|
err error
|
|
}{
|
|
{
|
|
desc: "empty key",
|
|
key: "",
|
|
id: "id",
|
|
err: apiutil.ErrBearerKey,
|
|
},
|
|
{
|
|
desc: "empty id",
|
|
key: "key",
|
|
id: "",
|
|
err: apiutil.ErrMissingID,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
req := updateReq{
|
|
key: tc.key,
|
|
id: tc.id,
|
|
}
|
|
|
|
err := req.validate()
|
|
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestListReqValidation(t *testing.T) {
|
|
cases := []struct {
|
|
desc string
|
|
offset uint64
|
|
key string
|
|
limit uint64
|
|
err error
|
|
}{
|
|
{
|
|
desc: "empty key",
|
|
key: "",
|
|
offset: 0,
|
|
limit: 1,
|
|
err: apiutil.ErrBearerKey,
|
|
},
|
|
{
|
|
desc: "too large limit",
|
|
key: "key",
|
|
offset: 0,
|
|
limit: maxLimitSize + 1,
|
|
err: apiutil.ErrLimitSize,
|
|
},
|
|
{
|
|
desc: "default limit",
|
|
key: "key",
|
|
offset: 0,
|
|
limit: defLimit,
|
|
err: nil,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
req := listReq{
|
|
key: tc.key,
|
|
offset: tc.offset,
|
|
limit: tc.limit,
|
|
}
|
|
|
|
err := req.validate()
|
|
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestBootstrapReqValidation(t *testing.T) {
|
|
cases := []struct {
|
|
desc string
|
|
externKey string
|
|
externID string
|
|
err error
|
|
}{
|
|
{
|
|
desc: "empty external key",
|
|
externKey: "",
|
|
externID: "id",
|
|
err: apiutil.ErrBearerKey,
|
|
},
|
|
{
|
|
desc: "empty external id",
|
|
externKey: "key",
|
|
externID: "",
|
|
err: apiutil.ErrMissingID,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
req := bootstrapReq{
|
|
id: tc.externID,
|
|
key: tc.externKey,
|
|
}
|
|
|
|
err := req.validate()
|
|
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|
|
|
|
func TestChangeStateReqValidation(t *testing.T) {
|
|
cases := []struct {
|
|
desc string
|
|
key string
|
|
id string
|
|
state bootstrap.State
|
|
err error
|
|
}{
|
|
{
|
|
desc: "empty key",
|
|
key: "",
|
|
id: "id",
|
|
state: bootstrap.State(1),
|
|
err: apiutil.ErrBearerKey,
|
|
},
|
|
{
|
|
desc: "empty id",
|
|
key: "key",
|
|
id: "",
|
|
state: bootstrap.State(0),
|
|
err: apiutil.ErrMissingID,
|
|
},
|
|
{
|
|
desc: "invalid state",
|
|
key: "key",
|
|
id: "id",
|
|
state: bootstrap.State(14),
|
|
err: apiutil.ErrBootstrapState,
|
|
},
|
|
}
|
|
|
|
for _, tc := range cases {
|
|
req := changeStateReq{
|
|
key: tc.key,
|
|
id: tc.id,
|
|
State: tc.state,
|
|
}
|
|
|
|
err := req.validate()
|
|
assert.Equal(t, tc.err, err, fmt.Sprintf("%s: expected %s got %s\n", tc.desc, tc.err, err))
|
|
}
|
|
}
|