I am trying to create a blank project, like a template, using lit-html. I wanted to also add some testing capabilities, so i have been trying to get it to work with Karma.
I can run a normal test, like an addition, without any errors, so i think Karma itself is running ok. but i can't run any test involving the webcomponent. I can't import the webcomponent!
i am exporting the webcomponent with:
export default class MyComponent ...
and then on the test file i am importing it with:
import MyComponent from 'pathToComponent/MyComponent'
When i run the test i get:
Error loading test file: /test/example.test.js
TypeError: Failed to fetch dynamically imported module: http://localhost:9876/base/test/example.test.js
I have it on a github repo here: https://github.com/boguz/rollup-lit-redux, so you can take a better look if you need to see what other packages i have installed.
Any help is very appreciated. Thank you!
 
                        
The error message is due to a module referenced by
/test/example.test.js- the error message is a little deceptive...The clue is that you didn't dynamically import (that's when you use
const module = await import('path')and you'd get an exception on that line if it failed) - you statically imported. That error message is not because it couldn't findhttp://localhost:9876/base/test/example.test.js, it's that it couldn't find a nested reference in that file.At a guess
example.test.jscontains animportwith a relative path that isn't served:That works in TypeScript and linting tools because it can resolve
./testFrameworkto./testFramework.d.ts,./node_modules/@types/testFramework.d.tsor whatever type lookup you're using.However, in the browser it doesn't know you actually want
./testFramework.jsor./testFramework/index.js, it requests./testFrameworkdirectly, gets a 404, and then gives you that error for the calling component.In short:
import * from ...)importinfilename.js, not gettingfilename.jsitself.The network tab will point you at which dependency is the problem, as it will be a 404, and the fix is either resolve these imports with your build tools, or put the full relative path to the .js file in your source.