fix: error out when projectOwner & projectName is not set in .all-contributorsrc file. (#80)

* error message when no project name and project owner is added in the init command

* moved error message away from init prompt

* 1. placed json parse in try catch
2. added check for owner and name in getcontributionsfromgithub before constructing url

* added check before config file is written

* changes as per https://github.com/jfmengels/all-contributors-cli/pull/80#pullrequestreview-85678121

* uncommented code

* tests added

* Added myself to contributors table

* test inside utils were moved to github in master branch

* changes to validation check, instead of checking for empty string to null obj value

* typo fixed

* unnecisary check.js file removed
This commit is contained in:
Md Zubair Ahmed 2018-05-30 01:56:25 +05:30 committed by Kent C. Dodds
parent 1562a379db
commit c4a0484759
3 changed files with 40 additions and 4 deletions

View file

@ -180,7 +180,9 @@
"profile": "https://in.linkedin.com/in/mzubairahmed", "profile": "https://in.linkedin.com/in/mzubairahmed",
"contributions": [ "contributions": [
"doc", "doc",
"bug" "bug",
"code",
"test"
] ]
}, },
{ {

View file

@ -1,15 +1,43 @@
import configFile from '../config-file' import configFile from '../config-file'
const absentFile = './abc' const absentFile = './abc'
const expected = `Configuration file not found: ${absentFile}` const absentConfileFileExpected = `Configuration file not found: ${absentFile}`
const incompleteConfigFilePath = './.all-contributorsrc'
const NoOwnerConfigFile = {
projectOwner: '',
projectName: 'all-contributors-cli',
imageSize: 100,
commit: false,
contributorsPerLine: 6,
contributors: [],
}
const NoNameConfigFile = {
projectOwner: 'jfmengels',
projectName: '',
imageSize: 100,
commit: false,
contributorsPerLine: 6,
contributors: [],
}
test('Reading an absent configuration file throws a helpful error', () => { test('Reading an absent configuration file throws a helpful error', () => {
expect(() => configFile.readConfig(absentFile)).toThrowError(expected) expect(() => configFile.readConfig(absentFile)).toThrowError(
absentConfileFileExpected,
)
}) })
test('Writing contributors in an absent configuration file throws a helpful error', async () => { test('Writing contributors in an absent configuration file throws a helpful error', async () => {
const resolvedError = await configFile const resolvedError = await configFile
.writeContributors(absentFile, []) .writeContributors(absentFile, [])
.catch(e => e) .catch(e => e)
expect(resolvedError.message).toBe(expected) expect(resolvedError.message).toBe(absentConfileFileExpected)
})
test('Should throw error and not allow editing config file if project name or owner is not set', () => {
expect(() =>
configFile.writeConfig(incompleteConfigFilePath, NoOwnerConfigFile),
).toThrow(`Error! Project owner is not set in ${incompleteConfigFilePath}`)
expect(() =>
configFile.writeConfig(incompleteConfigFilePath, NoNameConfigFile),
).toThrow(`Error! Project name is not set in ${incompleteConfigFilePath}`)
}) })

View file

@ -18,6 +18,12 @@ function readConfig(configPath) {
} }
function writeConfig(configPath, content) { function writeConfig(configPath, content) {
if (!content.projectOwner) {
throw new Error(`Error! Project owner is not set in ${configPath}`)
}
if (!content.projectName) {
throw new Error(`Error! Project name is not set in ${configPath}`)
}
return pify(fs.writeFile)(configPath, `${JSON.stringify(content, null, 2)}\n`) return pify(fs.writeFile)(configPath, `${JSON.stringify(content, null, 2)}\n`)
} }