Skip to content
Merged
Changes from 5 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
88 changes: 44 additions & 44 deletions docs/en/guides/testing-SFCs-with-mocha-webpack.md
Original file line number Diff line number Diff line change
@@ -1,22 +1,22 @@
# Testing Single File Components with Mocha + webpack
# Tester des composants monofichiers avec Mocha + Webpack
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

webpack


> An example project for this setup is available on [GitHub](https://github.com/vuejs/vue-test-utils-mocha-webpack-example).
> Un projet exemple pour cette installation est disponible sur [GitHub](https://github.com/vuejs/vue-test-utils-mocha-webpack-example).
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Un exemple de projet


Another strategy for testing SFCs is compiling all our tests via webpack and then run it in a test runner. The advantage of this approach is that it gives us full support for all webpack and `vue-loader` features, so we don't have to make compromises in our source code.
Une des stratégies pour tester des composants monofichiers est de compiler tous nos tests via webpack puis de les passer dans un lanceur de tests. L'avantage de cette approche est qu'elle procure un support complet pour les fonctionnalités de webpack et de `vue-loader`, et ce, afin de ne pas réaliser de compromis dans notre code.

You can technically use any test runner you like and manually wire things together, but we've found [`mocha-webpack`](https://github.com/zinserjan/mocha-webpack) to provide a very streamlined experience for this particular task.
Techniquement, vous pouvez utiliser n'importe quel lanceur de tests et relier le tout manuellement. Cependant, nous avons trouvé [`mocha-webpack`](https://github.com/zinserjan/mocha-webpack) qui procure une expérience très simplifiée pour cette tâche particulière.

## Setting Up `mocha-webpack`
## Mettre en place `mocha-webpack`

We will assume you are starting with a setup that already has webpack, vue-loader and Babel properly configured - e.g. the `webpack-simple` template scaffolded by `vue-cli`.
On va supposer que vous commencez avec une installation qui a déjà webpack, vue-loader et Babel de correctement configurés (cf. le template `webpack-simple` via `vue-cli`).
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

« de » est en trop ici


The first thing to do is installing test dependencies:
La première chose à faire est d'installer les dépendances de tests :

``` bash
npm install --save-dev vue-test-utils mocha mocha-webpack
```

Next we need to define a test script in our `package.json`.
Ensuite, on doit définir un script test dans notre `package.json`.

```json
// package.json
Expand All @@ -27,19 +27,19 @@ Next we need to define a test script in our `package.json`.
}
```

A few things to note here:
Quelques éléments importants à noter :

- The `--webpack-config` flag specifies the webpack config file to use for the tests. In most cases, this would be identical to the config you use for the actual project with one small tweak. We will talk about this later.
- Le paramètre `--webpack-config` indique le fichier de configuration webpack à utiliser pour les tests. Dans la plupart des cas, c'est identique à la configuration du projet actuel avec une petite modification. On en reparlera plus tard.

- The `--require` flag ensures the file `test/setup.js` is run before any tests, in which we can setup the global environment for our tests to be run in.
- Le paramètre `--require` permet de s'assurer que le fichier `test/setup.js` est bien exécuté avant les tests. Dans celui-ci, on met en place l'environnement où nos tests vont être exécutés.

- The final argument is a glob for the test files to be included in the test bundle.
- Le dernier paramètre est un glob pour indiquer les fichiers de tests à inclure dans le paquet.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

On remplace tout les bundle par paquetage (avec les mot de la famille, empaquetage, désempaquetage, empaqueter, etc.). On garde plutôt le terme paquet pour « npm est un gestionnaire de paquet »


### Extra webpack Configuration
### Configuration supplémentaire pour webpack

#### Externalizing NPM Dependencies
#### Externaliser les dépendances NPM
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

npm, nom de produit


In our tests we will likely import a number of NPM dependencies - some of these modules may be written without browser usage in mind and simply cannot be bundled properly by webpack. Another consideration is externalizing dependencies greatly improves test boot up speed. We can externalize all NPM dependencies with `webpack-node-externals`:
Dans nos tests, nous allons surement importer un nombre conséquent de dépendances NPM, certaines d'entre elles n'ont pas été conçues pour une utilisation dans un navigateur et ne peuvent être empaquetées par webpack. Il faut aussi considérer qu'externaliser les dépendances augmente énormément la vitesse de lancement des tests. On peut externaliser toutes les dépendances NPM avec `webpack-node-externals -externals` :
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

npm x2


```js
// webpack.config.js
Expand All @@ -51,9 +51,9 @@ module.exports = {
}
```

#### Source Maps
#### Carte des sources
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Si je devais traduire source map j'utiliserais plutôt le terme de « Coordinateurs de source » car source map est un terme qui explique que le fichier en question sert à faire le lien entre une sortie produite et son origine dans une source. Par exemple le « route mapping » est souvent traduit par « concordance de route » (mais je crois pas que concordinateur soit un terme existant :D).


Source maps need to be inlined to be picked up by `mocha-webpack`. The recommended config is:
La carte des sources doit être indiquée pour être utilisée par `mocha-webpack`. La configuration recommandée est la suivante :
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

En partant sur coordinateur je mettrais

Le coordinateur de source (« Source maps »)

Car ce n'est pas un terme que l'on va pouvoir trouver dans un dictionnaire, il est pertinant d'indiquer l'original dans la première occurance.


``` js
module.exports = {
Expand All @@ -62,117 +62,117 @@ module.exports = {
}
```

If debugging via IDE, it's also recommended to add the following:
Si vous déboguez via votre IDE, il est recommandé d'ajouter la configuration suivante :

``` js
module.exports = {
// ...
output: {
// ...
// use absolute paths in sourcemaps (important for debugging via IDE)
// utiliser des chemins absolus (c'est important si vous déboguez avec un IDE)
devtoolModuleFilenameTemplate: '[absolute-resource-path]',
devtoolFallbackModuleFilenameTemplate: '[absolute-resource-path]?[hash]'
}
}
```

### Setting Up Browser Environment
### Mettre en place l'environnement du navigateur

`vue-test-utils` requires a browser environment to run. We can simulate it in Node.js using `jsdom-global`:
`vue-test-utils` requiert en environnement de navigateur pour fonctionner. On peut le simuler avec Node.js en utilisant `jsdom-global` :

```bash
npm install --save-dev jsdom jsdom-global
```

Then in `test/setup.js`:
Puis dans `test/setup.js`:

``` js
require('jsdom-global')()
```

This adds a browser environment to node, so that `vue-test-utils` can run correctly.
Cela ajoute un environnement de navigateur dans node afin que `vue-test-utils` fonctionne correctement.
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Node.js


### Picking an Assertion Library
### Choisir une bibliothèque d'assertions

[Chai](http://chaijs.com/) is a popular assertion library that is commonly used alongside Mocha. You may also want to check out [Sinon](http://sinonjs.org/) for creating spies and stubs.
[Chai](http://chaijs.com/) est une bibliothèque populaire qui est généralement utilisée avec Mocha. Vous pouvez aussi jeter un coup d'œil à [Sinon](http://sinonjs.org/) pour créer des espions et des fonctions avec un comportement pré-programmé (stubs).
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

préprogrammé (« stubs »).


Alternatively you can use `expect` which is now part of Jest, and exposes [the exact same API](http://facebook.github.io/jest/docs/en/expect.html#content) in Jest docs.
Vous pouvez utiliser, alternativement, `expect` qui fait maintenant partie de Jest et expose [la même API](http://facebook.github.io/jest/docs/en/expect.html#content) dans la documentation de Jest.

We will be using `expect` here and make it globally available so that we don't have to import it in every test:
On va utiliser `expect` et le rendre globalement accessible afin de ne pas avoir à l'importer pour chaque test :

``` bash
npm install --save-dev expect
```

Then in `test/setup.js`:
Puis dans `test/setup.js`:

``` js
require('jsdom-global')()

global.expect = require('expect')
```

### Optimizing Babel for Tests
### Optimiser Babel pour les tests

Notice that we are using `babel-loader` to handle JavaScript. You should already have Babel configured if you are using it in your app via a `.babelrc` file. Here `babel-loader` will automatically use the same config file.
Notez que nous utilisons `babel-loader` pour gérer JavaScript. Vous devriez déjà avoir Babel de configuré si vous l'utilisez dans votre application via un fichier `.babelrc`. Ici `babel-loader` va automatiquement utiliser le même fichier de configuration.

One thing to note is that if you are using Node 6+, which already supports the majority of ES2015 features, you can configure a separate Babel [env option](https://babeljs.io/docs/usage/babelrc/#env-option) that only transpiles features that are not already supported in the Node version you are using (e.g. `stage-2` or flow syntax support, etc.)
Une autre chose à noter est que si vous utilisez une version de Node >= 6, qui supporte déjà une majorité des fonctionnalités d'ES2015, vous pouvez configurer séparément un autre Babel [env option](https://babeljs.io/docs/usage/babelrc/#env-option) qui va uniquement transpiler les fonctionnalités non supportées dans la version de Node que vous utilisez (c.-à-d. `stage-2` ou le support de la syntaxe flow, etc.).
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Node >= 6 ---> Node.js 6+

C'est la nomonclature qu'on utlise à travers toutes les docs Vue. Si tu ne vois pas ça quelque part, tu peux PR l'originale.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

version de Node.js

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Si tu mets

`stage-2`

je te laisse mettre

`stage-x`

sur l'un des précédents fichiers déjà validé


### Adding a test
### Ajouter un test

Create a file in `src` named `Counter.vue`:
Créez dans le dossier `src` un fichier nommé `Counter.vue`:

``` html
<template>
<div>
{{ count }}
<button @click="increment">Increment</button>
{{ counter }}
<button @click="incrementer">Incrementer</button>
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

<button @click="increment">Incrementer</button>

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Laisse count car ça nous fera moins de conflits à résoudre en cas de changement de code. On traduit texte, label et valeur de chaine de caractère. « increment » étant une fonction, on ne le traduit pas.

</div>
</template>

<script>
export default {
data () {
return {
count: 0
counter: 0
}
},

methods: {
increment () {
this.count++
incrementer () {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

increment

this.counter++
}
}
}
</script>
```

And create a test file named `test/Counter.spec.js` with the following code:
Puis créez un test nommé `test/Counter.spec.js` avec le code suivant :

```js
import { shallow } from 'vue-test-utils'
import Counter from '../src/Counter.vue'

describe('Counter.vue', () => {
it('increments count when button is clicked', () => {
it('incrémente le compteur quand le bouton est cliqué', () => {
const wrapper = shallow(Counter)
wrapper.find('button').trigger('click')
expect(wrapper.find('div').text()).toMatch('1')
})
})
```

And now we can run the test:
Et maintenant on peut lancer le test avec :

```
npm run unit
```

Woohoo, we got our tests running!
Woohoo, nos tests fonctionnent !

### Resources
### Ressources

- [Example project for this setup](https://github.com/vuejs/vue-test-utils-mocha-webpack-example)
- [Projet exemple pour cette installation](https://github.com/vuejs/vue-test-utils-mocha-webpack-example)
- [Mocha](https://mochajs.org/)
- [mocha-webpack](http://zinserjan.github.io/mocha-webpack/)
- [Chai](http://chaijs.com/)
Expand Down