179 lines
5.7 KiB
Markdown
Raw Normal View History

2014-01-05 20:07:11 +04:00
# Karma [![Build Status](https://secure.travis-ci.org/karma-runner/karma.png?branch=master)](http://travis-ci.org/karma-runner/karma)
A simple tool that allows you to execute JavaScript code in multiple
_real_ browsers, powered by [Node.js] and [Socket.io].
> The main purpose of Karma is to make your TDD development easy,
> fast, and fun.
## When should I use Karma?
* You want to test code in *real* browsers.
* You want to test code in multiple browsers (desktop, mobile,
tablets, etc.).
* You want to execute your tests locally during development.
* You want to execute your tests on a continuous integration server.
* You want to execute your tests on every save.
* You love your terminal.
* You don't want your (testing) life to suck.
* You want to use [Istanbul] to automagically generate coverage
reports.
* You want to use [RequireJS] for your source files.
## But I still want to use \_insert testing library\_
Karma is not a testing framework, neither an assertion library,
so for that you can use pretty much anything you like. Right now out
of the box there is support for
* [Mocha]
* [Jasmine]
* [QUnit]
* \_anything else\_ Write your own adapter. It's not that hard. And we
are here to help.
## Which Browsers can I use?
All the major browsers are supported, if you want to know more see the
[Browsers] page.
## I want to use it. Where do I sign?
You don't need to sign anything but here are some resources to help
you to get started. And if you need even more infos have a look at our
great [website].
### Obligatory Screencast.
Every serious project has a screencast, so here is ours. Just click
[here] and let the show begin.
### NPM Installation.
If you have [Node.js] installed, it's as simple as
```bash
$ npm install -g karma
```
This will give you the latest stable version available on npm. If you
want to live life on the edge you can do so by
```bash
$ npm install -g karma@canary
```
The curious can have a look at the documentation articles for
[Getting Started] and [Versioning].
### Using it.
Go into your project and create a Karma configuration. That is
just a simple JavaScript or CoffeeScript file that tells Karma
where all the awesomeness of your project are.
You can find a simple example in
[test/client/karma.conf.js](https://github.com/karma-runner/karma/blob/master/test/client/karma.conf.js)
which contains most of the options.
To create your own from scratch there is the `init` command, which
will be named `karma.conf.js` by default:
```bash
$ karma init
```
This will ask you many questions and if you answered them all correct
you will be allowed to use Karma.
For more information on the configuration options see
[Configuration File Overview].
Now that you have your configuration all that is left to do is to
start Karma:
```bash
$ karma start
```
If you want to run tests manually (without auto watching file changes), you can:
```bash
$ karma run
```
But only if you have started the Karma server before.
## Why did you create this?
Throughout the development of [AngularJS], we've been using [JSTD] for
testing. I really think that JSTD is a great idea. Unfortunately, we
had many problems with JSTD, so we decided to write our own test
runner based on the same idea. We wanted a simple tool just for
executing JavaScript tests that is both stable and fast. That's why we
use the awesome [Socket.io] library and [Node.js].
## I still don't get it. Where can I get help?
* [Docs]
* [Mailing List]
* [Issuetracker]
* [@JsKarma] on Twitter
## This is so great. I want to help.
See
[Contributing.md](https://github.com/karma-runner/karma/blob/master/CONTRIBUTING.md)
or the [docs] for more information.
## My boss wants a license. So where is it?
### The MIT License
> Copyright (C) 2011-2013 Vojta Jína.
>
> Permission is hereby granted, free of charge, to any person
> obtaining a copy of this software and associated documentation files
> (the "Software"), to deal in the Software without restriction,
> including without limitation the rights to use, copy, modify, merge,
> publish, distribute, sublicense, and/or sell copies of the Software,
> and to permit persons to whom the Software is furnished to do so,
> subject to the following conditions:
>
> The above copyright notice and this permission notice shall be
> included in all copies or substantial portions of the Software.
>
> THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
> EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
> MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
> NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
> BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
> ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
> CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
> SOFTWARE.
[AngularJS]: http://angularjs.org/
[JSTD]: http://code.google.com/p/js-test-driver/
[Socket.io]: http://socket.io/
[Node.js]: http://nodejs.org/
[Jasmine]: http://pivotal.github.io/jasmine/
[Mocha]: http://visionmedia.github.io/mocha/
[QUnit]: http://qunitjs.com/
[here]: http://www.youtube.com/watch?v=MVw8N3hTfCI
[Mailing List]: https://groups.google.com/forum/#!forum/karma-users
[Issuetracker]: https://github.com/karma-runner/karma/issues
[@JsKarma]: http://twitter.com/JsKarma
[RequireJS]: http://requirejs.org/
[Istanbul]: https://github.com/gotwarlost/istanbul
[Browsers]: http://karma-runner.github.io/0.8/config/browsers.html
[Versioning]: http://karma-runner.github.io/0.8/about/versioning.html
[Configuration File Overview]: http://karma-runner.github.io/0.8/config/configuration-file.html
[docs]: http://karma-runner.github.io
[Docs]: http://karma-runner.github.io
[website]: http://karma-runner.github.io