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:
@@ -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'),
|
||||||
|
})
|
||||||
@@ -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')
|
||||||
@@ -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,
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -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' })
|
||||||
|
|||||||
Reference in New Issue
Block a user