package main import ( "path/filepath" "testing" cliconfig "github.com/docker/docker/cli/config" "github.com/docker/docker/daemon/config" "github.com/spf13/pflag" "github.com/stretchr/testify/assert" ) func TestCommonOptionsInstallFlags(t *testing.T) { flags := pflag.NewFlagSet("testing", pflag.ContinueOnError) opts := newDaemonOptions(&config.Config{}) opts.InstallFlags(flags) err := flags.Parse([]string{ "--tlscacert=\"/foo/cafile\"", "--tlscert=\"/foo/cert\"", "--tlskey=\"/foo/key\"", }) assert.NoError(t, err) assert.Equal(t, "/foo/cafile", opts.TLSOptions.CAFile) assert.Equal(t, "/foo/cert", opts.TLSOptions.CertFile) assert.Equal(t, opts.TLSOptions.KeyFile, "/foo/key") } func defaultPath(filename string) string { return filepath.Join(cliconfig.Dir(), filename) } func TestCommonOptionsInstallFlagsWithDefaults(t *testing.T) { flags := pflag.NewFlagSet("testing", pflag.ContinueOnError) opts := newDaemonOptions(&config.Config{}) opts.InstallFlags(flags) err := flags.Parse([]string{}) assert.NoError(t, err) assert.Equal(t, defaultPath("ca.pem"), opts.TLSOptions.CAFile) assert.Equal(t, defaultPath("cert.pem"), opts.TLSOptions.CertFile) assert.Equal(t, defaultPath("key.pem"), opts.TLSOptions.KeyFile) }