Skip to content

Commit

Permalink
Add tests for dotenv
Browse files Browse the repository at this point in the history
* Unit tests added.

* Return error statement fixed. `err` replaced with `nil` for return line.

Signed-off-by: Gökhan Özeloğlu <gozeloglu@gmail.com>
  • Loading branch information
gozeloglu committed Feb 12, 2022
1 parent fe680f4 commit d72661e
Show file tree
Hide file tree
Showing 2 changed files with 141 additions and 1 deletion.
2 changes: 1 addition & 1 deletion parsers/dotenv/dotenv.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ func (p *DotEnv) Unmarshal(b []byte) (map[string]interface{}, error) {
mp[k] = v
}

return mp, err
return mp, nil
}

// Marshal marshals the given config map to DOTENV bytes.
Expand Down
140 changes: 140 additions & 0 deletions parsers/dotenv/dotenv_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,140 @@
package dotenv

import (
"github.com/stretchr/testify/assert"
"testing"
)

func TestDotEnv_Marshal(t *testing.T) {
de := DotEnv{}
testCases := []struct {
name string
cfg map[string]interface{}
expOut []byte
err error
}{
{
name: "Empty config",
cfg: map[string]interface{}{},
expOut: []byte{},
},
{
name: "Simple key-value pair",
cfg: map[string]interface{}{
"key": "value",
},
expOut: []byte("key=\"value\""),
},
{
name: "Multiple key-values",
cfg: map[string]interface{}{
"key-1": "value-1",
"key-2": "value-2",
"key-3": "value-3",
},
expOut: []byte("key-1=\"value-1\"\nkey-2=\"value-2\"\nkey-3=\"value-3\""),
},
{
name: "Mixed data types",
cfg: map[string]interface{}{
"int-key": 12,
"bool-key": true,
"arr-key": []int{1, 2, 3, 4},
"float-key": 10.5,
},
expOut: []byte("arr-key=\"[1 2 3 4]\"\nbool-key=\"true\"\nfloat-key=\"10.5\"\nint-key=\"12\""),
},
{
name: "Nested config",
cfg: map[string]interface{}{
"map-key": map[string]interface{}{
"arr-key": []float64{1.2, 4.3, 5, 6},
"bool-key": false,
"inner-map-key": map[interface{}]interface{}{
0: "zero",
1: 1.0,
},
"int-key": 12,
},
},
expOut: []byte(`map-key="map[arr-key:[1.2 4.3 5 6] bool-key:false inner-map-key:map[0:zero 1:1] int-key:12]"`),
},
}

for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
out, err := de.Marshal(tc.cfg)
assert.Equal(t, tc.err, err)
assert.Equal(t, tc.expOut, out)
})
}
}

func TestDotEnv_Unmarshal(t *testing.T) {
de := DotEnv{}
testCases := []struct {
name string
cfg []byte
expOut map[string]interface{}
err error
}{
{
name: "Empty config",
expOut: map[string]interface{}{},
},
{
name: "Simple key-value",
cfg: []byte(`key="value"`),
expOut: map[string]interface{}{
"key": "value",
},
},
{
name: "Multiple key-values",
cfg: []byte("key-1=\"value-1\"\nkey-2=\"value-2\""),
expOut: map[string]interface{}{
"key-1": "value-1",
"key-2": "value-2",
},
},
{
name: "Mixed data types",
cfg: []byte("arr=\"[1 2 3 4]\"\nbool=\"true\"\nfloat=\"12.5\"\nint=\"32\"\n"),
expOut: map[string]interface{}{
"arr": "[1 2 3 4]",
"bool": "true",
"float": "12.5",
"int": "32",
},
},
{
name: "Nested config",
cfg: []byte(`map-key="map[arr-key:[1 4 5 6] bool-key:false inner-map-key:map[0:zero 1:1] int-key:12]"`),
expOut: map[string]interface{}{
"map-key": "map[arr-key:[1 4 5 6] bool-key:false inner-map-key:map[0:zero 1:1] int-key:12]",
},
},
{
name: "Missing quotation mark",
cfg: []byte(`key="value`),
expOut: map[string]interface{}{
"key": `"value`,
},
},
{
name: "Missing value",
cfg: []byte(`key=`),
expOut: map[string]interface{}{
"key": "",
},
},
}

for _, tc := range testCases {
t.Run(tc.name, func(t *testing.T) {
outMap, err := de.Unmarshal(tc.cfg)
assert.Equal(t, tc.err, err)
assert.Equal(t, tc.expOut, outMap)
})
}
}

0 comments on commit d72661e

Please sign in to comment.