Skip to content

Commit

Permalink
rebase from upstream/master
Browse files Browse the repository at this point in the history
  • Loading branch information
Kam D Kasravi committed Oct 5, 2019
1 parent d48b8da commit 5897f84
Show file tree
Hide file tree
Showing 86 changed files with 28,858 additions and 1,701 deletions.
224 changes: 224 additions & 0 deletions tests/api-service-overlays-application_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,224 @@
package tests_test

import (
"sigs.k8s.io/kustomize/v3/k8sdeps/kunstruct"
"sigs.k8s.io/kustomize/v3/k8sdeps/transformer"
"sigs.k8s.io/kustomize/v3/pkg/fs"
"sigs.k8s.io/kustomize/v3/pkg/loader"
"sigs.k8s.io/kustomize/v3/pkg/plugins"
"sigs.k8s.io/kustomize/v3/pkg/resmap"
"sigs.k8s.io/kustomize/v3/pkg/resource"
"sigs.k8s.io/kustomize/v3/pkg/target"
"sigs.k8s.io/kustomize/v3/pkg/validators"
"testing"
)

func writeApiServiceOverlaysApplication(th *KustTestHarness) {
th.writeF("/manifests/pipeline/api-service/overlays/application/application.yaml", `
apiVersion: app.k8s.io/v1beta1
kind: Application
metadata:
name: $(generateName)
spec:
selector:
matchLabels:
app.kubernetes.io/instance: $(generateName)
componentKinds:
- group: apps
kind: Deployment
- group: rbac.authorization.k8s.io
kind: Role
- group: rbac.authorization.k8s.io
kind: RoleBinding
- group: core
kind: ServiceAccount
- group: core
kind: Service
descriptor:
type: "pipeline-api-server"
version: "v1beta1"
description: "api-server for kubeflow pipelines"
keywords:
- "argo"
links:
- description: About
url: "https://github.com/kubeflow/pipelines"
`)
th.writeF("/manifests/pipeline/api-service/overlays/application/params.yaml", `
varReference:
- path: metadata/name
kind: Application
- path: spec/selector/matchLabels/app.kubernetes.io\/instance
kind: Application
- path: spec/selector/app.kubernetes.io\/instance
kind: Service
- path: spec/selector/matchLabels/app.kubernetes.io\/instance
kind: Deployment
- path: spec/template/metadata/labels/app.kubernetes.io\/instance
kind: Deployment
`)
th.writeF("/manifests/pipeline/api-service/overlays/application/params.env", `
generateName=
`)
th.writeK("/manifests/pipeline/api-service/overlays/application", `
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
bases:
- ../../base
resources:
- application.yaml
configMapGenerator:
- name: pipeline-api-server-app-parameters
env: params.env
vars:
- name: generateName
objref:
kind: ConfigMap
name: pipeline-api-server-app-parameters
apiVersion: v1
fieldref:
fieldpath: data.generateName
configurations:
- params.yaml
commonLabels:
app.kubernetes.io/name: pipeline-api-server
app.kubernetes.io/instance: $(generateName)
app.kubernetes.io/managed-by: kfctl
app.kubernetes.io/component: pipeline-api-server
app.kubernetes.io/part-of: kubeflow
app.kubernetes.io/version: v0.6
`)
th.writeF("/manifests/pipeline/api-service/base/deployment.yaml", `
apiVersion: apps/v1
kind: Deployment
metadata:
name: ml-pipeline
spec:
template:
spec:
containers:
- name: ml-pipeline-api-server
env:
- name: POD_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
image: gcr.io/ml-pipeline/api-server:0.1.23
imagePullPolicy: IfNotPresent
ports:
- containerPort: 8888
- containerPort: 8887
serviceAccountName: ml-pipeline
`)
th.writeF("/manifests/pipeline/api-service/base/role-binding.yaml", `
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: RoleBinding
metadata:
name: ml-pipeline
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: Role
name: ml-pipeline
subjects:
- kind: ServiceAccount
name: ml-pipeline
`)
th.writeF("/manifests/pipeline/api-service/base/role.yaml", `
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: Role
metadata:
name: ml-pipeline
rules:
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- create
- get
- list
- update
- patch
- delete
`)
th.writeF("/manifests/pipeline/api-service/base/service-account.yaml", `
apiVersion: v1
kind: ServiceAccount
metadata:
name: ml-pipeline
`)
th.writeF("/manifests/pipeline/api-service/base/service.yaml", `
apiVersion: v1
kind: Service
metadata:
name: ml-pipeline
spec:
ports:
- name: http
port: 8888
protocol: TCP
targetPort: 8888
- name: grpc
port: 8887
protocol: TCP
targetPort: 8887
`)
th.writeK("/manifests/pipeline/api-service/base", `
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
commonLabels:
app: ml-pipeline
resources:
- deployment.yaml
- role-binding.yaml
- role.yaml
- service-account.yaml
- service.yaml
images:
- name: gcr.io/ml-pipeline/api-server
newTag: '0.1.23'
`)
}

