mirror of https://github.com/status-im/consul.git
99 lines
3.0 KiB
Go
99 lines
3.0 KiB
Go
|
// Copyright (c) HashiCorp, Inc.
|
||
|
// SPDX-License-Identifier: BUSL-1.1
|
||
|
|
||
|
package client
|
||
|
|
||
|
import (
|
||
|
"testing"
|
||
|
|
||
|
"github.com/stretchr/testify/assert"
|
||
|
)
|
||
|
|
||
|
func TestMergeFlagsIntoGRPCConfig(t *testing.T) {
|
||
|
t.Run("MergeFlagsIntoGRPCConfig", func(t *testing.T) {
|
||
|
// Setup GRPCFlags with some flag values
|
||
|
flags := &GRPCFlags{
|
||
|
address: TValue[string]{v: stringPointer("https://example.com:8502")},
|
||
|
grpcTLS: TValue[bool]{v: boolPointer(true)},
|
||
|
certFile: TValue[string]{v: stringPointer("/path/to/client.crt")},
|
||
|
keyFile: TValue[string]{v: stringPointer("/path/to/client.key")},
|
||
|
caFile: TValue[string]{v: stringPointer("/path/to/ca.crt")},
|
||
|
caPath: TValue[string]{v: stringPointer("/path/to/cacerts")},
|
||
|
}
|
||
|
|
||
|
// Setup GRPCConfig with some initial values
|
||
|
config := &GRPCConfig{
|
||
|
Address: "localhost:8500",
|
||
|
GRPCTLS: false,
|
||
|
GRPCTLSVerify: true,
|
||
|
CertFile: "/path/to/default/client.crt",
|
||
|
KeyFile: "/path/to/default/client.key",
|
||
|
CAFile: "/path/to/default/ca.crt",
|
||
|
CAPath: "/path/to/default/cacerts",
|
||
|
}
|
||
|
|
||
|
// Call MergeFlagsIntoGRPCConfig to merge flag values into the config
|
||
|
flags.MergeFlagsIntoGRPCConfig(config)
|
||
|
|
||
|
// Validate the merged config
|
||
|
expectedConfig := &GRPCConfig{
|
||
|
Address: "example.com:8502",
|
||
|
GRPCTLS: true,
|
||
|
GRPCTLSVerify: true,
|
||
|
CertFile: "/path/to/client.crt",
|
||
|
KeyFile: "/path/to/client.key",
|
||
|
CAFile: "/path/to/ca.crt",
|
||
|
CAPath: "/path/to/cacerts",
|
||
|
}
|
||
|
|
||
|
assert.Equal(t, expectedConfig, config)
|
||
|
})
|
||
|
t.Run("MergeFlagsIntoGRPCConfig: allow empty values", func(t *testing.T) {
|
||
|
// Setup GRPCFlags with some flag values
|
||
|
flags := &GRPCFlags{
|
||
|
address: TValue[string]{v: stringPointer("http://example.com:8502")},
|
||
|
grpcTLS: TValue[bool]{},
|
||
|
certFile: TValue[string]{v: stringPointer("/path/to/client.crt")},
|
||
|
keyFile: TValue[string]{v: stringPointer("/path/to/client.key")},
|
||
|
caFile: TValue[string]{v: stringPointer("/path/to/ca.crt")},
|
||
|
caPath: TValue[string]{v: stringPointer("/path/to/cacerts")},
|
||
|
}
|
||
|
|
||
|
// Setup GRPCConfig with some initial values
|
||
|
config := &GRPCConfig{
|
||
|
Address: "localhost:8500",
|
||
|
GRPCTLSVerify: true,
|
||
|
CertFile: "/path/to/default/client.crt",
|
||
|
KeyFile: "/path/to/default/client.key",
|
||
|
CAFile: "/path/to/default/ca.crt",
|
||
|
CAPath: "/path/to/default/cacerts",
|
||
|
}
|
||
|
|
||
|
// Call MergeFlagsIntoGRPCConfig to merge flag values into the config
|
||
|
flags.MergeFlagsIntoGRPCConfig(config)
|
||
|
|
||
|
// Validate the merged config
|
||
|
expectedConfig := &GRPCConfig{
|
||
|
Address: "example.com:8502",
|
||
|
GRPCTLS: false,
|
||
|
GRPCTLSVerify: true,
|
||
|
CertFile: "/path/to/client.crt",
|
||
|
KeyFile: "/path/to/client.key",
|
||
|
CAFile: "/path/to/ca.crt",
|
||
|
CAPath: "/path/to/cacerts",
|
||
|
}
|
||
|
|
||
|
assert.Equal(t, expectedConfig, config)
|
||
|
})
|
||
|
}
|
||
|
|
||
|
// Utility function to convert string to string pointer
|
||
|
func stringPointer(s string) *string {
|
||
|
return &s
|
||
|
}
|
||
|
|
||
|
// Utility function to convert bool to bool pointer
|
||
|
func boolPointer(b bool) *bool {
|
||
|
return &b
|
||
|
}
|