mirror of
https://github.com/open-telemetry/opentelemetry-go.git
synced 2025-01-26 03:52:03 +02:00
f4ec95d027
* Add container id support to Resource * Fix wrong test case name * Add WithContainer option * Update CHANGELOG * Fix comments * Update CHANGELOG * Use regex to find container id * Add tests for reading cgroup file * Update sdk/resource/container.go Co-authored-by: Chester Cheung <cheung.zhy.csu@gmail.com> * Update format Co-authored-by: Chester Cheung <cheung.zhy.csu@gmail.com> Co-authored-by: Anthony Mirabella <a9@aneurysm9.com>
158 lines
4.1 KiB
Go
158 lines
4.1 KiB
Go
// Copyright The OpenTelemetry Authors
|
|
//
|
|
// Licensed 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 resource_test
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"os"
|
|
"os/user"
|
|
"runtime"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"go.opentelemetry.io/otel/sdk/resource"
|
|
)
|
|
|
|
var (
|
|
fakePID = 123
|
|
fakeExecutablePath = "/fake/path/mock"
|
|
fakeCommandArgs = []string{"mock", "-t", "30"}
|
|
fakeOwner = "gopher"
|
|
fakeRuntimeName = "gcmock"
|
|
fakeRuntimeVersion = "go1.2.3"
|
|
fakeRuntimeOS = "linux"
|
|
fakeRuntimeArch = "amd64"
|
|
)
|
|
|
|
var (
|
|
fakeExecutableName = "mock"
|
|
fakeRuntimeDescription = "go version go1.2.3 linux/amd64"
|
|
)
|
|
|
|
var (
|
|
fakePidProvider = func() int { return fakePID }
|
|
fakeExecutablePathProvider = func() (string, error) { return fakeExecutablePath, nil }
|
|
fakeCommandArgsProvider = func() []string { return fakeCommandArgs }
|
|
fakeOwnerProvider = func() (*user.User, error) { return &user.User{Username: fakeOwner}, nil }
|
|
fakeRuntimeNameProvider = func() string { return fakeRuntimeName }
|
|
fakeRuntimeVersionProvider = func() string { return fakeRuntimeVersion }
|
|
fakeRuntimeOSProvider = func() string { return fakeRuntimeOS }
|
|
fakeRuntimeArchProvider = func() string { return fakeRuntimeArch }
|
|
)
|
|
|
|
var (
|
|
fakeExecutablePathProviderWithError = func() (string, error) {
|
|
return "", fmt.Errorf("Unable to get process executable")
|
|
}
|
|
fakeOwnerProviderWithError = func() (*user.User, error) {
|
|
return nil, fmt.Errorf("Unable to get process user")
|
|
}
|
|
)
|
|
|
|
func mockProcessAttributesProviders() {
|
|
resource.SetOSProviders(
|
|
fakePidProvider,
|
|
fakeExecutablePathProvider,
|
|
fakeCommandArgsProvider,
|
|
)
|
|
resource.SetRuntimeProviders(
|
|
fakeRuntimeNameProvider,
|
|
fakeRuntimeVersionProvider,
|
|
fakeRuntimeOSProvider,
|
|
fakeRuntimeArchProvider,
|
|
)
|
|
resource.SetUserProviders(
|
|
fakeOwnerProvider,
|
|
)
|
|
}
|
|
|
|
func mockProcessAttributesProvidersWithErrors() {
|
|
resource.SetOSProviders(
|
|
fakePidProvider,
|
|
fakeExecutablePathProviderWithError,
|
|
fakeCommandArgsProvider,
|
|
)
|
|
resource.SetRuntimeProviders(
|
|
fakeRuntimeNameProvider,
|
|
fakeRuntimeVersionProvider,
|
|
fakeRuntimeOSProvider,
|
|
fakeRuntimeArchProvider,
|
|
)
|
|
resource.SetUserProviders(
|
|
fakeOwnerProviderWithError,
|
|
)
|
|
}
|
|
|
|
func restoreAttributesProviders() {
|
|
resource.SetDefaultOSProviders()
|
|
resource.SetDefaultRuntimeProviders()
|
|
resource.SetDefaultUserProviders()
|
|
resource.SetDefaultOSDescriptionProvider()
|
|
resource.SetDefaultContainerProviders()
|
|
}
|
|
|
|
func TestWithProcessFuncsErrors(t *testing.T) {
|
|
mockProcessAttributesProvidersWithErrors()
|
|
|
|
t.Run("WithExecutablePath", testWithProcessExecutablePathError)
|
|
t.Run("WithOwner", testWithProcessOwnerError)
|
|
|
|
restoreAttributesProviders()
|
|
}
|
|
|
|
func TestCommandArgs(t *testing.T) {
|
|
require.EqualValues(t, os.Args, resource.CommandArgs())
|
|
}
|
|
|
|
func TestRuntimeName(t *testing.T) {
|
|
if runtime.Compiler == "gc" {
|
|
require.EqualValues(t, "go", resource.RuntimeName())
|
|
} else {
|
|
require.EqualValues(t, runtime.Compiler, resource.RuntimeName())
|
|
}
|
|
}
|
|
|
|
func TestRuntimeOS(t *testing.T) {
|
|
require.EqualValues(t, runtime.GOOS, resource.RuntimeOS())
|
|
}
|
|
|
|
func TestRuntimeArch(t *testing.T) {
|
|
require.EqualValues(t, runtime.GOARCH, resource.RuntimeArch())
|
|
}
|
|
|
|
func testWithProcessExecutablePathError(t *testing.T) {
|
|
ctx := context.Background()
|
|
|
|
res, err := resource.New(ctx,
|
|
resource.WithProcessExecutablePath(),
|
|
)
|
|
|
|
require.Error(t, err)
|
|
require.EqualValues(t, map[string]string{}, toMap(res))
|
|
}
|
|
|
|
func testWithProcessOwnerError(t *testing.T) {
|
|
ctx := context.Background()
|
|
|
|
res, err := resource.New(ctx,
|
|
resource.WithProcessOwner(),
|
|
)
|
|
|
|
require.Error(t, err)
|
|
require.EqualValues(t, map[string]string{}, toMap(res))
|
|
}
|