Skip to content

Commit f7baf45

Browse files
feat: support partial parameter files (#5392)
Fixes #5390
1 parent 5a568d8 commit f7baf45

File tree

3 files changed

+49
-11
lines changed

3 files changed

+49
-11
lines changed

cli/create_test.go

+29-5
Original file line numberDiff line numberDiff line change
@@ -232,13 +232,16 @@ func TestCreate(t *testing.T) {
232232
ProvisionApply: echo.ProvisionComplete,
233233
ProvisionPlan: echo.ProvisionComplete,
234234
})
235+
235236
coderdtest.AwaitTemplateVersionJob(t, client, version.ID)
236-
template := coderdtest.CreateTemplate(t, client, user.OrganizationID, version.ID)
237+
_ = coderdtest.CreateTemplate(t, client, user.OrganizationID, version.ID)
238+
237239
tempDir := t.TempDir()
238240
removeTmpDirUntilSuccessAfterTest(t, tempDir)
239241
parameterFile, _ := os.CreateTemp(tempDir, "testParameterFile*.yaml")
240-
_, _ = parameterFile.WriteString("zone: \"bananas\"")
241-
cmd, root := clitest.New(t, "create", "my-workspace", "--template", template.Name, "--parameter-file", parameterFile.Name())
242+
_, _ = parameterFile.WriteString("username: \"boingo\"")
243+
244+
cmd, root := clitest.New(t, "create", "", "--parameter-file", parameterFile.Name())
242245
clitest.SetupConfig(t, client, root)
243246
doneChan := make(chan struct{})
244247
pty := ptytest.New(t)
@@ -247,11 +250,32 @@ func TestCreate(t *testing.T) {
247250
go func() {
248251
defer close(doneChan)
249252
err := cmd.Execute()
250-
assert.EqualError(t, err, "Parameter value absent in parameter file for \"region\"!")
253+
assert.NoError(t, err)
251254
}()
255+
matches := []struct {
256+
match string
257+
write string
258+
}{
259+
{
260+
match: "Specify a name",
261+
write: "my-workspace",
262+
},
263+
{
264+
match: fmt.Sprintf("Enter a value (default: %q):", defaultValue),
265+
write: "bingo",
266+
},
267+
{
268+
match: "Confirm create?",
269+
write: "yes",
270+
},
271+
}
272+
273+
for _, m := range matches {
274+
pty.ExpectMatch(m.match)
275+
pty.WriteLine(m.write)
276+
}
252277
<-doneChan
253278
})
254-
255279
t.Run("FailedDryRun", func(t *testing.T) {
256280
t.Parallel()
257281
client := coderdtest.New(t, &coderdtest.Options{IncludeProvisionerDaemon: true})

cli/parameter.go

+7-4
Original file line numberDiff line numberDiff line change
@@ -36,18 +36,21 @@ func createParameterMapFromFile(parameterFile string) (map[string]string, error)
3636
return nil, xerrors.Errorf("Parameter file name is not specified")
3737
}
3838

39-
// Returns a parameter value from a given map, if the map exists, else takes input from the user.
40-
// Throws an error if the map exists but does not include a value for the parameter.
39+
// Returns a parameter value from a given map, if the map does not exist or does not contain the item, it takes input from the user.
40+
// Throws an error if there are any errors with the users input.
4141
func getParameterValueFromMapOrInput(cmd *cobra.Command, parameterMap map[string]string, parameterSchema codersdk.ParameterSchema) (string, error) {
4242
var parameterValue string
43+
var err error
4344
if parameterMap != nil {
4445
var ok bool
4546
parameterValue, ok = parameterMap[parameterSchema.Name]
4647
if !ok {
47-
return "", xerrors.Errorf("Parameter value absent in parameter file for %q!", parameterSchema.Name)
48+
parameterValue, err = cliui.ParameterSchema(cmd, parameterSchema)
49+
if err != nil {
50+
return "", err
51+
}
4852
}
4953
} else {
50-
var err error
5154
parameterValue, err = cliui.ParameterSchema(cmd, parameterSchema)
5255
if err != nil {
5356
return "", err

cli/templatecreate_test.go

+13-2
Original file line numberDiff line numberDiff line change
@@ -187,14 +187,25 @@ func TestTemplateCreate(t *testing.T) {
187187
match string
188188
write string
189189
}{
190-
{match: "Create and upload", write: "yes"},
190+
{
191+
match: "Create and upload",
192+
write: "yes",
193+
},
194+
{
195+
match: "Enter a value:",
196+
write: "bingo",
197+
},
198+
{
199+
match: "Confirm create?",
200+
write: "yes",
201+
},
191202
}
192203
for _, m := range matches {
193204
pty.ExpectMatch(m.match)
194205
pty.WriteLine(m.write)
195206
}
196207

197-
require.EqualError(t, <-execDone, "Parameter value absent in parameter file for \"region\"!")
208+
require.NoError(t, <-execDone)
198209
})
199210

200211
t.Run("Recreate template with same name (create, delete, create)", func(t *testing.T) {

0 commit comments

Comments
 (0)