mirror of
https://github.com/argoproj/argo-cd.git
synced 2026-02-20 17:48:47 +01:00
Compare commits
3 Commits
refresh-do
...
release-0.
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
08c63ec234 | ||
|
|
41f950fd43 | ||
|
|
826ee0dfa0 |
@@ -154,7 +154,7 @@ spec:
|
||||
spec:
|
||||
containers:
|
||||
- command: [/argocd-application-controller, --repo-server, 'argocd-repo-server:8081']
|
||||
image: argoproj/argocd-application-controller:v0.6.1
|
||||
image: argoproj/argocd-application-controller:v0.6.2
|
||||
name: application-controller
|
||||
serviceAccountName: application-controller
|
||||
---
|
||||
@@ -223,20 +223,20 @@ spec:
|
||||
serviceAccountName: argocd-server
|
||||
initContainers:
|
||||
- name: copyutil
|
||||
image: argoproj/argocd-server:v0.6.1
|
||||
image: argoproj/argocd-server:v0.6.2
|
||||
command: [cp, /argocd-util, /shared]
|
||||
volumeMounts:
|
||||
- mountPath: /shared
|
||||
name: static-files
|
||||
- name: ui
|
||||
image: argoproj/argocd-ui:v0.6.1
|
||||
image: argoproj/argocd-ui:v0.6.2
|
||||
command: [cp, -r, /app, /shared]
|
||||
volumeMounts:
|
||||
- mountPath: /shared
|
||||
name: static-files
|
||||
containers:
|
||||
- name: argocd-server
|
||||
image: argoproj/argocd-server:v0.6.1
|
||||
image: argoproj/argocd-server:v0.6.2
|
||||
command: [/argocd-server, --staticassets, /shared/app, --repo-server, 'argocd-repo-server:8081']
|
||||
volumeMounts:
|
||||
- mountPath: /shared
|
||||
@@ -283,7 +283,7 @@ spec:
|
||||
spec:
|
||||
containers:
|
||||
- name: argocd-repo-server
|
||||
image: argoproj/argocd-repo-server:v0.6.1
|
||||
image: argoproj/argocd-repo-server:v0.6.2
|
||||
command: [/argocd-repo-server]
|
||||
ports:
|
||||
- containerPort: 8081
|
||||
|
||||
@@ -149,7 +149,7 @@ func getDeploymentHealth(obj *unstructured.Unstructured) (*appv1.HealthStatus, e
|
||||
}
|
||||
|
||||
func getDaemonSetHealth(obj *unstructured.Unstructured) (*appv1.HealthStatus, error) {
|
||||
obj, err := kube.ConvertToVersion(obj, "", "v1")
|
||||
obj, err := kube.ConvertToVersion(obj, "apps", "v1")
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -187,7 +187,7 @@ func getDaemonSetHealth(obj *unstructured.Unstructured) (*appv1.HealthStatus, er
|
||||
}
|
||||
|
||||
func getStatefulSetHealth(obj *unstructured.Unstructured) (*appv1.HealthStatus, error) {
|
||||
obj, err := kube.ConvertToVersion(obj, "", "v1")
|
||||
obj, err := kube.ConvertToVersion(obj, "apps", "v1")
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@@ -238,7 +238,7 @@ func getStatefulSetHealth(obj *unstructured.Unstructured) (*appv1.HealthStatus,
|
||||
}
|
||||
|
||||
func getReplicaSetHealth(obj *unstructured.Unstructured) (*appv1.HealthStatus, error) {
|
||||
obj, err := kube.ConvertToVersion(obj, "", "v1")
|
||||
obj, err := kube.ConvertToVersion(obj, "apps", "v1")
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
@@ -17,7 +17,7 @@ func TestDeploymentHealth(t *testing.T) {
|
||||
var obj unstructured.Unstructured
|
||||
err = yaml.Unmarshal(yamlBytes, &obj)
|
||||
assert.Nil(t, err)
|
||||
health, err := getDeploymentHealth(&obj)
|
||||
health, err := GetAppHealth(&obj)
|
||||
assert.Nil(t, err)
|
||||
assert.NotNil(t, health)
|
||||
assert.Equal(t, appv1.HealthStatusHealthy, health.Status)
|
||||
@@ -29,7 +29,7 @@ func TestDeploymentProgressing(t *testing.T) {
|
||||
var obj unstructured.Unstructured
|
||||
err = yaml.Unmarshal(yamlBytes, &obj)
|
||||
assert.Nil(t, err)
|
||||
health, err := getDeploymentHealth(&obj)
|
||||
health, err := GetAppHealth(&obj)
|
||||
assert.Nil(t, err)
|
||||
assert.NotNil(t, health)
|
||||
assert.Equal(t, appv1.HealthStatusProgressing, health.Status)
|
||||
@@ -41,8 +41,20 @@ func TestDeploymentDegraded(t *testing.T) {
|
||||
var obj unstructured.Unstructured
|
||||
err = yaml.Unmarshal(yamlBytes, &obj)
|
||||
assert.Nil(t, err)
|
||||
health, err := getDeploymentHealth(&obj)
|
||||
health, err := GetAppHealth(&obj)
|
||||
assert.Nil(t, err)
|
||||
assert.NotNil(t, health)
|
||||
assert.Equal(t, appv1.HealthStatusDegraded, health.Status)
|
||||
}
|
||||
|
||||
func TestStatefulSetHealth(t *testing.T) {
|
||||
yamlBytes, err := ioutil.ReadFile("./testdata/statefulset.yaml")
|
||||
assert.Nil(t, err)
|
||||
var obj unstructured.Unstructured
|
||||
err = yaml.Unmarshal(yamlBytes, &obj)
|
||||
assert.Nil(t, err)
|
||||
health, err := GetAppHealth(&obj)
|
||||
assert.Nil(t, err)
|
||||
assert.NotNil(t, health)
|
||||
assert.Equal(t, appv1.HealthStatusHealthy, health.Status)
|
||||
}
|
||||
|
||||
119
util/health/testdata/statefulset.yaml
vendored
Normal file
119
util/health/testdata/statefulset.yaml
vendored
Normal file
@@ -0,0 +1,119 @@
|
||||
apiVersion: apps/v1
|
||||
kind: StatefulSet
|
||||
metadata:
|
||||
annotations:
|
||||
kubectl.kubernetes.io/last-applied-configuration: |
|
||||
{"apiVersion":"apps/v1beta2","kind":"StatefulSet","metadata":{"annotations":{},"labels":{"app":"redis","applications.argoproj.io/app-name":"redis","chart":"redis-3.6.5","heritage":"Tiller","release":"redis"},"name":"redis-master","namespace":"default"},"spec":{"selector":{"matchLabels":{"app":"redis","release":"redis","role":"master"}},"serviceName":"redis-master","template":{"metadata":{"labels":{"app":"redis","applications.argoproj.io/app-name":"redis","release":"redis","role":"master"}},"spec":{"containers":[{"env":[{"name":"REDIS_REPLICATION_MODE","value":"master"},{"name":"REDIS_PASSWORD","valueFrom":{"secretKeyRef":{"key":"redis-password","name":"redis"}}},{"name":"REDIS_DISABLE_COMMANDS","value":"FLUSHDB,FLUSHALL"}],"image":"docker.io/bitnami/redis:4.0.10-debian-9","imagePullPolicy":"Always","livenessProbe":{"exec":{"command":["redis-cli","ping"]},"failureThreshold":5,"initialDelaySeconds":30,"periodSeconds":10,"successThreshold":1,"timeoutSeconds":5},"name":"redis","ports":[{"containerPort":6379,"name":"redis"}],"readinessProbe":{"exec":{"command":["redis-cli","ping"]},"failureThreshold":5,"initialDelaySeconds":5,"periodSeconds":10,"successThreshold":1,"timeoutSeconds":1},"resources":{},"volumeMounts":[{"mountPath":"/bitnami/redis/data","name":"redis-data"}]}],"securityContext":{"fsGroup":1001,"runAsUser":1001},"serviceAccountName":"default"}},"updateStrategy":{"type":"OnDelete"},"volumeClaimTemplates":[{"metadata":{"labels":{"app":"redis","chart":"redis-3.6.5","component":"master","heritage":"Tiller","release":"redis"},"name":"redis-data"},"spec":{"accessModes":["ReadWriteOnce"],"resources":{"requests":{"storage":"8Gi"}}}}]}}
|
||||
creationTimestamp: 2018-07-20T08:23:04Z
|
||||
generation: 1
|
||||
labels:
|
||||
app: redis
|
||||
applications.argoproj.io/app-name: redis
|
||||
chart: redis-3.6.5
|
||||
heritage: Tiller
|
||||
release: redis
|
||||
name: redis-master
|
||||
namespace: default
|
||||
resourceVersion: "514251"
|
||||
selfLink: /apis/apps/v1/namespaces/default/statefulsets/redis-master
|
||||
uid: 1f80ab97-8bf6-11e8-aff0-42010a8a0fc6
|
||||
spec:
|
||||
podManagementPolicy: OrderedReady
|
||||
replicas: 1
|
||||
revisionHistoryLimit: 10
|
||||
selector:
|
||||
matchLabels:
|
||||
app: redis
|
||||
release: redis
|
||||
role: master
|
||||
serviceName: redis-master
|
||||
template:
|
||||
metadata:
|
||||
creationTimestamp: null
|
||||
labels:
|
||||
app: redis
|
||||
applications.argoproj.io/app-name: redis
|
||||
release: redis
|
||||
role: master
|
||||
spec:
|
||||
containers:
|
||||
- env:
|
||||
- name: REDIS_REPLICATION_MODE
|
||||
value: master
|
||||
- name: REDIS_PASSWORD
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
key: redis-password
|
||||
name: redis
|
||||
- name: REDIS_DISABLE_COMMANDS
|
||||
value: FLUSHDB,FLUSHALL
|
||||
image: docker.io/bitnami/redis:4.0.10-debian-9
|
||||
imagePullPolicy: Always
|
||||
livenessProbe:
|
||||
exec:
|
||||
command:
|
||||
- redis-cli
|
||||
- ping
|
||||
failureThreshold: 5
|
||||
initialDelaySeconds: 30
|
||||
periodSeconds: 10
|
||||
successThreshold: 1
|
||||
timeoutSeconds: 5
|
||||
name: redis
|
||||
ports:
|
||||
- containerPort: 6379
|
||||
name: redis
|
||||
protocol: TCP
|
||||
readinessProbe:
|
||||
exec:
|
||||
command:
|
||||
- redis-cli
|
||||
- ping
|
||||
failureThreshold: 5
|
||||
initialDelaySeconds: 5
|
||||
periodSeconds: 10
|
||||
successThreshold: 1
|
||||
timeoutSeconds: 1
|
||||
resources: {}
|
||||
terminationMessagePath: /dev/termination-log
|
||||
terminationMessagePolicy: File
|
||||
volumeMounts:
|
||||
- mountPath: /bitnami/redis/data
|
||||
name: redis-data
|
||||
dnsPolicy: ClusterFirst
|
||||
restartPolicy: Always
|
||||
schedulerName: default-scheduler
|
||||
securityContext:
|
||||
fsGroup: 1001
|
||||
runAsUser: 1001
|
||||
serviceAccount: default
|
||||
serviceAccountName: default
|
||||
terminationGracePeriodSeconds: 30
|
||||
updateStrategy:
|
||||
type: OnDelete
|
||||
volumeClaimTemplates:
|
||||
- metadata:
|
||||
creationTimestamp: null
|
||||
labels:
|
||||
app: redis
|
||||
chart: redis-3.6.5
|
||||
component: master
|
||||
heritage: Tiller
|
||||
release: redis
|
||||
name: redis-data
|
||||
spec:
|
||||
accessModes:
|
||||
- ReadWriteOnce
|
||||
resources:
|
||||
requests:
|
||||
storage: 8Gi
|
||||
status:
|
||||
phase: Pending
|
||||
status:
|
||||
collisionCount: 0
|
||||
currentReplicas: 1
|
||||
currentRevision: redis-master-7b8f75b98
|
||||
observedGeneration: 1
|
||||
readyReplicas: 1
|
||||
replicas: 1
|
||||
updateRevision: redis-master-7b8f75b98
|
||||
Reference in New Issue
Block a user