feat: deploy Renovate Bot via CronJob for automatic dependency updates
- CronJob every 6h, concurrencyPolicy: Forbid - Platform gitea at git.chemavx.xyz, repos: researchowl, polymarket-bot, n8n - packageRules: major=PR only, patch=automerge, private registry disabled - Secret placeholder for Gitea token (fill in before applying ArgoCD app) - ArgoCD Application with automated sync Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,20 @@
|
||||
apiVersion: argoproj.io/v1alpha1
|
||||
kind: Application
|
||||
metadata:
|
||||
name: renovate
|
||||
namespace: argocd
|
||||
spec:
|
||||
project: default
|
||||
source:
|
||||
repoURL: https://git.chemavx.xyz/chemavx/k8s-manifests
|
||||
targetRevision: HEAD
|
||||
path: renovate
|
||||
destination:
|
||||
server: https://kubernetes.default.svc
|
||||
namespace: renovate
|
||||
syncPolicy:
|
||||
automated:
|
||||
prune: true
|
||||
selfHeal: true
|
||||
syncOptions:
|
||||
- CreateNamespace=true
|
||||
@@ -0,0 +1,46 @@
|
||||
apiVersion: v1
|
||||
kind: ConfigMap
|
||||
metadata:
|
||||
name: renovate-config
|
||||
namespace: renovate
|
||||
data:
|
||||
config.js: |
|
||||
module.exports = {
|
||||
platform: 'gitea',
|
||||
endpoint: 'https://git.chemavx.xyz',
|
||||
repositories: [
|
||||
'chemavx/researchowl',
|
||||
'chemavx/polymarket-bot',
|
||||
'chemavx/n8n',
|
||||
],
|
||||
automerge: false,
|
||||
assignees: ['chemavx'],
|
||||
labels: ['renovate'],
|
||||
prCreation: 'not-pending',
|
||||
timezone: 'Europe/Madrid',
|
||||
schedule: ['after 9am and before 6pm on weekdays'],
|
||||
packageRules: [
|
||||
{
|
||||
// Major bumps: crear PR pero no automerge, requiere revisión manual
|
||||
matchUpdateTypes: ['major'],
|
||||
automerge: false,
|
||||
labels: ['renovate', 'major-update'],
|
||||
},
|
||||
{
|
||||
// Minor bumps: PR sin automerge
|
||||
matchUpdateTypes: ['minor'],
|
||||
automerge: false,
|
||||
},
|
||||
{
|
||||
// Patch bumps: automerge automático
|
||||
matchUpdateTypes: ['patch'],
|
||||
automerge: true,
|
||||
automergeType: 'pr',
|
||||
},
|
||||
{
|
||||
// Imágenes del registry privado: nunca tocar (tags son commits SHA)
|
||||
matchPackagePatterns: ['^git\\.chemavx\\.xyz/'],
|
||||
enabled: false,
|
||||
},
|
||||
],
|
||||
};
|
||||
@@ -0,0 +1,45 @@
|
||||
apiVersion: batch/v1
|
||||
kind: CronJob
|
||||
metadata:
|
||||
name: renovate
|
||||
namespace: renovate
|
||||
spec:
|
||||
schedule: "0 */6 * * *"
|
||||
concurrencyPolicy: Forbid
|
||||
successfulJobsHistoryLimit: 3
|
||||
failedJobsHistoryLimit: 3
|
||||
jobTemplate:
|
||||
spec:
|
||||
backoffLimit: 0
|
||||
template:
|
||||
spec:
|
||||
restartPolicy: Never
|
||||
containers:
|
||||
- name: renovate
|
||||
image: ghcr.io/renovatebot/renovate:latest
|
||||
imagePullPolicy: Always
|
||||
env:
|
||||
- name: RENOVATE_TOKEN
|
||||
valueFrom:
|
||||
secretKeyRef:
|
||||
name: renovate-token
|
||||
key: RENOVATE_TOKEN
|
||||
- name: RENOVATE_CONFIG_FILE
|
||||
value: /opt/renovate/config.js
|
||||
- name: LOG_LEVEL
|
||||
value: info
|
||||
resources:
|
||||
requests:
|
||||
cpu: 100m
|
||||
memory: 256Mi
|
||||
limits:
|
||||
cpu: "1"
|
||||
memory: 1Gi
|
||||
volumeMounts:
|
||||
- name: config
|
||||
mountPath: /opt/renovate
|
||||
readOnly: true
|
||||
volumes:
|
||||
- name: config
|
||||
configMap:
|
||||
name: renovate-config
|
||||
@@ -0,0 +1,4 @@
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: renovate
|
||||
@@ -0,0 +1,10 @@
|
||||
apiVersion: v1
|
||||
kind: Secret
|
||||
metadata:
|
||||
name: renovate-token
|
||||
namespace: renovate
|
||||
type: Opaque
|
||||
stringData:
|
||||
# Reemplazar con el token de Gitea que crees en:
|
||||
# https://git.chemavx.xyz/user/settings/applications
|
||||
RENOVATE_TOKEN: "PLACEHOLDER"
|
||||
Reference in New Issue
Block a user