Skip to content

Commit

Permalink
Generate volume and volume mount names
Browse files Browse the repository at this point in the history
Before this, if a user wanted to attach a Volume named "workspace"
they'd get a confusing error message (tektoncd#1402). tektoncd#1404 improves the error
message, but it would be nice to not have an error at all and just allow
user-defined volumes named "workspace"
  • Loading branch information
imjasonh committed Oct 9, 2019
1 parent d36e719 commit 2599039
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 20 deletions.
49 changes: 29 additions & 20 deletions pkg/reconciler/taskrun/resources/pod.go
Original file line number Diff line number Diff line change
Expand Up @@ -67,20 +67,6 @@ var (
Name: "HOME",
Value: homeDir,
}}
implicitVolumeMounts = []corev1.VolumeMount{{
Name: "workspace",
MountPath: workspaceDir,
}, {
Name: "home",
MountPath: homeDir,
}}
implicitVolumes = []corev1.Volume{{
Name: "workspace",
VolumeSource: emptyVolumeSource,
}, {
Name: "home",
VolumeSource: emptyVolumeSource,
}}

zeroQty = resource.MustParse("0")

Expand All @@ -101,7 +87,28 @@ const (
readyAnnotationValue = "READY"
)

func makeCredentialInitializer(credsImage, serviceAccountName, namespace string, kubeclient kubernetes.Interface) (*v1alpha1.Step, []corev1.Volume, error) {
// implicitVolumesAndVolumeMounts returns implicit Volumes and VolumeMounts for
// workspace and home volumes, with a generated name.
func implicitVolumesAndVolumeMounts() ([]corev1.Volume, []corev1.VolumeMount) {
workspaceVolumeName := names.SimpleNameGenerator.RestrictLength("workspace-")
homeVolumeName := names.SimpleNameGenerator.RestrictLength("home-")
return []corev1.Volume{{
Name: workspaceVolumeName,
VolumeSource: emptyVolumeSource,
}, {
Name: homeVolumeName,
VolumeSource: emptyVolumeSource,
}},
[]corev1.VolumeMount{{
Name: workspaceVolumeName,
MountPath: workspaceDir,
}, {
Name: homeVolumeName,
MountPath: homeDir,
}}
}

func makeCredentialInitializer(credsImage, serviceAccountName, namespace string, implicitVolumes []corev1.Volume, implicitVolumeMounts []corev1.VolumeMount, kubeclient kubernetes.Interface) (*v1alpha1.Step, []corev1.Volume, error) {
if serviceAccountName == "" {
serviceAccountName = "default"
}
Expand Down Expand Up @@ -184,7 +191,7 @@ func makeWorkingDirScript(workingDirs map[string]bool) string {
return script
}

func makeWorkingDirInitializer(bashNoopImage string, steps []v1alpha1.Step) *v1alpha1.Step {
func makeWorkingDirInitializer(bashNoopImage string, steps []v1alpha1.Step, implicitVolumeMounts []corev1.VolumeMount) *v1alpha1.Step {
workingDirs := make(map[string]bool)
for _, step := range steps {
workingDirs[step.WorkingDir] = true
Expand All @@ -206,7 +213,7 @@ func makeWorkingDirInitializer(bashNoopImage string, steps []v1alpha1.Step) *v1a

// initOutputResourcesDefaultDir checks if there are any output image resources expecting a default path
// and creates an init container to create that folder
func initOutputResourcesDefaultDir(bashNoopImage string, taskRun *v1alpha1.TaskRun, taskSpec v1alpha1.TaskSpec) []v1alpha1.Step {
func initOutputResourcesDefaultDir(bashNoopImage string, taskRun *v1alpha1.TaskRun, taskSpec v1alpha1.TaskSpec, implicitVolumeMounts []corev1.VolumeMount) []v1alpha1.Step {
var makeDirSteps []v1alpha1.Step
if len(taskRun.Spec.Outputs.Resources) > 0 {
for _, r := range taskRun.Spec.Outputs.Resources {
Expand Down Expand Up @@ -244,18 +251,20 @@ func TryGetPod(taskRunStatus v1alpha1.TaskRunStatus, gp GetPod) (*corev1.Pod, er
// MakePod converts TaskRun and TaskSpec objects to a Pod which implements the taskrun specified
// by the supplied CRD.
func MakePod(images pipeline.Images, taskRun *v1alpha1.TaskRun, taskSpec v1alpha1.TaskSpec, kubeclient kubernetes.Interface) (*corev1.Pod, error) {
cred, secrets, err := makeCredentialInitializer(images.CredsImage, taskRun.GetServiceAccountName(), taskRun.Namespace, kubeclient)
implicitVolumes, implicitVolumeMounts := implicitVolumesAndVolumeMounts()

cred, secrets, err := makeCredentialInitializer(images.CredsImage, taskRun.GetServiceAccountName(), taskRun.Namespace, implicitVolumes, implicitVolumeMounts, kubeclient)
if err != nil {
return nil, err
}
initSteps := []v1alpha1.Step{*cred}
var podSteps []v1alpha1.Step

if workingDir := makeWorkingDirInitializer(images.BashNoopImage, taskSpec.Steps); workingDir != nil {
if workingDir := makeWorkingDirInitializer(images.BashNoopImage, taskSpec.Steps, implicitVolumeMounts); workingDir != nil {
initSteps = append(initSteps, *workingDir)
}

initSteps = append(initSteps, initOutputResourcesDefaultDir(images.BashNoopImage, taskRun, taskSpec)...)
initSteps = append(initSteps, initOutputResourcesDefaultDir(images.BashNoopImage, taskRun, taskSpec, implicitVolumeMounts)...)

maxIndicesByResource := findMaxResourceRequest(taskSpec.Steps, corev1.ResourceCPU, corev1.ResourceMemory, corev1.ResourceEphemeralStorage)

Expand Down
2 changes: 2 additions & 0 deletions pkg/reconciler/taskrun/resources/pod_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,8 @@ var (
})
credsImage = "override-with-creds:latest"
bashNoopImage = "override-with-bash-noop:latest"

implicitVolumes, implicitVolumeMounts = implicitVolumesAndVolumeMounts()
)

func TestTryGetPod(t *testing.T) {
Expand Down

0 comments on commit 2599039

Please sign in to comment.