mirror of
https://github.com/status-im/consul.git
synced 2025-02-25 20:05:24 +00:00
* First conversion * Use serf 0.8.2 tag and associated updated deps * * Move freeport and testutil into internal/ * Make internal/ its own module * Update imports * Add replace statements so API and normal Consul code are self-referencing for ease of development * Adapt to newer goe/values * Bump to new cleanhttp * Fix ban nonprintable chars test * Update lock bad args test The error message when the duration cannot be parsed changed in Go 1.12 (ae0c435877d3aacb9af5e706c40f9dddde5d3e67). This updates that test. * Update another test as well * Bump travis * Bump circleci * Bump go-discover and godo to get rid of launchpad dep * Bump dockerfile go version * fix tar command * Bump go-cleanhttp
103 lines
2.2 KiB
Go
103 lines
2.2 KiB
Go
package create
|
|
|
|
import (
|
|
"io/ioutil"
|
|
"os"
|
|
"path"
|
|
"strings"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/hashicorp/consul/agent/connect"
|
|
"github.com/hashicorp/consul/internal/testutil"
|
|
"github.com/mitchellh/cli"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestValidateCommand_noTabs(t *testing.T) {
|
|
t.Parallel()
|
|
if strings.ContainsRune(New(nil).Help(), '\t') {
|
|
t.Fatal("help has tabs")
|
|
}
|
|
}
|
|
|
|
func TestCACreateCommand(t *testing.T) {
|
|
require := require.New(t)
|
|
|
|
previousDirectory, err := os.Getwd()
|
|
require.NoError(err)
|
|
|
|
testDir := testutil.TempDir(t, "ca-create")
|
|
|
|
defer os.RemoveAll(testDir)
|
|
defer os.Chdir(previousDirectory)
|
|
|
|
os.Chdir(testDir)
|
|
|
|
ui := cli.NewMockUi()
|
|
cmd := New(ui)
|
|
|
|
require.Equal(0, cmd.Run(nil), "ca create should exit 0")
|
|
|
|
errOutput := ui.ErrorWriter.String()
|
|
require.Equal("", errOutput)
|
|
|
|
caPem := path.Join(testDir, "consul-agent-ca.pem")
|
|
require.FileExists(caPem)
|
|
|
|
certData, err := ioutil.ReadFile(caPem)
|
|
require.NoError(err)
|
|
|
|
cert, err := connect.ParseCert(string(certData))
|
|
require.NoError(err)
|
|
require.NotNil(cert)
|
|
|
|
require.Equal(1825*24*time.Hour, time.Until(cert.NotAfter).Round(24*time.Hour))
|
|
require.False(cert.PermittedDNSDomainsCritical)
|
|
require.Len(cert.PermittedDNSDomains, 0)
|
|
}
|
|
|
|
func TestCACreateCommandWithOptions(t *testing.T) {
|
|
require := require.New(t)
|
|
|
|
previousDirectory, err := os.Getwd()
|
|
require.NoError(err)
|
|
|
|
testDir := testutil.TempDir(t, "ca-create")
|
|
|
|
defer os.RemoveAll(testDir)
|
|
defer os.Chdir(previousDirectory)
|
|
|
|
os.Chdir(testDir)
|
|
|
|
ui := cli.NewMockUi()
|
|
cmd := New(ui)
|
|
|
|
args := []string{
|
|
"-days=365",
|
|
"-name-constraint=true",
|
|
"-domain=foo",
|
|
"-additional-name-constraint=bar",
|
|
}
|
|
|
|
require.Equal(0, cmd.Run(args), "ca create should exit 0")
|
|
|
|
errOutput := ui.ErrorWriter.String()
|
|
require.Equal("", errOutput)
|
|
|
|
caPem := path.Join(testDir, "foo-agent-ca.pem")
|
|
require.FileExists(caPem)
|
|
|
|
certData, err := ioutil.ReadFile(caPem)
|
|
require.NoError(err)
|
|
|
|
cert, err := connect.ParseCert(string(certData))
|
|
require.NoError(err)
|
|
require.NotNil(cert)
|
|
|
|
require.Equal(365*24*time.Hour, time.Until(cert.NotAfter).Round(24*time.Hour))
|
|
require.True(cert.PermittedDNSDomainsCritical)
|
|
require.Len(cert.PermittedDNSDomains, 3)
|
|
require.ElementsMatch(cert.PermittedDNSDomains, []string{"foo", "localhost", "bar"})
|
|
}
|