ng-mockito icon indicating copy to clipboard operation
ng-mockito copied to clipboard

Jest error when using mockToken

Open Markus-Ende opened this issue 3 years ago • 0 comments

Tested with Angular 12

When using mockToken directly, Jest throws the following error (replacing mockToken with mockNg fixes the issue):

 FAIL   client  apps/todos/src/app/todos/todos.component.spec.ts
  ● Test suite failed to run

    Jest encountered an unexpected token

    This usually means that you are trying to import a file which Jest cannot parse, e.g. it's not plain JavaScript.

    By default, if Jest sees a Babel config, it will use that to transform your files, ignoring "node_modules".

    Here's what you can do:
     • If you are trying to use ECMAScript Modules, see https://jestjs.io/docs/en/ecmascript-modules for how to enable it.
     • To have some of your "node_modules" files transformed, you can specify a custom "transformIgnorePatterns" in your config.
     • If you need a custom transformation specify a "transform" option in your config.
     • If you simply want to mock your non-JS modules (e.g. binary assets) you can stub them out with the "moduleNameMapper" config option.

    You'll find more details and examples of these config options in the docs:
    https://jestjs.io/docs/en/configuration.html

    Details:

    /...../node_modules/ng-mockito/lib/mock-token.d.ts:1
    ({"Object.<anonymous>":function(module,exports,require,__dirname,__filename,global,jest){import { FactoryProvider, InjectionToken, Type } from '@angular/core';
                                                                                             ^^^^^^

    SyntaxError: Cannot use import statement outside a module

Markus-Ende avatar Jun 15 '21 06:06 Markus-Ende