Skip to content

Commit

Permalink
clustering: fix handling of empty join-addresses flag (#5454)
Browse files Browse the repository at this point in the history
Signed-off-by: Paschalis Tsilias <[email protected]>
  • Loading branch information
tpaschalis authored Oct 13, 2023
1 parent d597d56 commit 0a5a5aa
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 1 deletion.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,9 @@ Main (unreleased)

- Fixed an issue where `loki.process` validation for stage `metric.counter` was
allowing invalid combination of configuration options. (@thampiotr)

- Fix the handling of the `--cluster.join-addresses` flag causing an invalid
comparison with the mutually-exclusive `--cluster.discover-peers`. (@tpaschalis)

### Enhancements

Expand Down
18 changes: 18 additions & 0 deletions cmd/internal/flowmode/cluster_builder_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
package flowmode

import (
"testing"

"github.com/stretchr/testify/require"
)

func TestBuildClusterService(t *testing.T) {
opts := clusterOptions{
JoinPeers: []string{"foo", "bar"},
DiscoverPeers: "provider=aws key1=val1 key2=val2",
}

cs, err := buildClusterService(opts)
require.Nil(t, cs)
require.EqualError(t, err, "at most one of join peers and discover peers may be set")
}
9 changes: 8 additions & 1 deletion cmd/internal/flowmode/cmd_run.go
Original file line number Diff line number Diff line change
Expand Up @@ -210,7 +210,7 @@ func (fr *flowRun) Run(configPath string) error {
NodeName: fr.clusterNodeName,
AdvertiseAddress: fr.clusterAdvAddr,
ListenAddress: fr.httpListenAddr,
JoinPeers: strings.Split(fr.clusterJoinAddr, ","),
JoinPeers: splitPeers(fr.clusterJoinAddr, ","),
DiscoverPeers: fr.clusterDiscoverPeers,
RejoinInterval: fr.clusterRejoinInterval,
AdvertiseInterfaces: fr.clusterAdvInterfaces,
Expand Down Expand Up @@ -430,3 +430,10 @@ func interruptContext() (context.Context, context.CancelFunc) {

return ctx, cancel
}

func splitPeers(s, sep string) []string {
if len(s) == 0 {
return []string{}
}
return strings.Split(s, sep)
}

0 comments on commit 0a5a5aa

Please sign in to comment.