forked from apollographql/apollo-server
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrenovate.json5
63 lines (63 loc) · 2.71 KB
/
renovate.json5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
{
"extends": [
"apollo-open-source",
"group:graphqlcodegeneratorMonorepo",
"group:graphql-toolsMonorepo",
"group:jestMonorepo",
"group:jestPlusTSJest",
"group:jestPlusTypes",
],
"schedule": null,
// Override this value set in apollo-open-source back to the default.
// It's nice to be able to see PRs for everything in the Dependency Dashboard.
prCreation: "immediate",
// Disable circleci manager; see apollographql/federation's renovate file for details.
"enabledManagers": ["npm"],
"dependencyDashboard": true,
// It seems like a nice idea to let Renovate use GitHub's native "automerge" since PRs
// can get merged between Renovate runs. The downsides are:
// - Renovate doesn't seem to set up the automerges to use squash-and-merge (this is
// likely going to be fixed, see eg https://github.com/renovatebot/renovate/issues/12290)
// - When Renovate does the merge itself, it does its best to ensure that the PR is fully
// rebased on main so that the CI that ran is based on main rather than a possibly slightly
// old branch point. GH auto-merge doesn't have that property so it's a bit more likely that
// a deps update could break the build if there are recent related changes.
platformAutomerge: false,
"packageRules": [
// Bunch up all non-major dependencies into a single PR. In the common case
// where the upgrades apply cleanly, this causes less noise and is resolved faster
// than starting a bunch of upgrades in parallel for what may turn out to be
// a suite of related packages all released at once.
{
"groupName": "all non-major dependencies",
"matchUpdateTypes": ["patch", "minor"],
"groupSlug": "all-minor-patch",
},
// We need to support Node v14, so we don't allow ourselves to use type definitions
// that would let us write v16-specific code.
{
matchPackageNames: ["@types/node"],
allowedVersions: "14.x"
},
// node-fetch v3 only ships as ESM. We currently build as both CommonJS and
// ESM and we're not going to go ESM-only for a while. So let's stay on v2.
// (Perhaps we could swap to undici instead if this pin gets to be a
// problem.)
{
"matchPackageNames": ["node-fetch", "@types/node-fetch"],
"allowedVersions": "2.x"
},
{
// We're uncomfortable running TS4.8 until this PR is released:
// https://github.com/microsoft/TypeScript/pull/50974 (it's not in 4.8.4).
matchPackageNames: ["typescript"],
allowedVersions: "4.7.x",
},
{
// Major upgrade rollup plugins along with rollup itself.
matchSourceUrlPrefixes: ["https://github.com/rollup/"],
matchUpdateTypes: ["major"],
groupName: "rollup",
}
]
}