mirror of
https://github.com/all-contributors/cli.git
synced 2025-01-10 05:56:29 +00:00
Add ability to update existing contributors
This commit is contained in:
parent
5101e9085c
commit
01a6837485
3 changed files with 85 additions and 27 deletions
|
@ -1,5 +1,7 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
|
var uniq = require('lodash.uniq');
|
||||||
|
var values = require('lodash.values');
|
||||||
var template = require('lodash.template');
|
var template = require('lodash.template');
|
||||||
var findIndex = require('lodash.findindex');
|
var findIndex = require('lodash.findindex');
|
||||||
|
|
||||||
|
@ -16,12 +18,13 @@ var defaultTemplate =
|
||||||
'<br /><%= user.name %>](<%= user.html_url %>)' +
|
'<br /><%= user.name %>](<%= user.html_url %>)' +
|
||||||
' | [<%= contributions %>](https://github.com/<%= options.projectOwner %>/<%= options.projectName %>/commits?author=<%= user.login %>)';
|
' | [<%= contributions %>](https://github.com/<%= options.projectOwner %>/<%= options.projectName %>/commits?author=<%= user.login %>)';
|
||||||
|
|
||||||
function contributorEntry(options, user) {
|
function contributorEntry(options, user, existingContributions) {
|
||||||
var contributions = options.contributions
|
var contributions = uniq((existingContributions || []).concat(
|
||||||
|
options.contributions
|
||||||
.map(function(contribution) {
|
.map(function(contribution) {
|
||||||
return options.emoji[contribution];
|
return options.emoji[contribution];
|
||||||
})
|
})
|
||||||
.join('');
|
)).join('');
|
||||||
|
|
||||||
var contributionTemplate = template(options.template || defaultTemplate);
|
var contributionTemplate = template(options.template || defaultTemplate);
|
||||||
|
|
||||||
|
@ -32,21 +35,43 @@ function contributorEntry(options, user) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = function addContributor(options, user, fileContent) {
|
function parseContributionTypes(options, line) {
|
||||||
var contributor = contributorEntry(options, user);
|
return values(options.emoji)
|
||||||
|
.filter(function findExistingContribution(type) {
|
||||||
|
return line.indexOf(type) !== -1;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function upsertContributor(options, user, existingContributors) {
|
||||||
|
var contributor = contributorEntry(options, user);
|
||||||
|
var existingContributorIndex = findIndex(existingContributors, function(cont) {
|
||||||
|
return cont.indexOf(user.login) !== 1 && cont.indexOf(user.name) !== -1;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (existingContributorIndex === -1) {
|
||||||
|
return [].concat(existingContributors, contributor);
|
||||||
|
}
|
||||||
|
|
||||||
|
var contributionTypes = parseContributionTypes(options, existingContributors[existingContributorIndex]);
|
||||||
|
return [].concat(
|
||||||
|
existingContributors.slice(0, existingContributorIndex),
|
||||||
|
contributorEntry(options, user, contributionTypes),
|
||||||
|
existingContributors.slice(existingContributorIndex + 1)
|
||||||
|
).join('\n')
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = function addContributor(options, user, fileContent) {
|
||||||
var lines = fileContent.split('\n');
|
var lines = fileContent.split('\n');
|
||||||
var contributorListStart = findIndex(lines, function(line) {
|
var contributorListStart = findIndex(lines, function(line) {
|
||||||
return line.indexOf(':---: | :---:') !== -1;
|
return line.indexOf(':---: | :---:') !== -1;
|
||||||
});
|
});
|
||||||
var contributors = [].concat(
|
|
||||||
listAllContributors(contributorListStart + 1, lines),
|
var existingContributors = listAllContributors(contributorListStart + 1, lines);
|
||||||
contributor
|
var contributors = upsertContributor(options, user, existingContributors);
|
||||||
);
|
|
||||||
|
|
||||||
return [].concat(
|
return [].concat(
|
||||||
lines.slice(0, contributorListStart + 1),
|
lines.slice(0, contributorListStart + 1),
|
||||||
contributors,
|
contributors,
|
||||||
lines.slice(contributorListStart + contributors.length)
|
lines.slice(contributorListStart + existingContributors.length + 1)
|
||||||
).join('\n')
|
).join('\n')
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,13 +21,20 @@ function fixtures() {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const user = {
|
const jfmengelsUser = {
|
||||||
login: 'jfmengels',
|
login: 'jfmengels',
|
||||||
name: 'Jeroen Engels',
|
name: 'Jeroen Engels',
|
||||||
html_url: 'https://github.com/jfmengels',
|
html_url: 'https://github.com/jfmengels',
|
||||||
avatar_url: 'https://avatars.githubusercontent.com/u/3869412?v=3'
|
avatar_url: 'https://avatars.githubusercontent.com/u/3869412?v=3'
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const kentcdoddsUser = {
|
||||||
|
login: 'kentcdodds',
|
||||||
|
name: 'Kent C. Dodds',
|
||||||
|
html_url: 'https://github.com/kentcdodds',
|
||||||
|
avatar_url: 'https://avatars.githubusercontent.com/u/1500684?v=3'
|
||||||
|
};
|
||||||
|
|
||||||
const content = `
|
const content = `
|
||||||
# project
|
# project
|
||||||
|
|
||||||
|
@ -36,16 +43,18 @@ Description
|
||||||
## Contributors
|
## Contributors
|
||||||
These people contributed to the project:
|
These people contributed to the project:
|
||||||
:---: | :---:
|
:---: | :---:
|
||||||
[![Kent C. Dodds](https://avatars1.githubusercontent.com/u/1500684?s=130)<br />Kent C. Dodds](http://kentcdodds.com) | [📖](https://github.com/kentcdodds/all-contributors/commits?author=kentcdodds)
|
[![Kent C. Dodds](https://avatars.githubusercontent.com/u/1500684?v=3&s=100)<br />Kent C. Dodds](https://github.com/kentcdodds) | [:doc:](https://github.com/kentcdodds/all-contributors/commits?author=kentcdodds)
|
||||||
[![Divjot Singh](https://avatars1.githubusercontent.com/u/6177621?s=130)<br />Divjot Singh](http://bogas04.github.io) | [📖](https://github.com/kentcdodds/all-contributors/commits?author=bogas04)
|
[![Divjot Singh](https://avatars1.githubusercontent.com/u/6177621?s=130)<br />Divjot Singh](http://bogas04.github.io) | [:doc:](https://github.com/kentcdodds/all-contributors/commits?author=bogas04)
|
||||||
|
|
||||||
Thanks a lot guys!
|
Thanks a lot guys!
|
||||||
`;
|
`;
|
||||||
return {options, user, content};
|
|
||||||
|
return {options, jfmengelsUser, kentcdoddsUser, content};
|
||||||
}
|
}
|
||||||
|
|
||||||
test('should add a new contributor to the end of the list', t => {
|
test('should add a new contributor to the end of the list', t => {
|
||||||
const {options, user, content} = fixtures();
|
t.pass(1);
|
||||||
|
const {options, jfmengelsUser, content} = fixtures();
|
||||||
const expected = `
|
const expected = `
|
||||||
# project
|
# project
|
||||||
|
|
||||||
|
@ -54,32 +63,54 @@ Description
|
||||||
## Contributors
|
## Contributors
|
||||||
These people contributed to the project:
|
These people contributed to the project:
|
||||||
:---: | :---:
|
:---: | :---:
|
||||||
[![Kent C. Dodds](https://avatars1.githubusercontent.com/u/1500684?s=130)<br />Kent C. Dodds](http://kentcdodds.com) | [📖](https://github.com/kentcdodds/all-contributors/commits?author=kentcdodds)
|
[![Kent C. Dodds](https://avatars.githubusercontent.com/u/1500684?v=3&s=100)<br />Kent C. Dodds](https://github.com/kentcdodds) | [:doc:](https://github.com/kentcdodds/all-contributors/commits?author=kentcdodds)
|
||||||
[![Divjot Singh](https://avatars1.githubusercontent.com/u/6177621?s=130)<br />Divjot Singh](http://bogas04.github.io) | [📖](https://github.com/kentcdodds/all-contributors/commits?author=bogas04)
|
[![Divjot Singh](https://avatars1.githubusercontent.com/u/6177621?s=130)<br />Divjot Singh](http://bogas04.github.io) | [:doc:](https://github.com/kentcdodds/all-contributors/commits?author=bogas04)
|
||||||
[![Jeroen Engels](https://avatars.githubusercontent.com/u/3869412?v=3&s=100)<br />Jeroen Engels](https://github.com/jfmengels) | [:doc:](https://github.com/kentcdodds/all-contributors/commits?author=jfmengels)
|
[![Jeroen Engels](https://avatars.githubusercontent.com/u/3869412?v=3&s=100)<br />Jeroen Engels](https://github.com/jfmengels) | [:doc:](https://github.com/kentcdodds/all-contributors/commits?author=jfmengels)
|
||||||
|
|
||||||
Thanks a lot guys!
|
Thanks a lot guys!
|
||||||
`;
|
`;
|
||||||
|
|
||||||
t.is(addContributor(options, user, content), expected);
|
t.is(addContributor(options, jfmengelsUser, content), expected);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should be able to inject several contributions', t => {
|
test('should be able to inject several contributions', t => {
|
||||||
const {options, user, content} = fixtures();
|
t.pass(1);
|
||||||
|
const {options, jfmengelsUser, content} = fixtures();
|
||||||
options.contributions = ['doc', 'code'];
|
options.contributions = ['doc', 'code'];
|
||||||
const expected = '[![Jeroen Engels](https://avatars.githubusercontent.com/u/3869412?v=3&s=100)<br />Jeroen Engels](https://github.com/jfmengels) | [:doc::code:](https://github.com/kentcdodds/all-contributors/commits?author=jfmengels)';
|
const expected = '[![Jeroen Engels](https://avatars.githubusercontent.com/u/3869412?v=3&s=100)<br />Jeroen Engels](https://github.com/jfmengels) | [:doc::code:](https://github.com/kentcdodds/all-contributors/commits?author=jfmengels)';
|
||||||
|
|
||||||
const result = addContributor(options, user, content);
|
const result = addContributor(options, jfmengelsUser, content);
|
||||||
|
|
||||||
t.is(getUserLine(result, user), expected);
|
t.is(getUserLine(result, jfmengelsUser), expected);
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should be able to specify a new template in options', t => {
|
test('should be able to specify a new template in options', t => {
|
||||||
const {options, user, content} = fixtures();
|
t.pass(1);
|
||||||
|
const {options, jfmengelsUser, content} = fixtures();
|
||||||
options.template = '<%= user.login %> made awesome contributions!';
|
options.template = '<%= user.login %> made awesome contributions!';
|
||||||
const expected = 'jfmengels made awesome contributions!';
|
const expected = 'jfmengels made awesome contributions!';
|
||||||
|
|
||||||
const result = addContributor(options, user, content);
|
const result = addContributor(options, jfmengelsUser, content);
|
||||||
|
|
||||||
t.is(getUserLine(result, user), expected);
|
t.is(getUserLine(result, jfmengelsUser), expected);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should not modify content when adding an existing contributor that has the given contribution types', t => {
|
||||||
|
t.pass(1);
|
||||||
|
const {options, kentcdoddsUser, content} = fixtures();
|
||||||
|
const expected = content;
|
||||||
|
|
||||||
|
const result = addContributor(options, kentcdoddsUser, content);
|
||||||
|
t.is(result, expected);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('should add new contributions types to an existing contributor', t => {
|
||||||
|
t.pass(1);
|
||||||
|
const {options, kentcdoddsUser, content} = fixtures();
|
||||||
|
options.contributions = ['doc', 'code'];
|
||||||
|
const expected = '[![Kent C. Dodds](https://avatars.githubusercontent.com/u/1500684?v=3&s=100)<br />Kent C. Dodds](https://github.com/kentcdodds) | [:doc::code:](https://github.com/kentcdodds/all-contributors/commits?author=kentcdodds)';
|
||||||
|
|
||||||
|
const result = addContributor(options, kentcdoddsUser, content);
|
||||||
|
|
||||||
|
t.is(getUserLine(result, kentcdoddsUser), expected);
|
||||||
});
|
});
|
||||||
|
|
|
@ -25,6 +25,8 @@
|
||||||
"lodash.assign": "^4.0.4",
|
"lodash.assign": "^4.0.4",
|
||||||
"lodash.findindex": "^4.2.0",
|
"lodash.findindex": "^4.2.0",
|
||||||
"lodash.template": "^4.2.1",
|
"lodash.template": "^4.2.1",
|
||||||
|
"lodash.uniq": "^4.2.0",
|
||||||
|
"lodash.values": "^4.1.0",
|
||||||
"request": "^2.69.0",
|
"request": "^2.69.0",
|
||||||
"yargs": "^4.2.0"
|
"yargs": "^4.2.0"
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in a new issue