github.com/mysteriumnetwork/node@v0.0.0-20240516044423-365054f76801/cmd/commands/config/command_test.go (about)

     1  /*
     2   * Copyright (C) 2020 The "MysteriumNetwork/node" Authors.
     3   *
     4   * This program is free software: you can redistribute it and/or modify
     5   * it under the terms of the GNU General Public License as published by
     6   * the Free Software Foundation, either version 3 of the License, or
     7   * (at your option) any later version.
     8   *
     9   * This program is distributed in the hope that it will be useful,
    10   * but WITHOUT ANY WARRANTY; without even the implied warranty of
    11   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    12   * GNU General Public License for more details.
    13   *
    14   * You should have received a copy of the GNU General Public License
    15   * along with this program.  If not, see <http://www.gnu.org/licenses/>.
    16   */
    17  
    18  package config
    19  
    20  import (
    21  	"testing"
    22  
    23  	"github.com/stretchr/testify/assert"
    24  )
    25  
    26  func Test_squishMap(t *testing.T) {
    27  	for _, test := range []struct {
    28  		give map[string]interface{}
    29  		get  map[string]string
    30  	}{
    31  		{
    32  			give: map[string]interface{}{
    33  				"test1": 1,
    34  				"test2": "1",
    35  			},
    36  			get: map[string]string{
    37  				"test1": "1",
    38  				"test2": "1",
    39  			},
    40  		},
    41  		{
    42  			give: map[string]interface{}{
    43  				"test1": map[string]interface{}{
    44  					"test2": 1,
    45  				},
    46  				"test3": "1",
    47  				"test4": map[string]interface{}{
    48  					"test5": 7.5,
    49  				},
    50  			},
    51  			get: map[string]string{
    52  				"test1.test2": "1",
    53  				"test3":       "1",
    54  				"test4.test5": "7.5",
    55  			},
    56  		},
    57  	} {
    58  		dest := map[string]string{}
    59  		squishMap(test.give, dest)
    60  		assert.Len(t, dest, len(test.get))
    61  
    62  		for k, v := range test.get {
    63  			got, ok := dest[k]
    64  			assert.True(t, ok)
    65  			assert.Equal(t, v, got)
    66  		}
    67  	}
    68  }