-
Notifications
You must be signed in to change notification settings - Fork 2
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: first pass at @nodevu/opt (#79)
Signed-off-by: Tierney Cyren <hello@bnb.im>
- Loading branch information
Showing
9 changed files
with
280 additions
and
1 deletion.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
name: "Test Suite: Linter (@nodevu/opt)" | ||
|
||
on: | ||
push: | ||
pull_request: | ||
paths: | ||
- 'opt/**' | ||
branches: | ||
- main | ||
workflow_dispatch: | ||
workflow_call: | ||
|
||
jobs: | ||
tests: | ||
if: github.repository == 'cutenode/nodevu' | ||
runs-on: ubuntu-latest | ||
steps: | ||
- name: Checkout the repository | ||
uses: actions/checkout@v4 | ||
- name: Setup Node.js | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version: current | ||
- name: Run npm install -w opt | ||
run: npm install -w opt | ||
- name: Run npm run lint -w opt | ||
run: npm run lint -w opt |
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,31 @@ | ||
name: "Test Suite: @nodevu/opt" | ||
|
||
on: | ||
pull_request: | ||
paths: | ||
- 'opt/**' | ||
branches: | ||
- main | ||
workflow_dispatch: | ||
workflow_call: | ||
|
||
jobs: | ||
tests: | ||
if: github.repository == 'cutenode/nodevu' | ||
runs-on: ubuntu-latest | ||
strategy: | ||
matrix: | ||
node-version: [current, lts/*, lts/-1] | ||
steps: | ||
- name: Checkout the repository | ||
uses: actions/checkout@v4 | ||
- name: Setup Node.js ${{ matrix.node-version }} | ||
uses: actions/setup-node@v4 | ||
with: | ||
node-version: ${{ matrix.node-version }} | ||
- name: Install most recent npm | ||
run: npm install -g npm | ||
- name: Run npm install -w opt | ||
run: npm install -w opt | ||
- name: Run npm test -w opt | ||
run: npm test -w opt |
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,21 @@ | ||
MIT License Copyright (c) 2022 Tierney Cyren | ||
|
||
Permission is hereby granted, free | ||
of charge, to any person obtaining a copy of this software and associated | ||
documentation files (the "Software"), to deal in the Software without | ||
restriction, including without limitation the rights to use, copy, modify, merge, | ||
publish, distribute, sublicense, and/or sell copies of the Software, and to | ||
permit persons to whom the Software is furnished to do so, subject to the | ||
following conditions: | ||
|
||
The above copyright notice and this permission notice | ||
(including the next paragraph) shall be included in all copies or substantial | ||
portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF | ||
ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF | ||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO | ||
EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR | ||
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | ||
FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||
THE SOFTWARE. |
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,33 @@ | ||
# @nodevu/optionsparser | ||
|
||
A tool that fetches the /dist/index.json file from the Node.js website. | ||
|
||
## Usage | ||
|
||
```js | ||
const opt = require('@nodevu/opt') | ||
|
||
const parsedOptions = await opt(); // returns a default set of options | ||
``` | ||
|
||
```js | ||
const opt = require('@nodevu/opt') | ||
|
||
const options = { | ||
fetch: globalThis.fetch, // use your own fetch if you want! | ||
urls: { | ||
index: 'https://nodejs.org/dist/index.json', | ||
}, | ||
}; | ||
|
||
const parsedOptions = await parser(options); // returns a huge JSON object | ||
``` | ||
|
||
## API | ||
- `opt(options)` | ||
- `options` (`Object`, optional): Options object. | ||
- `fetch` (`Function`, optional): Fetch function. Default: `globalThis.fetch`. | ||
- `urls` (`Object`, optional): URLs object. | ||
- `index` (`String`, optional): URL to fetch the index.json file from. Default: `'https://nodejs.org/dist/index.json'`. | ||
- `schedule` (`String`, optional): URL to fetch the schedule.json file from. Default: `'https://raw.githubusercontent.com/nodejs/Release/master/schedule.json'`. | ||
- Returns: `Object` with a set of default options in the structure required by `@nodevu/core`. |
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,17 @@ | ||
{ | ||
"$schema": "https://biomejs.dev/schemas/1.6.1/schema.json", | ||
"organizeImports": { | ||
"enabled": true | ||
}, | ||
"javascript": { | ||
"formatter": { | ||
"quoteStyle": "single" | ||
} | ||
}, | ||
"linter": { | ||
"enabled": true, | ||
"rules": { | ||
"recommended": true | ||
} | ||
} | ||
} |
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,44 @@ | ||
const { DateTime } = require('luxon'); | ||
|
||
// this function allows us to parse user-passed options. | ||
// | ||
// this is particularly useful for tests so we can reduce variables | ||
// and ensure that our test suite is able to be consistent. | ||
function opt(inputOptions) { | ||
// set up our defaults | ||
const result = { | ||
fetch: globalThis.fetch, | ||
now: DateTime.now(), | ||
urls: { | ||
index: 'https://nodejs.org/dist/index.json', | ||
schedule: | ||
'https://raw.githubusercontent.com/nodejs/Release/master/schedule.json', | ||
}, | ||
}; | ||
|
||
if (typeof inputOptions === 'undefined') { | ||
return result; | ||
} | ||
|
||
// allow the end-user to replace our fetch implementation with another one they prefer. | ||
if (inputOptions?.fetch) { | ||
result.fetch = inputOptions.fetch; | ||
} | ||
|
||
// allow the end-user to provide a custom DateTime. This is particularly useful for tests. | ||
if (inputOptions?.now) { | ||
result.now = inputOptions.now; | ||
} | ||
|
||
if (inputOptions?.urls?.index) { | ||
result.urls.index = inputOptions.urls.index; | ||
} | ||
|
||
if (inputOptions?.urls?.schedule) { | ||
result.urls.schedule = inputOptions.urls.schedule; | ||
} | ||
|
||
return result; | ||
} | ||
|
||
module.exports = opt; |
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 @@ | ||
{ | ||
"name": "@nodevu/opt", | ||
"version": "0.1.0", | ||
"description": "internal options parser for @nodevu packages.", | ||
"main": "index.js", | ||
"files": ["index.js", "LICENSE"], | ||
"scripts": { | ||
"lint": "biome check ./", | ||
"lint:write": "biome check ./ --write", | ||
"test": "node --test", | ||
"coverage": "c8 node --test", | ||
"updates:check": "npx npm-check-updates", | ||
"updates:update": "npx npm-check-updates -u" | ||
}, | ||
"repository": { | ||
"type": "git", | ||
"url": "git+https://github.com/cutenode/nodevu.git" | ||
}, | ||
"keywords": ["node.js", "versions"], | ||
"author": "Tierney Cyren <hello@bnb.im> (https://bnb.im/)", | ||
"license": "MIT", | ||
"bugs": { | ||
"url": "https://github.com/cutenode/nodevu/issues" | ||
}, | ||
"homepage": "https://github.com/cutenode/nodevu#readme", | ||
"devDependencies": { | ||
"@biomejs/biome": "1.9.4", | ||
"c8": "^10.1.2", | ||
"luxon": "^3.5.0", | ||
"undici": "^6.20.1" | ||
} | ||
} |
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,73 @@ | ||
const { deepStrictEqual } = require('node:assert'); | ||
const { describe, it } = require('node:test'); | ||
const { fetch: undiciFetch } = require('undici'); | ||
const { DateTime } = require('luxon'); | ||
const opt = require('../index'); | ||
|
||
describe('the parseOptions module should return all correct defaults', async () => { | ||
it('should return the default date', async () => { | ||
const now = DateTime.now(); | ||
const defaultParsedOptions = opt(); | ||
deepStrictEqual(defaultParsedOptions.now.day, now.day); | ||
deepStrictEqual(defaultParsedOptions.now.hour, now.hour); | ||
deepStrictEqual(defaultParsedOptions.now.minute, now.minute); | ||
deepStrictEqual(defaultParsedOptions.now.month, now.month); | ||
}); | ||
|
||
it('should return the default date, when options is an empty object', async () => { | ||
const now = DateTime.now(); | ||
const defaultParsedOptions = opt({}); | ||
deepStrictEqual(defaultParsedOptions.now.day, now.day); | ||
deepStrictEqual(defaultParsedOptions.now.hour, now.hour); | ||
deepStrictEqual(defaultParsedOptions.now.minute, now.minute); | ||
deepStrictEqual(defaultParsedOptions.now.month, now.month); | ||
}); | ||
|
||
it('defaultParsedOptions.fetch should be globalThis.fetch when no options are passed', async () => { | ||
const defaultParsedOptions = opt(); | ||
deepStrictEqual(defaultParsedOptions.fetch, globalThis.fetch); | ||
}); | ||
|
||
it('should return the origin index.json for url.index', async () => { | ||
const defaultParsedOptions = opt(); | ||
deepStrictEqual( | ||
defaultParsedOptions.urls.index, | ||
'https://nodejs.org/dist/index.json', | ||
); | ||
}); | ||
|
||
it('should return the origin schedule.json for url.schedule', async () => { | ||
const defaultParsedOptions = opt(); | ||
deepStrictEqual( | ||
defaultParsedOptions.urls.schedule, | ||
'https://raw.githubusercontent.com/nodejs/Release/master/schedule.json', | ||
); | ||
}); | ||
}); | ||
|
||
describe('the parseOptions module should still work when defaults are changed', async () => { | ||
it('should still work when a custom date is passed', async () => { | ||
const currentNow = DateTime.now(); | ||
const defaultParsedOptions = opt({ now: currentNow }); | ||
deepStrictEqual(defaultParsedOptions.now, currentNow); | ||
}); | ||
|
||
it('defaultParsedOptions.fetch should be globalThis.fetch when no options are passed', async () => { | ||
const defaultParsedOptions = opt({ fetch: undiciFetch }); | ||
deepStrictEqual(defaultParsedOptions.fetch, undiciFetch); | ||
}); | ||
|
||
it('should return the origin index.json for url.index', async () => { | ||
const defaultParsedOptions = opt({ | ||
urls: { index: 'https://example.com' }, | ||
}); | ||
deepStrictEqual(defaultParsedOptions.urls.index, 'https://example.com'); | ||
}); | ||
|
||
it('should return the origin schedule.json for url.schedule', async () => { | ||
const defaultParsedOptions = opt({ | ||
urls: { schedule: 'https://example.com' }, | ||
}); | ||
deepStrictEqual(defaultParsedOptions.urls.schedule, 'https://example.com'); | ||
}); | ||
}); |
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 |
---|---|---|
|
@@ -30,6 +30,7 @@ | |
"ranges", | ||
"aliases", | ||
"translate", | ||
"fetchindex" | ||
"fetchindex", | ||
"opt" | ||
] | ||
} |