[Reddit] New badge and additional testing (#5166)

* fix: added detection of private subs and aded a test

* test: added test for no subscriber info

* feat: added user-karma badge

* refactor: changed class name for testing

Changed the class name to allow testing the whole service with 'reddit'

* refactor: refactored code for code and output style

* refactor: change how variables are passed to be cleaner

Co-authored-by: Caleb Cartwright <calebcartwright@users.noreply.github.com>
Co-authored-by: repo-ranger[bot] <39074581+repo-ranger[bot]@users.noreply.github.com>
This commit is contained in:
Joe Izzard
2020-06-09 03:15:07 +01:00
committed by GitHub
parent 88ad5aac01
commit 36e1d30631
4 changed files with 197 additions and 1 deletions

View File

@@ -11,7 +11,7 @@ const schema = Joi.object({
}).required(),
}).required()
module.exports = class SubredditSubscribers extends BaseJsonService {
module.exports = class RedditSubredditSubscribers extends BaseJsonService {
static get category() {
return 'social'
}
@@ -60,6 +60,7 @@ module.exports = class SubredditSubscribers extends BaseJsonService {
url: `https://www.reddit.com/r/${subreddit}/about.json`,
errorMessages: {
404: 'subreddit not found',
403: 'subreddit is private',
},
})
}

View File

@@ -23,3 +23,22 @@ t.create('subreddit-subscribers (not existing subreddit)')
label: 'reddit',
message: 'subreddit not found',
})
t.create('subreddit-subscribers (private sub)')
.get('/centuryclub.json')
.expectBadge({
label: 'reddit',
message: 'subreddit is private',
})
t.create('subreddit-subscribers (private sub)')
.get('/centuryclub.json')
.intercept(nock =>
nock('https://www.reddit.com/r')
.get('/centuryclub/about.json')
.reply(200, { kind: 't5', data: {} })
)
.expectBadge({
label: 'reddit',
message: 'subreddit not found',
})

View File

@@ -0,0 +1,96 @@
'use strict'
const Joi = require('@hapi/joi')
const { nonNegativeInteger } = require('../validators')
const { metric } = require('../text-formatters')
const { BaseJsonService } = require('..')
const schema = Joi.object({
data: Joi.object({
link_karma: nonNegativeInteger,
comment_karma: nonNegativeInteger,
}).required(),
}).required()
module.exports = class RedditUserKarma extends BaseJsonService {
static get category() {
return 'social'
}
static get route() {
return {
base: 'reddit/user-karma',
pattern: ':variant(link|comment|combined)/:user',
}
}
static get examples() {
return [
{
title: 'Reddit User Karma',
namedParams: { variant: 'combined', user: 'example' },
staticPreview: {
label: 'combined karma',
message: 56,
color: 'red',
style: 'social',
},
},
]
}
static get defaultBadgeData() {
return {
label: 'reddit karma',
namedLogo: 'reddit',
}
}
static render({ variant, karma, user }) {
const label =
variant === 'combined'
? `u/${user} karma`
: `u/${user} karma (${variant})`
return {
label,
message: metric(karma),
color: 'red',
link: [`https://www.reddit.com/u/${user}`],
}
}
async fetch({ user }) {
return this._requestJson({
schema,
url: `https://www.reddit.com/u/${user}/about.json`,
errorMessages: {
404: 'user not found',
},
})
}
transform({ json, variant }) {
let karma
if (variant === 'link') {
karma = json.data.link_karma
} else if (variant === 'comment') {
karma = json.data.comment_karma
} else {
const total = json.data.link_karma + json.data.comment_karma
karma = total
}
return { karma }
}
async handle({ variant, user }) {
const json = await this.fetch({ user })
const { karma } = this.transform({ json, variant })
return this.constructor.render({
variant,
karma,
user,
})
}
}

View File

@@ -0,0 +1,80 @@
'use strict'
const { isMetric } = require('../test-validators')
const t = (module.exports = require('../tester').createServiceTester())
t.create('user-karma (valid - link)')
.get('/link/user_simulator.json')
.expectBadge({
label: 'u/user_simulator karma (link)',
message: isMetric,
})
t.create('user-karma (valid - comment')
.get('/comment/user_simulator.json')
.expectBadge({
label: 'u/user_simulator karma (comment)',
message: isMetric,
})
t.create('user-karma (valid - combined)')
.get('/combined/user_simulator.json')
.expectBadge({
label: 'u/user_simulator karma',
message: isMetric,
})
t.create('user-karma (non-existing user)')
.get('/combined/thisuserdoesnotexistandhopefullyneverwill.json')
.expectBadge({
label: 'reddit karma',
message: 'user not found',
})
t.create('user-karma (link - math check)')
.get('/link/user_simulator.json')
.intercept(nock =>
nock('https://www.reddit.com/u')
.get('/user_simulator/about.json')
.reply(200, { kind: 't2', data: { link_karma: 20, comment_karma: 80 } })
)
.expectBadge({
label: 'u/user_simulator karma (link)',
message: '20',
})
t.create('user-karma (comment - math check)')
.get('/comment/user_simulator.json')
.intercept(nock =>
nock('https://www.reddit.com/u')
.get('/user_simulator/about.json')
.reply(200, { kind: 't2', data: { link_karma: 20, comment_karma: 80 } })
)
.expectBadge({
label: 'u/user_simulator karma (comment)',
message: '80',
})
t.create('user-karma (combined - math check)')
.get('/combined/user_simulator.json')
.intercept(nock =>
nock('https://www.reddit.com/u')
.get('/user_simulator/about.json')
.reply(200, { kind: 't2', data: { link_karma: 20, comment_karma: 80 } })
)
.expectBadge({
label: 'u/user_simulator karma',
message: '100',
})
t.create('user-karma (combined - missing data)')
.get('/combined/user_simulator.json')
.intercept(nock =>
nock('https://www.reddit.com/u')
.get('/user_simulator/about.json')
.reply(200, { kind: 't2', data: { link_karma: 20 } })
)
.expectBadge({
label: 'reddit karma',
message: 'invalid response data',
})