From d517440203cca343e3d3c8fcae118bf06d0d3225 Mon Sep 17 00:00:00 2001 From: Darek Kay Date: Sun, 4 Oct 2020 22:44:02 +0200 Subject: [PATCH] feat: display a meaningful error when the config file is missing (#288) * feat: display a meaningful error when the config file is missing ## What When you try to add a user with `.all-contributorsrc` missing, you will get a cryptic error message (see also all-contributors/all-contributors#378): ``` $ all-contributors add darekkay maintenance Cannot read property 'then' of null ``` This PR displays a meaningful error message in this case. ## Why So users know what's causing the problem. ## How Before a contribution is being added, the script checks whether the config file exists. If it doesn't, an error message is being displayed: ``` $ all-contributors add darekkay maintenance Configuration file not found: C:\projects\test\.all-contributorsrc ``` * docs: add darekkay as a contributor * refactor: fixed typos * docs(readme): table rectification Co-authored-by: Maximilian Berkmann --- .all-contributorsrc | 9 +++++++++ README.md | 3 ++- src/cli.js | 1 + src/generate/__tests__/format-contributor.js | 2 +- src/repo/__tests__/github.js | 4 ++-- 5 files changed, 15 insertions(+), 4 deletions(-) diff --git a/.all-contributorsrc b/.all-contributorsrc index da519c40..b501ffe0 100644 --- a/.all-contributorsrc +++ b/.all-contributorsrc @@ -530,6 +530,15 @@ "code", "test" ] + }, + { + "login": "darekkay", + "name": "Darek Kay", + "avatar_url": "https://avatars0.githubusercontent.com/u/3101914?v=4", + "profile": "https://darekkay.com/", + "contributions": [ + "code" + ] } ], "skipCi": true diff --git a/README.md b/README.md index d5171161..344349d5 100644 --- a/README.md +++ b/README.md @@ -148,8 +148,9 @@ Thanks goes to these wonderful people
Markus LΓΆning

πŸ’»
David Anson

πŸ›
Jeroen Claassens

πŸ’» -
Erek Speed

πŸ’»
Shai Reznik

πŸ› πŸ’» ⚠️ +
Darek Kay

πŸ’» +
Erek Speed

πŸ’» diff --git a/src/cli.js b/src/cli.js index 91212b1d..4d356819 100755 --- a/src/cli.js +++ b/src/cli.js @@ -66,6 +66,7 @@ function startGeneration(argv) { } function addContribution(argv) { + util.configFile.readConfig(argv.config) // ensure the config file exists const username = argv._[1] === undefined ? undefined : String(argv._[1]) const contributions = argv._[2] // Add or update contributor in the config file diff --git a/src/generate/__tests__/format-contributor.js b/src/generate/__tests__/format-contributor.js index 013318a7..bb3451ec 100644 --- a/src/generate/__tests__/format-contributor.js +++ b/src/generate/__tests__/format-contributor.js @@ -68,7 +68,7 @@ test('format contributor with pipes in their name', () => { expect(formatContributor(options, contributor)).toBe(expected) }) -test('format contributor with no github account', () => { +test('format contributor with no GitHub account', () => { const contributor = contributors.nologin const {options} = fixtures() diff --git a/src/repo/__tests__/github.js b/src/repo/__tests__/github.js index 7952d32a..ad9de9c7 100644 --- a/src/repo/__tests__/github.js +++ b/src/repo/__tests__/github.js @@ -96,7 +96,7 @@ test('Throw error when missing enterprise authentication', async () => { ) }) -test('handle API rate github errors', async () => { +test('handle API rate GitHub errors', async () => { const githubErrorMessage = "API rate limit exceeded for 0.0.0.0. (But here's the good news: Authenticated requests get a higher rate limit. Check out the documentation for more details." nock('https://api.github.com').get('/users/nodisplayname').reply(200, { @@ -177,7 +177,7 @@ test('append http when no absolute link is provided', async () => { expect(info.profile).toBe('http://www.github.com/nodisplayname') }) -test('retrieve user from a different github registry', async () => { +test('retrieve user from a different GitHub registry', async () => { nock('http://github.myhost.com:3000/api/v3') .get('/users/nodisplayname') .reply(200, {