@textbook/build-info
v1.3.0
Published
Generate build information for tracking deployments
Downloads
376
Readme
@textbook/build-info
Generate build information for tracking deployments.
Sources
buildinfo
has numerous sources, each of which is automatically enabled, if appropriate, in the following order:
- Clock - includes the build time
- User - includes the identity of the user
- Git - includes the commit the build was based on and a summary of any changes from it
- Heroku - includes the fact that it was built in Heroku, for which stack and from which commit
- GitHub Actions - includes the build number and URL
- CircleCI - includes the build number and URL
- Netlify - includes the build number and URL
Usage
You can install this package using e.g. NPM:
npm install --save-dev @textbook/build-info
and then use it in your scripts in package.json
:
{
// ...
"scripts": {
// ...
"build": "<do your build>",
"postbuild": "buildinfo -o path/to/build-info.txt",
// ...
}
}
This will generate a file like the following:
Built: 2022-07-07T20:17:55.213Z
By: jonrsharpe
From: 3f27baa Refactor sources in subdirectory
You can also run it without installation via NPX:
$ npx --package @textbook/build-info buildinfo -o path/to/file.txt
Need to install the following packages:
@textbook/build-info
Ok to proceed? (y)
(you can suppress the confirmation with the --yes
flag).
Arguments
-f
/--format
- the format to provide data in (one ofhtml
,json
,text
; default:text
)-h
/--help
- show a help message and exit-o
/--output
- the file to write data to-v
/--version
- show the version and exit
Stdout
If you don't supply the --output
argument (or supply the argument with the value -
), data will be written to
stdout, allowing redirection:
{
// ...
"scripts": {
// ...
"build": "<do your build>",
"postbuild": "buildinfo > path/to/build-info.txt",
// ...
}
}
Compatibility
The emitted code targets Node from at least 18.3 (see engines
field in package.json
). It is tested on the latest
even-numbered versions of Node (currently 18, 20 and 22) in Ubuntu (22.04) and Windows (Server 2022).
Development
Clone the repository, then install the dependencies using npm install
or npm ci
.
You can create a new build information source by implementing Source
, and optionally extend Cmd
or Env
to run
terminal commands or access environment variables respectively.
Scripts
The following scripts are provided to aid development:
npm run lint
: Applies linting using ESLintnpm run dev
: Runs the app without building it first (using ts-node)npm run test
: Runs tests using Mocha (plus ts-node, Chai and Sinon)npm run test:coverage
: Runs the tests with coverage using c8
npm run e2e
: Builds the library with TypeScript and runs it, generatingout.txt