Skip to content

Commit

Permalink
Fix Unix socket path in memcached (#17512)
Browse files Browse the repository at this point in the history
* Fix Unix socket path in memcached

* Fix: mage check

* Adjust changelog
  • Loading branch information
mtojek authored Apr 6, 2020
1 parent d12d9ef commit ccb525b
Show file tree
Hide file tree
Showing 3 changed files with 57 additions and 4 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.next.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -146,6 +146,7 @@ https://github.com/elastic/beats/compare/v7.0.0-alpha2...master[Check the HEAD d
- Fix how we filter services by name in system/service {pull}17400[17400]
- Fix cloudwatch metricset missing tags collection. {issue}17419[17419] {pull}17424[17424]
- check if cpuOptions field is nil in DescribeInstances output in ec2 metricset. {pull}17418[17418]
- Fix Unix socket path in memcached. {pull}17512[17512]

*Packetbeat*

Expand Down
12 changes: 8 additions & 4 deletions metricbeat/module/memcached/stats/stats.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ func New(base mb.BaseMetricSet) (mb.MetricSet, error) {
// format. It publishes the event which is then forwarded to the output. In case
// of an error set the Error field of mb.Event or simply call report.Error().
func (m *MetricSet) Fetch(reporter mb.ReporterV2) error {
network, address, err := m.getNetworkAndAddress()
network, address, err := getNetworkAndAddress(m.HostData())
if err != nil {
return errors.Wrap(err, "error in fetch")
}
Expand Down Expand Up @@ -92,14 +92,18 @@ func (m *MetricSet) Fetch(reporter mb.ReporterV2) error {
return nil
}

func (m *MetricSet) getNetworkAndAddress() (network string, address string, err error) {
hostData := m.HostData()
func getNetworkAndAddress(hostData mb.HostData) (network string, address string, err error) {
u, err := url.Parse(hostData.URI)
if err != nil {
err = errors.Wrap(err, "invalid URL")
return
}

network = u.Scheme
address = u.Host
if network == "unix" {
address = u.Path
} else {
address = u.Host
}
return
}
48 changes: 48 additions & 0 deletions metricbeat/module/memcached/stats/stats_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
// Licensed to Elasticsearch B.V. under one or more contributor
// license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright
// ownership. Elasticsearch B.V. licenses this file to you under
// the Apache License, Version 2.0 (the "License"); you may
// not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.

package stats

import (
"testing"

"github.com/stretchr/testify/require"

"github.com/elastic/beats/v7/metricbeat/mb"
)

func TestGetNetworkAddress_URL(t *testing.T) {
hostData := mb.HostData{
Host: "127.0.0.1:11211",
URI: "tcp://127.0.0.1:11211",
}
network, address, err := getNetworkAndAddress(hostData)
require.NoError(t, err)
require.Equal(t, "tcp", network)
require.Equal(t, "127.0.0.1:11211", address)
}

func TestGetNetworkAddress_Unix(t *testing.T) {
hostData := mb.HostData{
Host: "/tmp/d.sock",
URI: "unix:///tmp/d.sock",
}
network, address, err := getNetworkAndAddress(hostData)
require.NoError(t, err)
require.Equal(t, "unix", network)
require.Equal(t, "/tmp/d.sock", address)
}

0 comments on commit ccb525b

Please sign in to comment.