This is to demonstrate an issue when testing an Aurelia component library where components are registered as global resources and using signal
binding behaviour.
The problem occurs when unit-testing the components using aurelia-testing
plugin. In this example two components are using signal
binding behaviour with different signal names. There are two test cases for component parent1
, and parent2
.
au-signaler-issue/test/unit/app.spec.js
Line 26 in fb030b9
au-signaler-issue/test/unit/app.spec.js
Line 45 in fb030b9
comp2
).
au-signaler-issue/src/comp2.html
Line 3 in fb030b9
The second test succeeds when running standalone (e.g. using fit(...)
).
Both components parent1
, and parent2
are registered as global resources. If global registration is omitted, the problem does not occur.
au-signaler-issue/src/index.js
Line 4 in fb030b9
This project is bootstrapped by aurelia-cli.
For more information, go to https://aurelia.io/docs/cli/webpack
Run npm start
, then open http://localhost:8080
You can change the standard webpack configurations from CLI easily with something like this: npm start -- --open --port 8888
. However, it is better to change the respective npm scripts or webpack.config.js
with these options, as per your need.
To enable Webpack Bundle Analyzer, do npm run analyze
(production build).
To enable hot module reload, do npm start -- --hmr
.
To change dev server port, do npm start -- --port 8888
.
To change dev server host, do npm start -- --host 127.0.0.1
PS: You could mix all the flags as well, npm start -- --host 127.0.0.1 --port 7070 --open --hmr
For long time aurelia-cli user, you can still use au run
with those arguments like au run --env prod --open --hmr
. But au run
now simply executes npm start
command.
Run npm run build
, or the old way au build --env prod
.
Run au test
(or au jest
).
To run in watch mode, au test --watch
or au jest --watch
.