1 // Copyright (C) The Arvados Authors. All rights reserved.
3 // SPDX-License-Identifier: AGPL-3.0
13 "git.curoverse.com/arvados.git/lib/cmd"
14 check "gopkg.in/check.v1"
17 var _ = check.Suite(&CommandSuite{})
20 // Commands must satisfy cmd.Handler interface
21 _ cmd.Handler = dumpCommand{}
22 _ cmd.Handler = checkCommand{}
25 type CommandSuite struct{}
27 func (s *CommandSuite) TestBadArg(c *check.C) {
28 var stderr bytes.Buffer
29 code := DumpCommand.RunCommand("arvados config-dump", []string{"-badarg"}, bytes.NewBuffer(nil), bytes.NewBuffer(nil), &stderr)
30 c.Check(code, check.Equals, 2)
31 c.Check(stderr.String(), check.Matches, `(?ms)flag provided but not defined: -badarg\nUsage:\n.*`)
34 func (s *CommandSuite) TestEmptyInput(c *check.C) {
35 var stdout, stderr bytes.Buffer
36 code := DumpCommand.RunCommand("arvados config-dump", []string{"-config", "-"}, &bytes.Buffer{}, &stdout, &stderr)
37 c.Check(code, check.Equals, 1)
38 c.Check(stderr.String(), check.Matches, `config does not define any clusters\n`)
41 func (s *CommandSuite) TestCheckNoDeprecatedKeys(c *check.C) {
42 var stdout, stderr bytes.Buffer
47 MaxItemsPerResponse: 1234
54 "http://0.0.0.0:8000": {}
56 UserProfileFormFields:
61 ApplicationMimetypesWithViewIcon:
64 code := CheckCommand.RunCommand("arvados config-check", []string{"-config", "-"}, bytes.NewBufferString(in), &stdout, &stderr)
65 c.Check(code, check.Equals, 0)
66 c.Check(stdout.String(), check.Equals, "")
67 c.Check(stderr.String(), check.Equals, "")
70 func (s *CommandSuite) TestCheckDeprecatedKeys(c *check.C) {
71 var stdout, stderr bytes.Buffer
76 MaxItemsPerResponse: 1234
78 code := CheckCommand.RunCommand("arvados config-check", []string{"-config", "-"}, bytes.NewBufferString(in), &stdout, &stderr)
79 c.Check(code, check.Equals, 1)
80 c.Check(stdout.String(), check.Matches, `(?ms).*\n\- +.*MaxItemsPerResponse: 1000\n\+ +MaxItemsPerResponse: 1234\n.*`)
83 func (s *CommandSuite) TestCheckOldKeepstoreConfigFile(c *check.C) {
84 f, err := ioutil.TempFile("", "")
85 c.Assert(err, check.IsNil)
86 defer os.Remove(f.Name())
88 io.WriteString(f, "Listen: :12345\nDebug: true\n")
90 var stdout, stderr bytes.Buffer
97 code := CheckCommand.RunCommand("arvados config-check", []string{"-config", "-", "-legacy-keepstore-config", f.Name()}, bytes.NewBufferString(in), &stdout, &stderr)
98 c.Check(code, check.Equals, 1)
99 c.Check(stdout.String(), check.Matches, `(?ms).*\n\- +.*LogLevel: info\n\+ +LogLevel: debug\n.*`)
100 c.Check(stderr.String(), check.Matches, `(?ms).*you should remove the legacy keepstore config file.*\n`)
103 func (s *CommandSuite) TestCheckUnknownKey(c *check.C) {
104 var stdout, stderr bytes.Buffer
118 code := CheckCommand.RunCommand("arvados config-check", []string{"-config", "-"}, bytes.NewBufferString(in), &stdout, &stderr)
119 c.Log(stderr.String())
120 c.Check(code, check.Equals, 1)
121 c.Check(stderr.String(), check.Matches, `(?ms).*deprecated or unknown config entry: Clusters.z1234.Bogus1"\n.*`)
122 c.Check(stderr.String(), check.Matches, `(?ms).*deprecated or unknown config entry: Clusters.z1234.BogusSection"\n.*`)
123 c.Check(stderr.String(), check.Matches, `(?ms).*deprecated or unknown config entry: Clusters.z1234.API.Bogus3"\n.*`)
124 c.Check(stderr.String(), check.Matches, `(?ms).*unexpected object in config entry: Clusters.z1234.PostgreSQL.ConnectionPool"\n.*`)
127 func (s *CommandSuite) TestDumpFormatting(c *check.C) {
128 var stdout, stderr bytes.Buffer
138 http://localhost:12345: {}
140 code := DumpCommand.RunCommand("arvados config-dump", []string{"-config", "-"}, bytes.NewBufferString(in), &stdout, &stderr)
141 c.Check(code, check.Equals, 0)
142 c.Check(stdout.String(), check.Matches, `(?ms).*TimeoutBooting: 10m\n.*`)
143 c.Check(stdout.String(), check.Matches, `(?ms).*http://localhost:12345: {}\n.*`)
146 func (s *CommandSuite) TestDumpUnknownKey(c *check.C) {
147 var stdout, stderr bytes.Buffer
152 ManagementToken: secret
154 code := DumpCommand.RunCommand("arvados config-dump", []string{"-config", "-"}, bytes.NewBufferString(in), &stdout, &stderr)
155 c.Check(code, check.Equals, 0)
156 c.Check(stderr.String(), check.Matches, `(?ms).*deprecated or unknown config entry: Clusters.z1234.UnknownKey.*`)
157 c.Check(stdout.String(), check.Matches, `(?ms)Clusters:\n z1234:\n.*`)
158 c.Check(stdout.String(), check.Matches, `(?ms).*\n *ManagementToken: secret\n.*`)
159 c.Check(stdout.String(), check.Not(check.Matches), `(?ms).*UnknownKey.*`)