func TestApiServiceOverlaysApplication(t *testing.T) {
th := NewKustTestHarness(t, "/manifests/pipeline/api-service/overlays/application")
writeApiServiceOverlaysApplication(th)
m, err := th.makeKustTarget().MakeCustomizedResMap()
if err != nil {
t.Fatalf("Err: %v", err)
}
expected, err := m.AsYaml()
if err != nil {
t.Fatalf("Err: %v", err)
}
targetPath := "../pipeline/api-service/overlays/application"
fsys := fs.MakeRealFS()
lrc := loader.RestrictionRootOnly
_loader, loaderErr := loader.NewLoader(lrc, validators.MakeFakeValidator(), targetPath, fsys)
if loaderErr != nil {
t.Fatalf("could not load kustomize loader: %v", loaderErr)
}
rf := resmap.NewFactory(resource.NewFactory(kunstruct.NewKunstructuredFactoryImpl()), transformer.NewFactoryImpl())
pc := plugins.DefaultPluginConfig()
kt, err := target.NewKustTarget(_loader, rf, transformer.NewFactoryImpl(), plugins.NewLoader(pc, rf))
if err != nil {
th.t.Fatalf("Unexpected construction error %v", err)
}
actual, err := kt.MakeCustomizedResMap()
if err != nil {
t.Fatalf("Err: %v", err)
}
th.assertActualEqualsExpected(actual, string(expected))
}
6 changes: 3 additions & 3 deletions tests/application-base_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -117,9 +117,9 @@ configMapGenerator:
generatorOptions:
disableNameSuffixHash: true
images:
- name: gcr.io/kubeflow-images-public/kubernetes-sigs/application
newName: gcr.io/kubeflow-images-public/kubernetes-sigs/application
newTag: 1.0-beta
- name: gcr.io/kubeflow-images-public/kubernetes-sigs/application
newName: gcr.io/kubeflow-images-public/kubernetes-sigs/application
newTag: 1.0-beta
vars:
- name: project
objref:
Expand Down
8 changes: 4 additions & 4 deletions tests/application-crds-base_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ import (
)

func writeApplicationCrdsBase(th *KustTestHarness) {
th.writeF("/manifests/application/application-crds/base/crd.yaml", `
th.writeF("/manifests/application/application/application-crds/base/crd.yaml", `
apiVersion: apiextensions.k8s.io/v1beta1
kind: CustomResourceDefinition
metadata:
Expand Down Expand Up @@ -255,7 +255,7 @@ status:
conditions: []
storedVersions: []
`)
th.writeK("/manifests/application/application-crds/base", `
th.writeK("/manifests/application/application/application-crds/base", `
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
resources:
Expand All @@ -264,7 +264,7 @@ resources:
}

func TestApplicationCrdsBase(t *testing.T) {
th := NewKustTestHarness(t, "/manifests/application/application-crds/base")
th := NewKustTestHarness(t, "/manifests/application/application/application-crds/base")
writeApplicationCrdsBase(th)
m, err := th.makeKustTarget().MakeCustomizedResMap()
if err != nil {
Expand All @@ -274,7 +274,7 @@ func TestApplicationCrdsBase(t *testing.T) {
if err != nil {
t.Fatalf("Err: %v", err)
}
targetPath := "../application/application-crds/base"
targetPath := "../application/application/application-crds/base"
fsys := fs.MakeRealFS()
lrc := loader.RestrictionRootOnly
_loader, loaderErr := loader.NewLoader(lrc, validators.MakeFakeValidator(), targetPath, fsys)
Expand Down
Loading

0 comments on commit 5897f84

Please sign in to comment.