This repository contains a collection of useful tools for use with Taskcluster. Generally, we strive to not add UI to Taskcluster components, but instead offer well documented APIs that can be easily consumed using a client library for Taskcluster.
- Node version v8+
- Yarn
First, fork this repository to another GitHub account. Then you can clone and install:
git clone https://github.com/<YOUR_ACCOUNT>/taskcluster-tools.git
cd taskcluster-tools
yarn
src/
: source codesrc/App
: top-level component, holds page layout, route rendering, and login handlingsrc/views
: route-based components typically matching a URL, e.g./groups
maps tosrc/views/UnifiedInspector
src/components
: generic components that can be used in any view (not view-specific)
Building this project uses Neutrino, neutrino-preset-frontend-infra to:
- Compile ES2015+ syntax to ES5-compatible JS
- Compile React JSX to de-sugared JS
- Show ESLint errors based on R&P rules
- Build views into cacheable bundles
- Importing files directly via JS and output to the bundle
Install npm dependencies and start it up:
yarn
yarn start
This will start a local development server on port 9000 (http://localhost:9000).
Any ESLint errors across the project will be displayed in the terminal during development.
yarn start
: the default development build, watchessrc/
, and serves onhttp://localhost:9000/
yarn build
: buildssrc/
files into abuild/
directory
It's possible that when building a larger project like taskcluster-tools that Node.js will run out
of memory for the amount of files being built during development. As a workaround, instead of
running yarn start
, run the following to run the same command with more memory:
node --max-old-space-size=4096 node_modules/.bin/neutrino start
You may need to adjust the memory size to your machine specs accordingly.
Until someone comes up with something better, all testing is manual. Open the tools and check that they work. :)
Ngrok allows you to expose a web server running on your local machine to the internet. Ngrok is used to create an https connection, so that you can login to the taskcluster-tools. For using ngrok:
- Create a free account on ngrok.
- Install ngrok -
npm install -g ngrok
oryarn global add ngrok
- Run ngrok -
ngrok http 9000
Note: You have to run ngrok in a separate terminal/console.
Taskcluster uses Travis to automatically deploy the Heroku application after a successful build on master.
This is done in .travis.yml
:
deploy:
provider: heroku
api_key:
secure: "<your encrypted API key>"
If a deployment results in the site throwing a 404, try updating the API key. A non valid key will not deploy properly.
- Run
heroku auth:token
on the command line and then copy the token. - Navigate to https://travis-encrypt.github.io/.
- Write
taskcluster/taskcluster-tools
in the first input field and paste the copied token in the second text field. - Click the encrypt button.
- Replace the
<your encrypted API key>
placeholder from the snippet above with the encryped key that was generated for you.