Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update renovate config to handle all dependency types and group upgrades #3312

Merged
merged 3 commits into from
Nov 6, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Jump to
Jump to file
Failed to load files.
Diff view
Diff view
142 changes: 0 additions & 142 deletions .github/dependabot.yml

This file was deleted.

72 changes: 68 additions & 4 deletions .github/renovate.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,14 @@
"onboarding": false,
"platform": "github",
"repositories": ["WordPress/openverse"],
"extends": ["config:base", ":preserveSemverRanges", "schedule:monthly"],
"extends": [
"config:recommended",
":preserveSemverRanges",
":automergeMinor",
":automergePr",
"schedule:monthly",
"group:monorepos"
],
"prCommitsPerRunLimit": 3,
"labels": [
"dependencies",
Expand All @@ -16,9 +23,66 @@
"packageRules": [
{
"matchDatasources": ["docker"],
"labels": ["🐳 tech: docker"]
"addLabels": ["🐳 tech: docker"]
},
{
"groupName": "workflows",
"matchFileNames": [
".github/{actions,workflows}/**",
"automations/**",
".pre-commit-config.yaml"
],
"matchManagers": ["pre-commit", "github-actions"],
"addLabels": ["🧱 stack: mgmt"]
},
{
"matchDatasources": ["pypi"],
"addLabels": ["🐍 tech: python"]
},
{
"matchDatasources": ["npm"],
"addLabels": ["🟨 tech: javascript"]
},
{
"matchFileNames": ["{frontend,packages}/**"],
"addLabels": ["🧱 stack: frontend"]
},
{
"matchFileNames": ["api/**"],
"addLabels": ["🧱 stack: api"]
},
{
"matchFileNames": ["ingestion_server/**"],
"addLabels": ["🧱 stack: ingestion server"]
},
{
"matchFileNames": ["catalog/**"],
"addLabels": ["🧱 stack: catalog"]
},
{
"matchFileNames": ["documentation/**"],
"addLabels": ["🧱 stack: documentation"]
},
{
"groupName": "python dev dependencies",
"matchDepTypes": ["dev-packages"],
"matchManagers": ["pipenv"],
"matchFileNames": ["api/**", "ingestion_server/**", "documentation/**"]
},
{
"groupName": "@openverse/eslint-plugin",
"matchFileNames": ["packages/eslint-plugin/**"]
},
{
"groupName": "tailwind",
"matchPackagePatterns": ["tailwindcss"]
},
{
"groupName": "@testing-library",
"matchPackagePrefixes": ["@testing-library"]
}
],
"ignorePaths": ["package.json"],
"includeForks": false
"forkProcessing": "disabled",
"allowScripts": true,
"pre-commit": { "enabled": true }
}
85 changes: 81 additions & 4 deletions .github/workflows/renovate.yml
Original file line number Diff line number Diff line change
@@ -1,18 +1,95 @@
name: Renovate
on:
# This lets you dispatch a renovate job with different cache options if you want to reset or disable the cache manually.
workflow_dispatch:
inputs:
repoCache:
description: "Reset or disable the cache?"
type: choice
default: enabled
options:
- enabled
- disabled
- reset
schedule:
# The "*" (#42, asterisk) character has special semantics in YAML, so this
# string has to be quoted.
- cron: "0/15 * * * *"
# Run every 30 minutes:
- cron: "0,30 * * * *"

# Adding these as env variables makes it easy to re-use them in different steps and in bash.
env:
cache_archive: renovate_cache.tar.gz
# This is the dir renovate provides -- if we set our own directory via cacheDir, we can run into permissions issues.
# It is also possible to cache a higher level of the directory, but it has minimal benefit. While renovate execution
# time gets faster, it also takes longer to upload the cache as it grows bigger.
cache_dir: /tmp/renovate/cache/renovate/repository
# This can be manually changed to bust the cache if necessary.
cache_key: renovate-cache

jobs:
renovate:
runs-on: ubuntu-latest
if: github.repository == 'WordPress/openverse'
steps:
- uses: actions/checkout@v4

# This third party action allows you to download the cache artifact from different workflow runs
# Note that actions/cache doesn't work well because the cache key would need to be computed from
# a file within the cache, meaning there would never be any data to restore. With other keys, the
sarayourfriend marked this conversation as resolved.
Show resolved Hide resolved
# cache wouldn't necessarily upload when it changes. actions/download-artifact also doesn't work
# because it only handles artifacts uploaded in the same run, and we want to restore from the
# previous successful run.
- uses: dawidd6/action-download-artifact@v2
if: github.event.inputs.repoCache != 'disabled'
continue-on-error: true
with:
name: ${{ env.cache_key }}
path: cache-download

# Using tar to compress and extract the archive isn't strictly necessary, but it can improve
# performance significantly when uploading artifacts with lots of files.
- name: Extract renovate cache
run: |
set -x
# Skip if no cache is set, such as the first time it runs.
if [ ! -d cache-download ] ; then
echo "No cache found."
exit 0
fi

# Make sure the directory exists, and extract it there. Note that it's nested in the download directory.
mkdir -p "$cache_dir"
tar -xzf "cache-download/$cache_archive" -C "$cache_dir"

# Unfortunately, the permissions expected within renovate's docker container
# are different than the ones given after the cache is restored. We have to
# change ownership to solve this. We also need to have correct permissions in
# the entire /tmp/renovate tree, not just the section with the repo cache.
sudo chown -R runneradmin:root /tmp/renovate/
ls -R "$cache_dir"

- uses: renovatebot/github-action@v39.1.1
with:
configurationFile: .github/renovate.json
configurationFile: .github/renovate-config.js
sarayourfriend marked this conversation as resolved.
Show resolved Hide resolved
token: ${{ secrets.ACCESS_TOKEN }}
env:
# This enables the cache -- if this is set, it's not necessary to add it to renovate.json.
RENOVATE_REPOSITORY_CACHE: ${{ github.event.inputs.repoCache || 'enabled' }}

# Compression helps performance in the upload step!
- name: Compress renovate cache
run: |
ls "$cache_dir"
# The -C is important -- otherwise we end up extracting the files with
# their full path, ultimately leading to a nested directory situation.
# To solve *that*, we'd have to extract to root (/), which isn't safe.
tar -czvf "$cache_archive" -C "$cache_dir" .

- uses: actions/upload-artifact@v3
if: github.event.inputs.repoCache != 'disabled'
with:
name: ${{ env.cache_key }}
path: ${{ env.cache_archive }}
# Since this is updated and restored on every run, we don't need to keep it
# for long. Just make sure this value is large enough that multiple renovate
# runs can happen before older cache archives are deleted.
retention-days: 1
7 changes: 7 additions & 0 deletions .pre-commit-config.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -171,3 +171,10 @@ repos:
entry: bash -c 'just automations/js/render-release-drafter'
language: system
pass_filenames: false

- repo: https://github.com/renovatebot/pre-commit-hooks
rev: 37.43.1
hooks:
- id: renovate-config-validator
args:
- --strict