• Stars
    star
    112
  • Rank 302,804 (Top 7 %)
  • Language
    JavaScript
  • Created about 11 years ago
  • Updated over 8 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Example setup with Karma and Require.js

THIS REPO IS OUT OF DATE. IF YOU WANT TO MAINTAIN IT, PLEASE CONTACT ME VIA EMAIL.

Testing Require.js code with Karma

To get Karma to run with Require.js we need two files:

  • karma.conf.js — which configures Karma
  • test-main.js — which configures Require.js for the tests

Let's say our app has a directory structure which looks something like this:

$ tree
.
|-- index.html
|-- karma.conf.js
|-- lib
|   |-- jquery.js
|   |-- require.js
|   `-- underscore.js
|-- src
|   |-- app.js
|   `-- main.js
`-- test
    |-- appSpec.js
    `-- test-main.js

3 directories, 9 files

Configure Karma

The first step is creating our karma.conf.js. We can do this in the terminal by running:

$ karma init

This will give you a series of prompts for things such as paths to source and tests and which browsers to capture.

In this example we'll use Jasmine, but other test frameworks works just as well.

Choose "yes" for Require.js.

For the question "Which files do you want to include with <script> tag?", we need to choose all files which are not loaded by Require.js. Usually you'll only need to include your test/test-main.js file, which has the same role for your tests as main.js has for your app when using Require.js.

For the question "Which files do you want to test?", we choose all the files we want to load with Require.js. For this example we'll need:

  • lib/**/*.js — all external libraries
  • src/**/*.js — our source code
  • test/**/*Spec.js — all the tests

And then, for excludes, type src/main.js, as we don't want to actually start the application in our tests.

Now your karma.conf.js should include:

// list of files / patterns to load in the browser
files = [
  JASMINE,
  JASMINE_ADAPTER,
  REQUIRE,
  REQUIRE_ADAPTER,

  {pattern: 'lib/**/*.js', included: false},
  {pattern: 'src/**/*.js', included: false},
  {pattern: 'test/**/*Spec.js', included: false},

  'test/test-main.js'
];

// list of files to exclude
exclude = [
    'src/main.js'
];

Configuring Require.js

Just like any Require.js project, you need a main module to bootstrap your tests. We do this is test/test-main.js.

Karma /base Directory

Karma serves files under the /base directory. So, on the server requests to files will be served up under http://localhost:9876/base/*.

The Require.js config for baseUrl gives a starting context for modules that load with relative paths. When setting this value for the Karma server it will need to start with /base. We want the baseUrl for our tests to be the same folder as the base url we have in src/main.js, so that relative requires in the source won’t need to change. So, as we want our base url to be at src/, we need to write /base/src.

Require Each Test File

With Karma we don't need to list all test files ourselves as we can easily find them from the files specified in test-main.js: Karma includes all the files in window.__karma__.files, so by filtering this array we find all our test files.

Now we can tell Require.js to load our tests, which must be done asynchronously as dependencies must be fetched before the tests are run. The test/test-main.js file ends up looking like this:

var tests = [];
for (var file in window.__karma__.files) {
    if (/Spec\.js$/.test(file)) {
        tests.push(file);
    }
}

requirejs.config({
    // Karma serves files from '/base'
    baseUrl: '/base/src',

    paths: {
        'jquery': '../lib/jquery',
        'underscore': '../lib/underscore',
    },

    shim: {
        'underscore': {
            exports: '_'
        }
    },

    // ask Require.js to load these files (all our tests)
    deps: tests,

    // start test run, once Require.js is done
    callback: window.__karma__.start
});

Using Require.js in tests

Tests can now be written as regular Require.js modules. We wrap everything in define, and inside we can use the regular test methods, such as describe and it. Example:

define(['app', 'jquery', 'underscore'], function(App, $, _) {

    describe('just checking', function() {

        it('works for app', function() {
            var el = $('<div></div>');

            var app = new App(el);
            app.render();

            expect(el.text()).toEqual('require.js up and running');
        });

        it('works for underscore', function() {
            // just checking that _ works
            expect(_.size([1,2,3])).toEqual(3);
        });

    });

});

Running the tests

Install Karma:

$ npm install -g karma

Now we can run the tests with:

$ karma start

If you didn't configure to watch all the files and run tests automatically on any change, you can trigger the tests manually by typing:

$ karma run

Based on Jake Trent's post, with some improvements on shims and so on.

More Repositories

1

writings

My blog posts
1,997
star
2

js-java-setup

Efficient JavaScript development in a Java world
JavaScript
33
star
3

simple

simplistic MV* JavaScript library
JavaScript
30
star
4

generate-asset-webpack-plugin

A Webpack plugin for generating assets, e.g. an index.html
JavaScript
28
star
5

gulp-css-rebase-urls

Rebase relative image URLs
JavaScript
22
star
6

expect-to

Framework-agnostic assertion library based on pure functions
JavaScript
11
star
7

remark-bekk

BEKK theme for remark
JavaScript
8
star
8

coordinate-converter

Converting UTM to Latitude and Longitude
Ruby
7
star
9

kimjoar.net

I sometimes write stuff.
TypeScript
6
star
10

dotfiles

My dotfiles
Shell
5
star
11

js-build

Playing with ShellJS, PhantomJS, Karma, and more
JavaScript
5
star
12

po.js

JavaScript
3
star
13

js-testing

Kurs i bygging av testbare JavaScript-applikasjoner
JavaScript
3
star
14

php-satisfaction

PHP Library for the Get Satisfaction API
PHP
3
star
15

flux-workshop

Introduction to Flux
JavaScript
2
star
16

rubbr

Easily build large LaTeX documents (Fork of https://bitbucket.org/uggedal/rubbr)
Ruby
2
star
17

instapush

Ruby wrapper for the Instapaper API.
Ruby
2
star
18

zend-framework-components

My Zend Framework components.
PHP
2
star
19

monologue

JavaScript
2
star
20

ttm4137

From the course TTM4137 - Wireless Network Security
1
star
21

react-setup

JavaScript
1
star
22

routine

A simple routing engine
JavaScript
1
star
23

backbone-subViewHandler

Improve subview handling in your Backbone app
JavaScript
1
star
24

based-on

JavaScript
1
star
25

mongol-rally

JavaScript
1
star
26

node-browsermob-proxy

Browsermob Proxy bindings for Node.js
JavaScript
1
star
27

ruby-fagkveld

Presentasjon av Ruby til IT-studenter
Ruby
1
star
28

go-concurrent-requests

Go
1
star
29

extendable-js

Easily create a layered architecture in JavaScript
JavaScript
1
star
30

ttm4130

From the course TTM4130 Service Intelligence and Mobility
Java
1
star
31

html-parse-tree

JavaScript
1
star
32

ruby-intro

Introduksjon til programmeringsspråket Ruby
1
star