mirror of
https://github.com/coder/coder.git
synced 2025-07-03 16:13:58 +00:00
feat: implement dynamic parameter validation (#18482)
# What does this do?
This does parameter validation for dynamic parameters in `wsbuilder`. All input parameters are validated in `coder/coder` before being sent to terraform.
The heart of this PR is [`ResolveParameters`](b65001e89c/coderd/dynamicparameters/resolver.go (L30-L30)
).
# What else changes?
`wsbuilder` now needs to load the terraform files into memory to succeed. This does add a larger memory requirement to workspace builds.
# Future work
- Sort autostart handling workspaces by template version id. So workspaces with the same template version only load the terraform files once from the db, and store them in the cache.
This commit is contained in:
@ -100,10 +100,11 @@ func TestDynamicParametersWithTerraformValues(t *testing.T) {
|
||||
require.Equal(t, -1, preview.ID)
|
||||
require.Empty(t, preview.Diagnostics)
|
||||
|
||||
require.Len(t, preview.Parameters, 1)
|
||||
require.Equal(t, "jetbrains_ide", preview.Parameters[0].Name)
|
||||
require.True(t, preview.Parameters[0].Value.Valid)
|
||||
require.Equal(t, "CL", preview.Parameters[0].Value.Value)
|
||||
require.Len(t, preview.Parameters, 2)
|
||||
coderdtest.AssertParameter(t, "jetbrains_ide", preview.Parameters).
|
||||
Exists().Value("CL")
|
||||
coderdtest.AssertParameter(t, "region", preview.Parameters).
|
||||
Exists().Value("na")
|
||||
})
|
||||
|
||||
// OldProvisioners use the static parameters in the dynamic param flow
|
||||
@ -241,10 +242,11 @@ func TestDynamicParametersWithTerraformValues(t *testing.T) {
|
||||
require.Equal(t, -1, preview.ID)
|
||||
require.Empty(t, preview.Diagnostics)
|
||||
|
||||
require.Len(t, preview.Parameters, 1)
|
||||
require.Equal(t, "jetbrains_ide", preview.Parameters[0].Name)
|
||||
require.True(t, preview.Parameters[0].Value.Valid)
|
||||
require.Equal(t, "CL", preview.Parameters[0].Value.Value)
|
||||
require.Len(t, preview.Parameters, 2)
|
||||
coderdtest.AssertParameter(t, "jetbrains_ide", preview.Parameters).
|
||||
Exists().Value("CL")
|
||||
coderdtest.AssertParameter(t, "region", preview.Parameters).
|
||||
Exists().Value("na")
|
||||
_ = stream.Close(websocket.StatusGoingAway)
|
||||
|
||||
wrk := coderdtest.CreateWorkspace(t, setup.client, setup.template.ID, func(request *codersdk.CreateWorkspaceRequest) {
|
||||
@ -253,6 +255,10 @@ func TestDynamicParametersWithTerraformValues(t *testing.T) {
|
||||
Name: preview.Parameters[0].Name,
|
||||
Value: "GO",
|
||||
},
|
||||
{
|
||||
Name: preview.Parameters[1].Name,
|
||||
Value: "eu",
|
||||
},
|
||||
}
|
||||
request.EnableDynamicParameters = true
|
||||
})
|
||||
@ -260,22 +266,24 @@ func TestDynamicParametersWithTerraformValues(t *testing.T) {
|
||||
|
||||
params, err := setup.client.WorkspaceBuildParameters(ctx, wrk.LatestBuild.ID)
|
||||
require.NoError(t, err)
|
||||
require.Len(t, params, 1)
|
||||
require.Equal(t, "jetbrains_ide", params[0].Name)
|
||||
require.Equal(t, "GO", params[0].Value)
|
||||
require.ElementsMatch(t, []codersdk.WorkspaceBuildParameter{
|
||||
{Name: "jetbrains_ide", Value: "GO"}, {Name: "region", Value: "eu"},
|
||||
}, params)
|
||||
|
||||
regionOptions := []string{"na", "af", "sa", "as"}
|
||||
|
||||
// A helper function to assert params
|
||||
doTransition := func(t *testing.T, trans codersdk.WorkspaceTransition) {
|
||||
t.Helper()
|
||||
|
||||
fooVal := coderdtest.RandomUsername(t)
|
||||
regionVal := regionOptions[0]
|
||||
regionOptions = regionOptions[1:] // Choose the next region on the next build
|
||||
|
||||
bld, err := setup.client.CreateWorkspaceBuild(ctx, wrk.ID, codersdk.CreateWorkspaceBuildRequest{
|
||||
TemplateVersionID: setup.template.ActiveVersionID,
|
||||
Transition: trans,
|
||||
RichParameterValues: []codersdk.WorkspaceBuildParameter{
|
||||
// No validation, so this should work as is.
|
||||
// Overwrite the value on each transition
|
||||
{Name: "foo", Value: fooVal},
|
||||
{Name: "region", Value: regionVal},
|
||||
},
|
||||
EnableDynamicParameters: ptr.Ref(true),
|
||||
})
|
||||
@ -286,7 +294,7 @@ func TestDynamicParametersWithTerraformValues(t *testing.T) {
|
||||
require.NoError(t, err)
|
||||
require.ElementsMatch(t, latestParams, []codersdk.WorkspaceBuildParameter{
|
||||
{Name: "jetbrains_ide", Value: "GO"},
|
||||
{Name: "foo", Value: fooVal},
|
||||
{Name: "region", Value: regionVal},
|
||||
})
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user