Clone and navigate to this repo:
git clone [email protected]:bugsnag/bugsnag-js.git
cd bugsnag-js
Install top level dependencies:
npm i
Bootstrap all of the individual packages:
npm run bootstrap
Build each of the standalone packages:
npm run build
Runs the unit tests for each package.
npm run test:unit
This tests the validity of .d.ts files by attempting to compile a TypeScript program that uses Bugsnag.
npm run test:types
Lints the entire repo with ESLint. On JavaScript files this uses the standard ruleset and on TypeScript files this uses the @typescript/eslint recommended set of rules.
npm run test:lint
These tests are implemented with our notifier testing tool Maze runner.
End to end tests are written in cucumber-style .feature
files, and need Ruby-backed "steps" in order to know what to run. The tests are located in the top level test
directory.
Maze runner's CLI and the test fixtures are containerised so you'll need Docker (and Docker Compose) to run them.
Note: only Bugsnag employees can run the end-to-end tests. We have dedicated test infrastructure and private BrowserStack credentials which can't be shared outside of the organisation.
You'll need to set the credentials for the aws profile in order to access the private docker registry:
aws configure --profile=opensource
Subsequently you'll need to run the following commmand to authenticate with the registry:
npm run test:test-container-registry-login
Your session will periodically expire, so you'll need to run this command to re-authenticate when that happens.
The browser tests drive real, remote browsers using BrowserStack. As a Bugsnag employee you can access the necessary credentials in our shared password manager.
The following environment variables need to be set:
BROWSER
(the browser you want to test on – choose a key fromtest/browser/features/browsers.yml
)BROWSER_STACK_USERNAME
BROWSER_STACK_ACCESS_KEY
BROWSER=chrome_61 \
BROWSER_STACK_USERNAME=xxx \
BROWSER_STACK_ACCESS_KEY=xxx \
npm run test:browser
To run a single feature file:
BROWSER=chrome_61 \
BROWSER_STACK_USERNAME=xxx \
BROWSER_STACK_ACCESS_KEY=xxx \
npm run test:browser -- features/unhandled_errors.feature
To run the Node test suite:
npm run test:node
You can use the NODE_VERSION
env var to choose which version of Node to run the tests on. The default version is 10
.
To run a single feature file:
npm run test:node -- features/unhandled_errors.feature
The Expo tests drive real, remote mobile devices using BrowserStack. As a Bugsnag employee you can access the necessary credentials in our shared password manager.
They also require access to the Expo ecosystem in order to publish, then build, the installable app packages. As above, these credentials can also be found in the shared password manager.
The following environment variables need to be set:
DEVICE_TYPE
: the mobile operating system you want to test on – one of ANDROID_5, ANDROID_6, ANDROID_7, ANDROID_8, ANDROID_9, IOS_10, IOS_11, IOS_12BROWSER_STACK_USERNAME
BROWSER_STACK_ACCESS_KEY
EXPO_USERNAME
EXPO_PASSWORD
To run against an android device:
DEVICE_TYPE=ANDROID_9 \
BROWSER_STACK_USERNAME=xxx \
BROWSER_STACK_ACCESS_KEY=xxx \
EXPO_USERNAME=xxx \
EXPO_PASSWORD=xxx \
npm run test:expo:android
To run against an iOS device, several additional details are required. In order to provision the app the Expotest.mobileprovision
and its accompanying certificates need to be downloaded from the shared engineering document store and additional environment variables need to be set:
APPLE_TEAM_ID
: The team ID to use when building the applicationEXPO_PROVISIONING_PROFILE_PATH
: The path to theExpotest.mobileprovision
file as mentioned aboveEXPO_P12_PATH
: The path to theCertificates.p12
file as mentioned aboveEXPO_IOS_DIST_P12_PASSWORD
: The password required for the above certificate
To run against an iOS device:
DEVICE_TYPE=IOS_10 \
BROWSER_STACK_USERNAME=xxx \
BROWSER_STACK_ACCESS_KEY=xxx \
EXPO_USERNAME=xxx \
EXPO_PASSWORD=xxx \
APPLE_TEAM_ID=xxx \
EXPO_PROVISIONING_PROFILE_PATH=xxx \
EXPO_P12_PATH=xxx \
EXPO_IOS_DIST_P12_PASSWORD=xxx \
npm run test:expo:ios