Skip to content

Commit

Permalink
Merge pull request #19 from suzuki-shunsuke/refactor/change-signature
Browse files Browse the repository at this point in the history
feat: change signature
  • Loading branch information
suzuki-shunsuke committed Jul 10, 2020
2 parents 6f14bae + 1dc5350 commit b762442
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 46 deletions.
23 changes: 4 additions & 19 deletions .golangci.yml
@@ -1,21 +1,6 @@
---
linters:
enable:
- deadcode
- errcheck
- goconst
- gofmt
- goimports
- golint
- gosimple
- govet
- interfacer
- maligned
- misspell
- nakedret
- staticcheck
- structcheck
- unconvert
- unused
- varcheck
disable-all: true
enable-all: true
disable:
- wsl
- goerr113
28 changes: 11 additions & 17 deletions dataeq/dataeq.go
Expand Up @@ -8,54 +8,48 @@ type (
Marshal func(interface{}) ([]byte, error)
Unmarshal func([]byte, interface{}) error

DataFormat interface {
ConvertByte([]byte) (interface{}, error)
Convert(interface{}) (interface{}, error)
Equal(x, y interface{}) (bool, error)
}

converter struct {
DataFormat struct {
marshal func(interface{}) ([]byte, error)
unmarshal func([]byte, interface{}) error
}
)

func New(marshal Marshal, unmarshal Unmarshal) DataFormat {
return &converter{
return DataFormat{
marshal: marshal,
unmarshal: unmarshal,
}
}

func (c *converter) ConvertByte(b []byte) (interface{}, error) {
func (df DataFormat) ConvertByte(b []byte) (interface{}, error) {
var d interface{}
err := c.unmarshal(b, &d)
err := df.unmarshal(b, &d)
if err == nil {
return d, nil
}
return nil, err
}

func (c *converter) Convert(x interface{}) (interface{}, error) {
func (df DataFormat) Convert(x interface{}) (interface{}, error) {
if a, ok := x.([]byte); ok {
return c.ConvertByte(a)
return df.ConvertByte(a)
}
b, err := c.marshal(x)
b, err := df.marshal(x)
if err != nil {
return nil, err
}
return c.ConvertByte(b)
return df.ConvertByte(b)
}

func (c *converter) Equal(x, y interface{}) (bool, error) {
func (df DataFormat) Equal(x, y interface{}) (bool, error) {
if reflect.DeepEqual(x, y) {
return true, nil
}
a, err := c.Convert(x)
a, err := df.Convert(x)
if err != nil {
return false, err
}
b, err := c.Convert(y)
b, err := df.Convert(y)
if err != nil {
return false, err
}
Expand Down
12 changes: 8 additions & 4 deletions dataeq/dataeq_test.go
@@ -1,10 +1,11 @@
package dataeq
package dataeq_test

import (
"fmt"
"testing"

"github.com/stretchr/testify/require"
"github.com/suzuki-shunsuke/go-dataeq/dataeq"
)

func TestJSON_ConvertByte(t *testing.T) {
Expand Down Expand Up @@ -48,8 +49,9 @@ func TestJSON_ConvertByte(t *testing.T) {
},
}
for _, d := range data {
d := d
t.Run(d.title, func(t *testing.T) {
a, err := JSON.ConvertByte(d.b)
a, err := dataeq.JSON.ConvertByte(d.b)
if d.isError {
require.NotNil(t, err)
return
Expand Down Expand Up @@ -104,8 +106,9 @@ func TestJSON_Convert(t *testing.T) {
},
}
for _, d := range data {
d := d
t.Run(d.title, func(t *testing.T) {
a, err := JSON.Convert(d.x)
a, err := dataeq.JSON.Convert(d.x)
if d.isError {
require.NotNil(t, err)
return
Expand Down Expand Up @@ -162,8 +165,9 @@ func TestJSON_Equal(t *testing.T) {
},
}
for _, d := range data {
d := d
t.Run(d.title, func(t *testing.T) {
f, err := JSON.Equal(d.x, d.y)
f, err := dataeq.JSON.Equal(d.x, d.y)
if d.isError {
require.NotNil(t, err)
return
Expand Down
2 changes: 1 addition & 1 deletion dataeq/json.go
Expand Up @@ -4,4 +4,4 @@ import (
"encoding/json"
)

var JSON = New(json.Marshal, json.Unmarshal)
var JSON = New(json.Marshal, json.Unmarshal) //nolint:gochecknoglobals
9 changes: 4 additions & 5 deletions go.sum
@@ -1,11 +1,10 @@
github.com/davecgh/go-spew v1.1.0 h1:ZDRjVQ15GmhC3fiQ8ni8+OwkZQO4DARzQgrnXU1Liz8=
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
github.com/stretchr/testify v1.4.0 h1:2E4SXV/wtOkTonXsotYi4li6zVWxYlZuYNCXe9XRJyk=
github.com/stretchr/testify v1.4.0/go.mod h1:j7eGeouHqKxXV5pUuKE4zz7dFj8WfuZ+81PSLYec5m4=
github.com/stretchr/testify v1.5.1/go.mod h1:5W2xD1RspED5o8YsWQXVCued0rvSQ+mT+I5cxcmMvtA=
github.com/stretchr/testify v1.6.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
github.com/stretchr/testify v1.6.1 h1:hDPOHmpOpP40lSULcqw7IrRb/u7w6RpDC9399XyoNd0=
github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI=
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c h1:dUUwHk2QECo/6vqA44rthZ8ie2QXMNeKRTHCNY2nXvo=
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=

0 comments on commit b762442

Please sign in to comment.