Update [SourceForge] commit count badge to support repository parameter (#10954)

* [sourceforge] update commit count service to support repo param

follow-up to #10935
sourceforge commit count also requires the new repo param for some projects.

* [sourceforge] add redirector for legacy commit count URLs

* fix missing openapi path
This commit is contained in:
jNullj
2025-03-16 22:27:43 +02:00
committed by GitHub
parent b23a8ec307
commit 834e4e1f96
4 changed files with 51 additions and 14 deletions

View File

@@ -0,0 +1,15 @@
import { redirector } from '../index.js'
export default redirector({
// SourceForge commit count service used to only have project name as a parameter
// and the repository name was always `git`.
// The service was later updated to have the repository name as a parameter.
// This redirector is used to keep the old URLs working.
category: 'activity',
route: {
base: 'sourceforge/commit-count',
pattern: ':project',
},
transformPath: ({ project }) => `/sourceforge/commit-count/${project}/git`,
dateAdded: new Date('2025-03-15'),
})

View File

@@ -0,0 +1,6 @@
import { createServiceTester } from '../tester.js'
export const t = await createServiceTester()
t.create('commit count (redirect)')
.get('/guitarix.json')
.expectRedirect('/sourceforge/commit-count/guitarix/git.json')

View File

@@ -11,17 +11,25 @@ export default class SourceforgeCommitCount extends BaseJsonService {
static route = { static route = {
base: 'sourceforge/commit-count', base: 'sourceforge/commit-count',
pattern: ':project', pattern: ':project/:repo',
} }
static openApi = { static openApi = {
'/sourceforge/commit-count/{project}': { '/sourceforge/commit-count/{project}/{repo}': {
get: { get: {
summary: 'SourceForge Commit Count', summary: 'SourceForge Commit Count',
parameters: pathParams({ parameters: pathParams(
name: 'project', {
example: 'guitarix', name: 'project',
}), example: 'guitarix',
},
{
name: 'repo',
example: 'git',
description:
'The repository name, usually `git` but might be different.',
},
),
}, },
}, },
} }
@@ -35,18 +43,18 @@ export default class SourceforgeCommitCount extends BaseJsonService {
} }
} }
async fetch({ project }) { async fetch({ project, repo }) {
return this._requestJson({ return this._requestJson({
url: `https://sourceforge.net/rest/p/${project}/git`, url: `https://sourceforge.net/rest/p/${project}/${repo}`,
schema, schema,
httpErrors: { httpErrors: {
404: 'project not found', 404: 'project or repo not found',
}, },
}) })
} }
async handle({ project }) { async handle({ project, repo }) {
const body = await this.fetch({ project }) const body = await this.fetch({ project, repo })
return this.constructor.render({ return this.constructor.render({
commitCount: body.commit_count, commitCount: body.commit_count,
}) })

View File

@@ -3,9 +3,17 @@ import { createServiceTester } from '../tester.js'
export const t = await createServiceTester() export const t = await createServiceTester()
t.create('commit count') t.create('commit count')
.get('/guitarix.json') .get('/guitarix/git.json')
.expectBadge({ label: 'commit count', message: isMetric })
t.create('commit count (non default repo)')
.get('/opencamera/code.json')
.expectBadge({ label: 'commit count', message: isMetric }) .expectBadge({ label: 'commit count', message: isMetric })
t.create('commit count (project not found)') t.create('commit count (project not found)')
.get('/that-doesnt-exist.json') .get('/that-doesnt-exist/git.json')
.expectBadge({ label: 'commit count', message: 'project not found' }) .expectBadge({ label: 'commit count', message: 'project or repo not found' })
t.create('commit count (repo not found)')
.get('/guitarix/invalid-repo.json')
.expectBadge({ label: 'commit count', message: 'project or repo not found' })