-
Notifications
You must be signed in to change notification settings - Fork 86
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Browse files
Browse the repository at this point in the history
- Add functionality to ignore files based on provided regular expressions - Support writeIndex and writeIndexCli - in index.js config must be specified as below // @create-index {"ignore":["/foo.js"]}
- Loading branch information
Showing
20 changed files
with
256 additions
and
38 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
// eslint-disable-next-line | ||
export const CREATE_INDEX_PATTERN = /(?:^|[\n\r]+)\/\/ @create-index\s?({.*})?[\n\r]+/; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
import fs from 'fs'; | ||
import path from 'path'; | ||
|
||
export default (directoryPath) => { | ||
const indexPath = path.resolve(directoryPath, 'index.js'); | ||
|
||
try { | ||
fs.statSync(indexPath); | ||
|
||
return true; | ||
} catch (error) { | ||
return false; | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
import fs from 'fs'; | ||
import path from 'path'; | ||
import hasIndex from './hasIndex'; | ||
import {CREATE_INDEX_PATTERN} from './constants'; | ||
|
||
export default (directoryPath) => { | ||
if (!hasIndex(directoryPath)) { | ||
return {}; | ||
} | ||
|
||
const indexPath = path.resolve(directoryPath, 'index.js'); | ||
const indexContents = fs.readFileSync(indexPath, 'utf-8'); | ||
const found = indexContents.match(CREATE_INDEX_PATTERN); | ||
const configLine = typeof found[1] === 'string' ? found[1].trim() : ''; | ||
|
||
if (configLine.length === 0) { | ||
return {}; | ||
} | ||
|
||
let config; | ||
|
||
try { | ||
config = JSON.parse(configLine); | ||
} catch (error) { | ||
throw new Error( | ||
'"' + indexPath + '" contains invalid configuration object.\n' + | ||
'Configuration object must be a valid JSON.' | ||
); | ||
} | ||
|
||
return config; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
// @create-index {"ignore": ["/foo.js$/"]} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
// @create-index {ignore: 'foo'} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
// @create-index |
Empty file.
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,4 @@ | ||
// @create-index {"ignore":["/bar.js$/"]} | ||
|
||
export { default as foo } from './foo.js'; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
import path from 'path'; | ||
import { | ||
expect | ||
} from 'chai'; | ||
import readIndexConfig from '../src/utilities/readIndexConfig'; | ||
|
||
const fixtures = { | ||
noIndex: path.resolve(__dirname, 'fixtures/read-index-config/no-index'), | ||
withConfig: path.resolve(__dirname, 'fixtures/read-index-config/with-config'), | ||
withInvalidConfig: path.resolve(__dirname, 'fixtures/read-index-config/with-invalid-config'), | ||
withoutConfig: path.resolve(__dirname, 'fixtures/read-index-config/without-config') | ||
}; | ||
|
||
const expectedValues = { | ||
noIndex: {}, | ||
withConfig: { | ||
ignore: ['/foo.js$/'] | ||
}, | ||
withoutConfig: {} | ||
}; | ||
|
||
describe('readIndexConfig()', () => { | ||
context('When valid config is defined', () => { | ||
it('reads config object', () => { | ||
const config = readIndexConfig(fixtures.withConfig); | ||
|
||
expect(config).to.deep.equal(expectedValues.withConfig); | ||
}); | ||
}); | ||
|
||
context('When invalid config is defined', () => { | ||
it('should throw an error', () => { | ||
const wrappedReadIndexConfig = () => { | ||
readIndexConfig(fixtures.withInvalidConfig); | ||
}; | ||
|
||
expect(wrappedReadIndexConfig).to.throw(/Configuration object must be a valid JSON./); | ||
}); | ||
}); | ||
|
||
context('When config is NOT defined', () => { | ||
it('returns an empty object', () => { | ||
const config = readIndexConfig(fixtures.withoutConfig); | ||
|
||
expect(config).to.deep.equal(expectedValues.withoutConfig); | ||
}); | ||
}); | ||
|
||
context('When index file doesn\'t exist', () => { | ||
it('returns an empty object', () => { | ||
const config = readIndexConfig(fixtures.withoutConfig); | ||
|
||
expect(config).to.deep.equal(expectedValues.noIndex); | ||
}); | ||
}); | ||
}); |
Oops, something went wrong.