Not familiar with SystemJS or your app, but if we assume you're doing some asynchronous work on load, you can set up some global property which indicates whether the app is ready or not.
// your main.js
let _appReadyResolver;
window.APP_READY = new Promise( resolve => _appReadyResolver = resolve );
// do some async setup
setTimeout(() => {
_appReadyResolver();
});
Then, in your tests:
cy.visit("/")
// by default will wait 4sec for APP_READY prop to exist on
// window object (unfortunately I don't know how to increase timeouts
// of `cy.its` command)
// After that, it will wait indefinitely for your promise to resolve
.its("APP_READY")
That being said --- if you're not doing any async setup in your app, but the main.js
is simply being loaded asynchronously and it can take longer than 4sec, then I'd do this:
// index.js
<script>
SystemJS.import('/js/main.js');
window.APP_READY = new Promise( resolve => {
let interval = setInterval(() => {
if ( window.MAIN_READY ) {
resolve();
clearTimeout(interval);
};
}, 100 );
</script>
// main.js
window.MAIN_READY = true;
You'll want to strip the APP_READY
logic from production build.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…