This is a start kit that creates an ES Modules format library that runs on node.js.
-
Create project.
mkdir yourLibrary && cd $_;
-
Create project configuration file.
Execute the following command.
This will create package.json at the root of the project.npm init -y;
Open package.json and edit as follows.
... "main": "src/yourLibrary.js", ...
Name Value Description main src/yourLibrary.js The main field is a module ID that is the primary entry point to your program. -
Install required packages.
npm i -S esm && npm i -D jest @babel/preset-env;
Name Description esm Necessary for executing modules in ES Modules format with node.js. jest Jest is a library for testing JavaScript code. @babel/preset-env Compile the code under test from the latest specification to ECMAScript 5 so that it can be tested with Jest -
Create a library module.
Create a directory to store source files.
mkdir src;
Submodule that calculates the subtraction.
// src/add.js /** * Sum two values */ export default function (a, b) { return a + b; }
Submodule that calculates the addition.
// src/sub.js /** * Diff two values */ export default function (a, b) { return a - b; }
Main module that imports multiple modules and exports a single library.
// src/yourLibrary.js import add from './add'; import sub from './sub'; export {add, sub};
-
Let's run the library on node.
Run the following command.
node -r esm -e "\ import {add} from './src/yourLibrary'; console.log('1+2=' + add(1,2));";# 1+2=3
-
Setting up and running unit tests.
Then, Create add.test.ts and sub.test.ts files in the src directory.
This will contain our actual test.// src/add.test.js import {add} from './yourLibrary'; test('add 1 + 2 to equal 3', () => { expect(add(1, 2)).toBe(3); });
// src/sub.test.js import {sub} from './yourLibrary'; test('sub 2 - 1 to equal -1', () => { expect(sub(1, 2)).toBe(-1); });
Add .babelrc to the project root and add the following content.
{ "presets": ["@babel/preset-env"] }
Open your package.json and add the following script.
... "scripts": { "test": "jest" ...
Run the test.
npm run test;
Jest will print this message.
You just successfully wrote your first test.PASS src/add.test.js PASS src/sub.test.js Test Suites: 2 passed, 2 total Tests: 2 passed, 2 total Snapshots: 0 total Time: 1.329s Ran all test suites.
-
Create an NPM user locally.
When the command is executed, a '~/.npmrc' file is created and the entered information is stored.npm set init.author.name 'Your name'; npm set init.author.email '[email protected]'; npm set init.author.url 'https://your-url.com'; npm set init.license 'MIT'; npm set init.version '1.0.0';
-
Create a user on npm.
If the user is not registered yet, enter the new user information to be registered in npm.
If an npm user has already been created, enter the user information and log in.npm adduser;
-
Create a repository on GitHub and clone.
git clone https://github.com/your-user/your-repository.git;
-
Setting files to be excluded from publishing
Create an .npmignore file at the root of the project.
.npmignore
Add node_modules and package-lock.json to .npmignore not to publish.
node_modules/ package-lock.json
-
Create v1.0.0 tag on GitHub.
git tag -a v1.0.0 -m 'My first version v1.0.0'; git push origin v1.0.0;
-
Publish to npm
npm publish;
-
Push program changes to github
git commit -am 'Update something'; git push;
-
Increase version
npm version patch -m "Update something";
-
Create a new version tag on Github
git push --tags;
-
Publish to npm
npm publish;
-
Create project.
mkdir myapp && cd $_;
-
Create project configuration file.
npm init -y;
-
Install this library and esm.
npm i -S nodejs-package-starter esm;
-
Create a test module.
Add library execution test module to project root.
touch app.js;
Add content:
/* app.js */ import {add, sub} from 'nodejs-package-starter'; console.log(`1+2=${add(1,2)}`);// 1+2=3 console.log(`1-2=${sub(1,2)}`);// 1-2=-1
-
Run the test module.
node -r esm app;
- Twitter: @TakuyaMotoshima
- Github: TakuyaMotoshima mail to: [email protected]