ci/github-script/teams: use consistent style

These are style-only changes, that are not enforced via tooling - but
used mostly consistently in the other github-script files.
This commit is contained in:
Wolfgang Walther
2025-10-28 11:53:23 +01:00
parent 81005856bb
commit 3df31aa255
2 changed files with 11 additions and 9 deletions

19
ci/github-script/get-teams.js Executable file → Normal file
View File

@@ -7,9 +7,13 @@ const excludeTeams = [
module.exports = async ({ github, context, core, outFile }) => {
const withRateLimit = require('./withRateLimit.js')
const { writeFileSync } = require('node:fs')
const org = context.repo.owner
const result = {}
await withRateLimit({ github, core }, async (_stats) => {
/// Turn an Array of users into an Object, mapping user.login -> user.id
await withRateLimit({ github, core }, async () => {
// Turn an Array of users into an Object, mapping user.login -> user.id
function makeUserSet(users) {
// Sort in-place and build result by mutation
users.sort((a, b) => (a.login > b.login ? 1 : -1))
@@ -20,21 +24,21 @@ module.exports = async ({ github, context, core, outFile }) => {
}, {})
}
/// Process a list of teams and append to the result variable
// Process a list of teams and append to the result variable
async function processTeams(teams) {
for (const team of teams) {
core.notice(`Processing team ${team.slug}`)
if (!excludeTeams.some((regex) => team.slug.match(regex))) {
const members = makeUserSet(
await github.paginate(github.rest.teams.listMembersInOrg, {
org: context.repo.owner,
org,
team_slug: team.slug,
role: 'member',
}),
)
const maintainers = makeUserSet(
await github.paginate(github.rest.teams.listMembersInOrg, {
org: context.repo.owner,
org,
team_slug: team.slug,
role: 'maintainer',
}),
@@ -49,7 +53,7 @@ module.exports = async ({ github, context, core, outFile }) => {
}
await processTeams(
await github.paginate(github.rest.teams.listChildInOrg, {
org: context.repo.owner,
org,
team_slug: team.slug,
}),
)
@@ -57,8 +61,7 @@ module.exports = async ({ github, context, core, outFile }) => {
}
const teams = await github.paginate(github.rest.repos.listTeams, {
owner: context.repo.owner,
repo: context.repo.repo,
...context.repo,
})
await processTeams(teams)

View File

@@ -91,7 +91,6 @@ program
.argument('[outFile]', 'Path to the output file (Example: github-teams.json). If not set, prints to stdout')
.action(async (owner, repo, outFile, options) => {
const getTeams = (await import('./get-teams.js')).default
// TODO: Refactor this file so we don't need to pass a PR
await run(getTeams, owner, repo, undefined, { ...options, outFile })
})