Mocha non riconoscerà JSX

voti
8

Sto cercando di aggiornare i miei test di unità utilizzando moka e l'enzima. Il codice che sto testando è in ES6, utilizzando JSX e reagire.

Sono stato in grado di ottenere moka di non errore sul JSX nel mio script di test.

script di test:

import React from 'react';
import assert from 'assert';
import { shallow } from 'enzyme';
import SamplePageMain from '../SamplePageMain';

describe('<SamplePageMain />', () => {

    var samplePage = shallow(<SamplePageMain />);

    it('should render', function () {
        assert.notEqual(samplePage, null);
    });

});

gulpfile.js:

require('babel-core/register');

...

gulp.task('test', function() {
    return gulp.src('scripts/**/test/*.js', {read: false})
        .pipe(mocha());
});

e l'uscita è:

gulp test

[16:19:06] Using gulpfile ~/dev/bikini/gulpfile.js
[16:19:06] Starting 'test'...
[16:19:06] 'test' errored after 62 ms
[16:19:06] SyntaxError in plugin 'gulp-mocha'
Message:
        /Users/me/dev/bikini/scripts/components/test/samplePageMain.js:     Unexpected token (9:26)
Details:
    pos: 206
    loc: [object Object]
    _babel: true
    codeFrame:    7 | 
   8 | 
>  9 |  var samplePage = shallow(<SamplePageMain />);
     |                           ^
  10 | 
  11 |  it('should render', function () {
  12 |      assert.notEqual(samplePage, null);
Stack:
SyntaxError:     /Users/me/dev/bikini/scripts/components/test/samplePageMain.js:     Unexpected token (9:26)
   7 | 
   8 | 
>  9 |  var samplePage = shallow(<SamplePageMain />);
     |                           ^
  10 | 
  11 |  it('should render', function () {
  12 |      assert.notEqual(samplePage, null);
    at Parser.pp.raise (/Users/me/dev/bikini/node_modules/babel-    register/node_modules/babel-core/node_modules/babylon/index.js:1425:13)
    at Parser.pp.unexpected (/Users/me/dev/bikini/node_modules/babel-    register/node_modules/babel-core/node_modules/babylon/index.js:2907:8)
    at Parser.pp.parseExprAtom     (/Users/me/dev/bikini/node_modules/babel-register/node_modules/babel-    core/node_modules/babylon/index.js:754:12)
    at Parser.pp.parseExprSubscripts     (/Users/me/dev/bikini/node_modules/babel-register/node_modules/babel-    core/node_modules/babylon/index.js:509:19)
    at Parser.pp.parseMaybeUnary     (/Users/me/dev/bikini/node_modules/babel-register/node_modules/babel-    core/node_modules/babylon/index.js:489:19)
    at Parser.pp.parseExprOps     (/Users/me/dev/bikini/node_modules/babel-register/node_modules/babel-    core/node_modules/babylon/index.js:420:19)
    at Parser.pp.parseMaybeConditional     (/Users/me/dev/bikini/node_modules/babel-register/node_modules/babel-    core/node_modules/babylon/index.js:402:19)
    at Parser.pp.parseMaybeAssign     (/Users/me/dev/bikini/node_modules/babel-register/node_modules/babel-    core/node_modules/babylon/index.js:365:19)
    at Parser.pp.parseExprListItem     (/Users/me/dev/bikini/node_modules/babel-register/node_modules/babel-    core/node_modules/babylon/index.js:1232:16)
    at Parser.pp.parseCallExpressionArguments     (/Users/me/dev/bikini/node_modules/babel-register/node_modules/babel-    core/node_modules/babylon/index.js:585:20)

Ho avuto il test eseguito correttamente eseguendo il codice sorgente attraverso browserify e metterlo in una directory di prova per dimostrare che non è moka / enzima stesso. Il mio problema è solo cercando di ottenere il sorso giusta magia.

È pubblicato 10/02/2016 alle 00:25
fonte dall'utente
In altre lingue...                            


1 risposte

voti
18

Questo è stato un problema molto comune per gli utenti di Babel 6, che da solo (babel-core) non fa nulla. Essa richiede che trasforma / plugin sono alimentati ad esso durante transpilation.

Babel offre fasci di plug-in comuni come predefiniti. Comuni progetti per Reagire sono babel-preset-2015, babel-preset-reacte babel-preset-stage-0. Dopo npm di installarli, aggiungere un .babelrcfile di configurazione che sembra qualcosa di simile:

{
  "presets": ["react", "es2015", "stage-0"]
}

Per moka con gulp checkout questo stack gulp-moka come passare la bandiera compilatori? .

E leggere qui sulla configurazione di Babel 6 generalmente https://babeljs.io/blog/2015/10/31/setting-up-babel-6

Risposto il 10/02/2016 a 19:24
fonte dall'utente

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more