Skip to content

Commit

Permalink
all: use package filepath for file paths (#47061)
Browse files Browse the repository at this point in the history
Some day Teleport will run on systems that don't use / as a path
separator.
  • Loading branch information
zmb3 authored Oct 1, 2024
1 parent 685dd44 commit ec3e48b
Show file tree
Hide file tree
Showing 39 changed files with 147 additions and 154 deletions.
3 changes: 1 addition & 2 deletions api/client/credentials_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@ import (
"log"
"math/big"
"os"
"path"
"path/filepath"
"testing"
"time"
Expand Down Expand Up @@ -445,7 +444,7 @@ Private-MAC: 8951bbe929e0714a61df01bc8fbc5223e3688f174aee29339931984fb9224c7d`)

func TestDynamicIdentityFileCreds(t *testing.T) {
dir := t.TempDir()
identityPath := path.Join(dir, "identity")
identityPath := filepath.Join(dir, "identity")

idFile := &identityfile.IdentityFile{
PrivateKey: keyPEM,
Expand Down
4 changes: 2 additions & 2 deletions build.assets/tooling/cmd/difftest/ast.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,15 +69,15 @@ func findAllSuiteRunners(repoPath string, filename []string) (RunnersMap, error)

// Find all affected directories
for _, f := range filename {
dir := path.Join(repoPath, path.Dir(f))
dir := filepath.Join(repoPath, path.Dir(f))
s[dir] = struct{}{}
}

allRunners := make(RunnersMap)

// Find all test files in affected directoriees
for dir := range s {
matches, err := filepath.Glob(path.Join(dir, "*_test.go"))
matches, err := filepath.Glob(filepath.Join(dir, "*_test.go"))
if err != nil {
return nil, trace.Wrap(err)
}
Expand Down
3 changes: 1 addition & 2 deletions build.assets/tooling/cmd/difftest/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,6 @@ import (
"fmt"
"log"
"os"
"path"
"path/filepath"
"slices"
"strings"
Expand Down Expand Up @@ -244,7 +243,7 @@ func inspect(repoPath string, ref string, changedFiles []string, fn func(string,
}
}

head, err := parseMethodMap(path.Join(repoPath, filename), nil, runners)
head, err := parseMethodMap(filepath.Join(repoPath, filename), nil, runners)
if err != nil {
return trace.Wrap(err)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ package main
import (
"context"
"os"
"path"
"path/filepath"

"github.com/gravitational/trace"
"github.com/hashicorp/go-hclog"
Expand Down Expand Up @@ -65,7 +65,7 @@ func (gw *GonWrapper) SignAndNotarizeBinaries() error {
if err != nil {
return trace.Wrap(err, "failed to zip binaries for notarization")
}
defer os.RemoveAll(path.Dir(zipPath))
defer os.RemoveAll(filepath.Dir(zipPath))

err = gw.NotarizeBinaries(zipPath)
if err != nil {
Expand Down Expand Up @@ -99,7 +99,7 @@ func (gw *GonWrapper) ZipBinaries() (string, error) {
return "", trace.Wrap(err, "failed to create temporary directory for binary zipping")
}

outputPath := path.Join(tmpDir, zipFileName)
outputPath := filepath.Join(tmpDir, zipFileName)
gw.logger.Debug("Using binary zip path %q", outputPath)

err = zip.Zip(gw.ctx, &zip.Options{
Expand Down
8 changes: 4 additions & 4 deletions examples/dynamoathenamigration/migration_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ import (
"io"
"math/rand"
"os"
"path"
"path/filepath"
"sort"
"strings"
"sync"
Expand Down Expand Up @@ -62,7 +62,7 @@ func TestMigrateProcessDataObjects(t *testing.T) {
Logger: utils.NewLoggerForTests(),
NoOfEmitWorkers: 5,
bufferSize: 10,
CheckpointPath: path.Join(t.TempDir(), "migration-tests.json"),
CheckpointPath: filepath.Join(t.TempDir(), "migration-tests.json"),
},
}
err := mt.ProcessDataObjects(ctx, &exportInfo{
Expand Down Expand Up @@ -133,7 +133,7 @@ func TestLargeEventsParse(t *testing.T) {
Logger: utils.NewLoggerForTests(),
NoOfEmitWorkers: 5,
bufferSize: 10,
CheckpointPath: path.Join(t.TempDir(), "migration-tests.json"),
CheckpointPath: filepath.Join(t.TempDir(), "migration-tests.json"),
},
}
err := mt.ProcessDataObjects(ctx, &exportInfo{
Expand Down Expand Up @@ -223,7 +223,7 @@ func TestMigrationCheckpoint(t *testing.T) {
Logger: utils.NewLoggerForTests(),
NoOfEmitWorkers: noOfWorkers,
bufferSize: noOfWorkers * 5,
CheckpointPath: path.Join(t.TempDir(), "migration-tests.json"),
CheckpointPath: filepath.Join(t.TempDir(), "migration-tests.json"),
}

t.Run("no migration checkpoint, emit every event", func(t *testing.T) {
Expand Down
12 changes: 6 additions & 6 deletions integration/utmp_integration_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ import (
"context"
"os"
"os/user"
"path"
"path/filepath"
"testing"
"time"

Expand Down Expand Up @@ -170,8 +170,8 @@ func TestRootUsernameLimit(t *testing.T) {
}

dir := t.TempDir()
utmpPath := path.Join(dir, "utmp")
wtmpPath := path.Join(dir, "wtmp")
utmpPath := filepath.Join(dir, "utmp")
wtmpPath := filepath.Join(dir, "wtmp")

err := TouchFile(utmpPath)
require.NoError(t, err)
Expand Down Expand Up @@ -287,9 +287,9 @@ func newSrvCtx(ctx context.Context, t *testing.T) *SrvCtx {
require.NoError(t, err)

uaccDir := t.TempDir()
utmpPath := path.Join(uaccDir, "utmp")
wtmpPath := path.Join(uaccDir, "wtmp")
btmpPath := path.Join(uaccDir, "btmp")
utmpPath := filepath.Join(uaccDir, "utmp")
wtmpPath := filepath.Join(uaccDir, "wtmp")
btmpPath := filepath.Join(uaccDir, "btmp")
require.NoError(t, TouchFile(utmpPath))
require.NoError(t, TouchFile(wtmpPath))
require.NoError(t, TouchFile(btmpPath))
Expand Down
26 changes: 13 additions & 13 deletions integrations/event-handler/cli_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ package main

import (
"os"
"path"
"path/filepath"
"testing"
"time"

Expand Down Expand Up @@ -47,13 +47,13 @@ func TestStartCmdConfig(t *testing.T) {
FluentdConfig: FluentdConfig{
FluentdURL: "https://localhost:8888/test.log",
FluentdSessionURL: "https://localhost:8888/session",
FluentdCert: path.Join(wd, "testdata", "fake-file"),
FluentdKey: path.Join(wd, "testdata", "fake-file"),
FluentdCA: path.Join(wd, "testdata", "fake-file"),
FluentdCert: filepath.Join(wd, "testdata", "fake-file"),
FluentdKey: filepath.Join(wd, "testdata", "fake-file"),
FluentdCA: filepath.Join(wd, "testdata", "fake-file"),
},
TeleportConfig: TeleportConfig{
TeleportAddr: "localhost:3025",
TeleportIdentityFile: path.Join(wd, "testdata", "fake-file"),
TeleportIdentityFile: filepath.Join(wd, "testdata", "fake-file"),
TeleportRefreshEnabled: true,
TeleportRefreshInterval: 2 * time.Minute,
},
Expand Down Expand Up @@ -85,13 +85,13 @@ func TestStartCmdConfig(t *testing.T) {
FluentdConfig: FluentdConfig{
FluentdURL: "https://localhost:8888/test.log",
FluentdSessionURL: "https://localhost:8888/session",
FluentdCert: path.Join(wd, "testdata", "fake-file"),
FluentdKey: path.Join(wd, "testdata", "fake-file"),
FluentdCA: path.Join(wd, "testdata", "fake-file"),
FluentdCert: filepath.Join(wd, "testdata", "fake-file"),
FluentdKey: filepath.Join(wd, "testdata", "fake-file"),
FluentdCA: filepath.Join(wd, "testdata", "fake-file"),
},
TeleportConfig: TeleportConfig{
TeleportAddr: "localhost:3025",
TeleportIdentityFile: path.Join(wd, "testdata", "fake-file"),
TeleportIdentityFile: filepath.Join(wd, "testdata", "fake-file"),
TeleportRefreshEnabled: true,
TeleportRefreshInterval: 2 * time.Minute,
},
Expand Down Expand Up @@ -123,13 +123,13 @@ func TestStartCmdConfig(t *testing.T) {
FluentdConfig: FluentdConfig{
FluentdURL: "https://localhost:8888/test.log",
FluentdSessionURL: "https://localhost:8888/session",
FluentdCert: path.Join(wd, "testdata", "fake-file"),
FluentdKey: path.Join(wd, "testdata", "fake-file"),
FluentdCA: path.Join(wd, "testdata", "fake-file"),
FluentdCert: filepath.Join(wd, "testdata", "fake-file"),
FluentdKey: filepath.Join(wd, "testdata", "fake-file"),
FluentdCA: filepath.Join(wd, "testdata", "fake-file"),
},
TeleportConfig: TeleportConfig{
TeleportAddr: "localhost:3025",
TeleportIdentityFile: path.Join(wd, "testdata", "fake-file"),
TeleportIdentityFile: filepath.Join(wd, "testdata", "fake-file"),
TeleportRefreshEnabled: true,
TeleportRefreshInterval: 2 * time.Minute,
},
Expand Down
25 changes: 12 additions & 13 deletions integrations/event-handler/configure_cmd.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,6 @@ import (
"io"
"math/big"
"os"
"path"
"path/filepath"
"strings"

Expand Down Expand Up @@ -119,15 +118,15 @@ const (
func RunConfigureCmd(cfg *ConfigureCmdConfig) error {
c := ConfigureCmd{
ConfigureCmdConfig: cfg,
caCertPath: path.Join(cfg.Out, cfg.CAName) + ".crt",
caKeyPath: path.Join(cfg.Out, cfg.CAName) + ".key",
serverCertPath: path.Join(cfg.Out, cfg.ServerName) + ".crt",
serverKeyPath: path.Join(cfg.Out, cfg.ServerName) + ".key",
clientCertPath: path.Join(cfg.Out, cfg.ClientName) + ".crt",
clientKeyPath: path.Join(cfg.Out, cfg.ClientName) + ".key",
roleDefPath: path.Join(cfg.Out, roleDefFileName),
fluentdConfPath: path.Join(cfg.Out, fluentdConfFileName),
confPath: path.Join(cfg.Out, confFileName),
caCertPath: filepath.Join(cfg.Out, cfg.CAName) + ".crt",
caKeyPath: filepath.Join(cfg.Out, cfg.CAName) + ".key",
serverCertPath: filepath.Join(cfg.Out, cfg.ServerName) + ".crt",
serverKeyPath: filepath.Join(cfg.Out, cfg.ServerName) + ".key",
clientCertPath: filepath.Join(cfg.Out, cfg.ClientName) + ".crt",
clientKeyPath: filepath.Join(cfg.Out, cfg.ClientName) + ".key",
roleDefPath: filepath.Join(cfg.Out, roleDefFileName),
fluentdConfPath: filepath.Join(cfg.Out, fluentdConfFileName),
confPath: filepath.Join(cfg.Out, confFileName),
}

g, err := GenerateMTLSCerts(cfg.DNSNames, cfg.IP, cfg.TTL, cfg.Length)
Expand Down Expand Up @@ -347,9 +346,9 @@ func (c *ConfigureCmd) writeFluentdConf(pwd string) error {
ServerKeyFileName string
Pwd string
}{
path.Base(c.caCertPath),
path.Base(c.serverCertPath),
path.Base(c.serverKeyPath),
filepath.Base(c.caCertPath),
filepath.Base(c.serverCertPath),
filepath.Base(c.serverKeyPath),
pwd,
}

Expand Down
14 changes: 7 additions & 7 deletions integrations/event-handler/fake_fluentd_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ import (
"net/http"
"net/http/httptest"
"os"
"path"
"path/filepath"
"testing"
"time"

Expand Down Expand Up @@ -73,12 +73,12 @@ func (f *FakeFluentd) writeCerts() error {
return trace.Wrap(err)
}

f.caCertPath = path.Join(f.keyTmpDir, "ca.crt")
f.caKeyPath = path.Join(f.keyTmpDir, "ca.key")
f.serverCertPath = path.Join(f.keyTmpDir, "server.crt")
f.serverKeyPath = path.Join(f.keyTmpDir, "server.key")
f.clientCertPath = path.Join(f.keyTmpDir, "client.crt")
f.clientKeyPath = path.Join(f.keyTmpDir, "client.key")
f.caCertPath = filepath.Join(f.keyTmpDir, "ca.crt")
f.caKeyPath = filepath.Join(f.keyTmpDir, "ca.key")
f.serverCertPath = filepath.Join(f.keyTmpDir, "server.crt")
f.serverKeyPath = filepath.Join(f.keyTmpDir, "server.key")
f.clientCertPath = filepath.Join(f.keyTmpDir, "client.crt")
f.clientKeyPath = filepath.Join(f.keyTmpDir, "client.key")

err = g.CACert.WriteFile(f.caCertPath, f.caKeyPath, "")
if err != nil {
Expand Down
6 changes: 3 additions & 3 deletions integrations/event-handler/mtls_certs_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ import (
"encoding/pem"
"io"
"os"
"path"
"path/filepath"
"testing"
"time"

Expand Down Expand Up @@ -60,9 +60,9 @@ func TestGenerateClientCertFile(t *testing.T) {
require.Equal(t, "localhost", certs.serverCert.DNSNames[0])

// Write the cert to the tempdir
err = certs.ClientCert.WriteFile(path.Join(td, cp), path.Join(td, kp), ".")
err = certs.ClientCert.WriteFile(filepath.Join(td, cp), filepath.Join(td, kp), ".")
require.NoError(t, err)
f, err := os.Open(path.Join(td, cp))
f, err := os.Open(filepath.Join(td, cp))
require.NoError(t, err)
b, err := io.ReadAll(f)
require.NoError(t, err)
Expand Down
6 changes: 3 additions & 3 deletions integrations/event-handler/state.go
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ import (
"io/fs"
"net"
"os"
"path"
"path/filepath"
"strings"
"syscall"
"time"
Expand Down Expand Up @@ -110,10 +110,10 @@ func createStorageDir(c *StartCmdConfig) (string, error) {
return "", trace.Wrap(err)
}

dir = path.Join(dir, "dry_run", rs)
dir = filepath.Join(dir, "dry_run", rs)
}

dir = path.Join(c.StorageDir, dir)
dir = filepath.Join(c.StorageDir, dir)

_, err = os.Stat(dir)
if os.IsNotExist(err) {
Expand Down
5 changes: 2 additions & 3 deletions integrations/lib/tar/extract.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,6 @@ import (
"errors"
"io"
"os"
"path"
"path/filepath"
"strings"

Expand Down Expand Up @@ -116,10 +115,10 @@ func Extract(reader io.Reader, options ExtractOptions) error {
if strip > len(parts)-1 {
strip = len(parts) - 1
}
outFileName = path.Join(parts[strip:]...)
outFileName = filepath.Join(parts[strip:]...)
}

outFilePath := path.Join(outDir, outFileName)
outFilePath := filepath.Join(outDir, outFileName)
outFilePerm := os.FileMode(header.Mode).Perm()

// fail if the outFilePath is outside outDir, see the "zip slip" vulnerability
Expand Down
4 changes: 2 additions & 2 deletions lib/backend/pgbk/common/gcp_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ import (
"context"
"log/slog"
"os"
"path"
"path/filepath"
"testing"
"time"

Expand Down Expand Up @@ -79,7 +79,7 @@ func Test_makeGCPCloudSQLAuthOptionsForServiceAccount(t *testing.T) {
func mustSetGoogleApplicationCredentialsEnv(t *testing.T) {
t.Helper()

file := path.Join(t.TempDir(), uuid.New().String())
file := filepath.Join(t.TempDir(), uuid.New().String())
err := os.WriteFile(file, []byte(fakeServiceAccountCredentialsJSON), 0644)
require.NoError(t, err)

Expand Down
Loading

0 comments on commit ec3e48b

Please sign in to comment.