mirror of
https://github.com/all-contributors/cli.git
synced 2025-01-25 05:56:28 +00:00
fix: Wrong contribution type being added to .all-contributorsrc (#78)
* initial issue fix * tests added * revert unneisary lint change to untouched file * added myself * no contribution types when adding a contributor error handled * revert commit1bdb51eadf
* reverted readme back to commit#f697c73c48
* further reverted Readme to master * removed generated index from rm * removed generated index from rm * breaking change to cli fixed: * Update prompt.js * Update prompt.js * added code and test in my contribution * list of invalid contributions added in error message Closes #71
This commit is contained in:
parent
c4a0484759
commit
526d4dbba2
4 changed files with 89 additions and 3 deletions
|
@ -178,7 +178,7 @@ Thanks goes to these wonderful people
|
||||||
| :---: | :---: | :---: | :---: | :---: | :---: |
|
| :---: | :---: | :---: | :---: | :---: | :---: |
|
||||||
| [<img src="https://avatars3.githubusercontent.com/u/8212?v=3" width="100px;"/><br /><sub><b>Jerod Santo</b></sub>](https://jerodsanto.net)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=jerodsanto "Code") | [<img src="https://avatars1.githubusercontent.com/u/574871?v=3" width="100px;"/><br /><sub><b>Kevin Jalbert</b></sub>](https://github.com/kevinjalbert)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=kevinjalbert "Code") | [<img src="https://avatars3.githubusercontent.com/u/5038030?v=4" width="100px;"/><br /><sub><b>tunnckoCore</b></sub>](https://i.am.charlike.online)<br />[🔧](#tool-charlike "Tools") | [<img src="https://avatars2.githubusercontent.com/u/304450?v=4" width="100px;"/><br /><sub><b>Mehdi Achour</b></sub>](https://machour.idk.tn/)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=machour "Code") | [<img src="https://avatars1.githubusercontent.com/u/8344688?v=4" width="100px;"/><br /><sub><b>Roy Revelt</b></sub>](https://codsen.com)<br />[🐛](https://github.com/jfmengels/all-contributors-cli/issues?q=author%3Arevelt "Bug reports") | [<img src="https://avatars1.githubusercontent.com/u/422331?v=4" width="100px;"/><br /><sub><b>Chris Vickery</b></sub>](https://github.com/chrisinajar)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=chrisinajar "Code") |
|
| [<img src="https://avatars3.githubusercontent.com/u/8212?v=3" width="100px;"/><br /><sub><b>Jerod Santo</b></sub>](https://jerodsanto.net)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=jerodsanto "Code") | [<img src="https://avatars1.githubusercontent.com/u/574871?v=3" width="100px;"/><br /><sub><b>Kevin Jalbert</b></sub>](https://github.com/kevinjalbert)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=kevinjalbert "Code") | [<img src="https://avatars3.githubusercontent.com/u/5038030?v=4" width="100px;"/><br /><sub><b>tunnckoCore</b></sub>](https://i.am.charlike.online)<br />[🔧](#tool-charlike "Tools") | [<img src="https://avatars2.githubusercontent.com/u/304450?v=4" width="100px;"/><br /><sub><b>Mehdi Achour</b></sub>](https://machour.idk.tn/)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=machour "Code") | [<img src="https://avatars1.githubusercontent.com/u/8344688?v=4" width="100px;"/><br /><sub><b>Roy Revelt</b></sub>](https://codsen.com)<br />[🐛](https://github.com/jfmengels/all-contributors-cli/issues?q=author%3Arevelt "Bug reports") | [<img src="https://avatars1.githubusercontent.com/u/422331?v=4" width="100px;"/><br /><sub><b>Chris Vickery</b></sub>](https://github.com/chrisinajar)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=chrisinajar "Code") |
|
||||||
| [<img src="https://avatars2.githubusercontent.com/u/1026002?v=4" width="100px;"/><br /><sub><b>Bryce Reynolds</b></sub>](https://github.com/brycereynolds)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=brycereynolds "Code") | [<img src="https://avatars3.githubusercontent.com/u/2322305?v=4" width="100px;"/><br /><sub><b>James, please</b></sub>](http://www.jmeas.com)<br />[🤔](#ideas-jmeas "Ideas, Planning, & Feedback") [💻](https://github.com/jfmengels/all-contributors-cli/commits?author=jmeas "Code") | [<img src="https://avatars3.githubusercontent.com/u/1057324?v=4" width="100px;"/><br /><sub><b>Spyros Ioakeimidis</b></sub>](http://www.spyros.io)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=spirosikmd "Code") | [<img src="https://avatars3.githubusercontent.com/u/12335761?v=4" width="100px;"/><br /><sub><b>Fernando Costa</b></sub>](https://github.com/fadc80)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=fadc80 "Code") | [<img src="https://avatars0.githubusercontent.com/u/197404?v=4" width="100px;"/><br /><sub><b>snipe</b></sub>](https://snipe.net)<br />[📖](https://github.com/jfmengels/all-contributors-cli/commits?author=snipe "Documentation") | [<img src="https://avatars0.githubusercontent.com/u/997157?v=4" width="100px;"/><br /><sub><b>Gant Laborde</b></sub>](http://gantlaborde.com/)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=GantMan "Code") |
|
| [<img src="https://avatars2.githubusercontent.com/u/1026002?v=4" width="100px;"/><br /><sub><b>Bryce Reynolds</b></sub>](https://github.com/brycereynolds)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=brycereynolds "Code") | [<img src="https://avatars3.githubusercontent.com/u/2322305?v=4" width="100px;"/><br /><sub><b>James, please</b></sub>](http://www.jmeas.com)<br />[🤔](#ideas-jmeas "Ideas, Planning, & Feedback") [💻](https://github.com/jfmengels/all-contributors-cli/commits?author=jmeas "Code") | [<img src="https://avatars3.githubusercontent.com/u/1057324?v=4" width="100px;"/><br /><sub><b>Spyros Ioakeimidis</b></sub>](http://www.spyros.io)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=spirosikmd "Code") | [<img src="https://avatars3.githubusercontent.com/u/12335761?v=4" width="100px;"/><br /><sub><b>Fernando Costa</b></sub>](https://github.com/fadc80)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=fadc80 "Code") | [<img src="https://avatars0.githubusercontent.com/u/197404?v=4" width="100px;"/><br /><sub><b>snipe</b></sub>](https://snipe.net)<br />[📖](https://github.com/jfmengels/all-contributors-cli/commits?author=snipe "Documentation") | [<img src="https://avatars0.githubusercontent.com/u/997157?v=4" width="100px;"/><br /><sub><b>Gant Laborde</b></sub>](http://gantlaborde.com/)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=GantMan "Code") |
|
||||||
| [<img src="https://avatars2.githubusercontent.com/u/17708702?v=4" width="100px;"/><br /><sub><b>Md Zubair Ahmed</b></sub>](https://in.linkedin.com/in/mzubairahmed)<br />[📖](https://github.com/jfmengels/all-contributors-cli/commits?author=M-ZubairAhmed "Documentation") [🐛](https://github.com/jfmengels/all-contributors-cli/issues?q=author%3AM-ZubairAhmed "Bug reports") | [<img src="https://avatars3.githubusercontent.com/u/6177621?v=4" width="100px;"/><br /><sub><b>Divjot Singh</b></sub>](http://bogas04.github.io)<br />[📖](https://github.com/jfmengels/all-contributors-cli/commits?author=bogas04 "Documentation") | [<img src="https://avatars0.githubusercontent.com/u/15315098?v=4" width="100px;"/><br /><sub><b>João Marques</b></sub>](https://github.com/tigermarques)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=tigermarques "Code") [📖](https://github.com/jfmengels/all-contributors-cli/commits?author=tigermarques "Documentation") [🤔](#ideas-tigermarques "Ideas, Planning, & Feedback") |
|
| [<img src="https://avatars2.githubusercontent.com/u/17708702?v=4" width="100px;"/><br /><sub><b>Md Zubair Ahmed</b></sub>](https://in.linkedin.com/in/mzubairahmed)<br />[📖](https://github.com/jfmengels/all-contributors-cli/commits?author=M-ZubairAhmed "Documentation") [🐛](https://github.com/jfmengels/all-contributors-cli/issues?q=author%3AM-ZubairAhmed "Bug reports") [💻](https://github.com/jfmengels/all-contributors-cli/commits?author=M-ZubairAhmed "Code") [⚠️](https://github.com/jfmengels/all-contributors-cli/commits?author=M-ZubairAhmed "Tests") | [<img src="https://avatars3.githubusercontent.com/u/6177621?v=4" width="100px;"/><br /><sub><b>Divjot Singh</b></sub>](http://bogas04.github.io)<br />[📖](https://github.com/jfmengels/all-contributors-cli/commits?author=bogas04 "Documentation") | [<img src="https://avatars0.githubusercontent.com/u/15315098?v=4" width="100px;"/><br /><sub><b>João Marques</b></sub>](https://github.com/tigermarques)<br />[💻](https://github.com/jfmengels/all-contributors-cli/commits?author=tigermarques "Code") [📖](https://github.com/jfmengels/all-contributors-cli/commits?author=tigermarques "Documentation") [🤔](#ideas-tigermarques "Ideas, Planning, & Feedback") |
|
||||||
<!-- ALL-CONTRIBUTORS-LIST:END -->
|
<!-- ALL-CONTRIBUTORS-LIST:END -->
|
||||||
|
|
||||||
This project follows the
|
This project follows the
|
||||||
|
|
59
src/contributors/__tests__/prompt.js
Normal file
59
src/contributors/__tests__/prompt.js
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
import prompt from '../prompt'
|
||||||
|
|
||||||
|
function fixtures() {
|
||||||
|
const options = {
|
||||||
|
contributors: [
|
||||||
|
{
|
||||||
|
login: 'jfmengels',
|
||||||
|
name: 'Jeroen Engels',
|
||||||
|
avatar_url: 'https://avatars.githubusercontent.com/u/3869412?v=3',
|
||||||
|
profile: 'https://github.com/jfmengels',
|
||||||
|
contributions: [],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
login: 'kentcdodds',
|
||||||
|
name: 'Kent C. Dodds',
|
||||||
|
avatar_url: 'https://avatars.githubusercontent.com/u/1500684?v=3',
|
||||||
|
profile: 'http://kentcdodds.com/',
|
||||||
|
contributions: [],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
login: 'jccguimaraes',
|
||||||
|
name: 'João Guimarães',
|
||||||
|
avatar_url: 'https://avatars.githubusercontent.com/u/14871650?v=3',
|
||||||
|
profile: 'https://github.com/jccguimaraes',
|
||||||
|
contributions: [],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
}
|
||||||
|
return options
|
||||||
|
}
|
||||||
|
|
||||||
|
test(`should throw error if all contribution types are invalid`, () => {
|
||||||
|
const options = fixtures()
|
||||||
|
const username = 'userName'
|
||||||
|
const contributions = 'invalidContributionType1,invalidContributionType2'
|
||||||
|
expect(() => prompt(options, username, contributions)).toThrow(
|
||||||
|
'invalidContributionType1,invalidContributionType2 is/are invalid contribution type(s)',
|
||||||
|
)
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`should not throw error if atleast one of the contribution types is valid`, () => {
|
||||||
|
const options = fixtures()
|
||||||
|
const username = 'userName'
|
||||||
|
const contributions = 'wrongContributionType,code'
|
||||||
|
return prompt(options, username, contributions).then(answers => {
|
||||||
|
expect(answers).toEqual({username: 'userName', contributions: ['code']})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
test(`should filter valid contribution types from user inserted types`, () => {
|
||||||
|
const options = fixtures()
|
||||||
|
const username = 'userName'
|
||||||
|
const contributions =
|
||||||
|
'invalidContributionType1,code,invalidContributionType2,bug'
|
||||||
|
return prompt(options, username, contributions).then(answers => {
|
||||||
|
expect(answers.contributions.length).toBe(2)
|
||||||
|
expect(answers.contributions).toEqual(['code', 'bug'])
|
||||||
|
})
|
||||||
|
})
|
|
@ -22,7 +22,9 @@ function getQuestions(options, username, contributions) {
|
||||||
{
|
{
|
||||||
type: 'input',
|
type: 'input',
|
||||||
name: 'username',
|
name: 'username',
|
||||||
message: `What is the contributor's ${repo.getTypeName(options.repoType)} username?`,
|
message: `What is the contributor's ${repo.getTypeName(
|
||||||
|
options.repoType,
|
||||||
|
)} username?`,
|
||||||
when: !username,
|
when: !username,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -69,10 +71,34 @@ function getQuestions(options, username, contributions) {
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getValidUserContributions(options, contributions) {
|
||||||
|
const validContributionTypes = util.contributionTypes(options)
|
||||||
|
const userContributions = contributions && contributions.split(',')
|
||||||
|
|
||||||
|
const validUserContributions = _.filter(
|
||||||
|
userContribution => validContributionTypes[userContribution] !== undefined,
|
||||||
|
)(userContributions)
|
||||||
|
|
||||||
|
const invalidUserContributions = _.filter(
|
||||||
|
userContribution => validContributionTypes[userContribution] === undefined,
|
||||||
|
)(userContributions)
|
||||||
|
|
||||||
|
if (_.isEmpty(validUserContributions)) {
|
||||||
|
throw new Error(
|
||||||
|
`${invalidUserContributions.toString()} is/are invalid contribution type(s)`,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
return validUserContributions
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = function prompt(options, username, contributions) {
|
module.exports = function prompt(options, username, contributions) {
|
||||||
const defaults = {
|
const defaults = {
|
||||||
username,
|
username,
|
||||||
contributions: contributions && contributions.split(','),
|
contributions:
|
||||||
|
username === undefined && contributions === undefined
|
||||||
|
? []
|
||||||
|
: getValidUserContributions(options, contributions),
|
||||||
}
|
}
|
||||||
const questions = getQuestions(options, username, contributions)
|
const questions = getQuestions(options, username, contributions)
|
||||||
return inquirer.prompt(questions).then(_.assign(defaults))
|
return inquirer.prompt(questions).then(_.assign(defaults))
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
const _ = require('lodash/fp')
|
const _ = require('lodash/fp')
|
||||||
|
|
||||||
const util = require('../util')
|
const util = require('../util')
|
||||||
|
|
||||||
const linkTemplate = _.template(
|
const linkTemplate = _.template(
|
||||||
|
|
Loading…
Reference in a new issue