fixed a couple Markdown formatting issues

This commit is contained in:
Erik Hanson 2010-02-26 11:42:38 -08:00
parent e1b3ca4066
commit fcfe23d516

View File

@ -56,6 +56,7 @@ Enter Jasmine
Jasmine is our dream JavaScript testing framework. It's heavily influenced by, and borrows the best parts of, ScrewUnit, JSSpec, [JSpec](http://github.com/visionmedia/jspec/tree/master), and of course RSpec. Jasmine is our dream JavaScript testing framework. It's heavily influenced by, and borrows the best parts of, ScrewUnit, JSSpec, [JSpec](http://github.com/visionmedia/jspec/tree/master), and of course RSpec.
Jasmine was designed with a few principles in mind. We believe that a good JavaScript testing framework: Jasmine was designed with a few principles in mind. We believe that a good JavaScript testing framework:
* should not be tied to any browser, framework, platform, or host language. * should not be tied to any browser, framework, platform, or host language.
* should have idiomatic and unsurprising syntax. * should have idiomatic and unsurprising syntax.
* should work anywhere JavaScript can run, including browsers, servers, phones, etc. * should work anywhere JavaScript can run, including browsers, servers, phones, etc.
@ -63,6 +64,7 @@ Jasmine was designed with a few principles in mind. We believe that a good JavaS
* should play well with IDEs (e.g. test code should pass static analysis). * should play well with IDEs (e.g. test code should pass static analysis).
Some of our goals while writing Jasmine: Some of our goals while writing Jasmine:
* it should encourage good testing practices. * it should encourage good testing practices.
* it should integrate easily with continuous build systems. * it should integrate easily with continuous build systems.
* it should be simple to get started with. * it should be simple to get started with.
@ -138,34 +140,34 @@ To add the matcher to your suite, call `this.addMatchers()` from within a `befor
Specs are grouped in Suites. Suites are defined using the global `describe()` function: Specs are grouped in Suites. Suites are defined using the global `describe()` function:
describe('One suite', function () { describe('One suite', function () {
it('has a test', function () { it('has a test', function () {
... ...
});
it('has another test', function () {
...
});
}); });
it('has another test', function () {
...
});
});
The Suite name is so that reporting is more descriptive. The Suite name is so that reporting is more descriptive.
Suites are executed in the order in which `describe()` calls are made, usually in the order in which their script files are included. Additionally, specs within a suite share a functional scope. So you may declare variables inside a describe block and they are accessible from within your specs. For example: Suites are executed in the order in which `describe()` calls are made, usually in the order in which their script files are included. Additionally, specs within a suite share a functional scope. So you may declare variables inside a describe block and they are accessible from within your specs. For example:
describe('A suite with some variables', function () { describe('A suite with some variables', function () {
var bar = 0 var bar = 0
it('has a test', function () { it('has a test', function () {
bar++; bar++;
expect(bar).toEqual(1); expect(bar).toEqual(1);
});
it('has another test', function () {
bar++;
expect(bar).toEqual(2);
});
}); });
it('has another test', function () {
bar++;
expect(bar).toEqual(2);
});
});
#### beforeEach #### beforeEach
A suite can have a beforeEach declaration. It takes a function that is run before each spec. For example: A suite can have a beforeEach declaration. It takes a function that is run before each spec. For example:
@ -249,26 +251,26 @@ A runner can also have an afterEach declarations. Runner afterEach functions are
Jasmine supports nested describes. An example: Jasmine supports nested describes. An example:
describe('some suite', function () { describe('some suite', function () {
var suiteWideFoo; var suiteWideFoo;
beforeEach(function () { beforeEach(function () {
suiteWideFoo = 0; suiteWideFoo = 0;
}); });
describe('some nested suite', function() { describe('some nested suite', function() {
var nestedSuiteBar; var nestedSuiteBar;
beforeEach(function() { beforeEach(function() {
nestedSuiteBar=1; nestedSuiteBar=1;
}); });
it('nested expectation', function () { it('nested expectation', function () {
expect(suiteWideFoo).toEqual(0); expect(suiteWideFoo).toEqual(0);
expect(nestedSuiteBar).toEqual(1); expect(nestedSuiteBar).toEqual(1);
}); });
}); });
it('top-level describe', function () { it('top-level describe', function () {
expect(suiteWideFoo).toEqual(0); expect(suiteWideFoo).toEqual(0);
expect(nestedSuiteBar).toEqual(undefined); expect(nestedSuiteBar).toEqual(undefined);
@ -414,7 +416,7 @@ multiple `runs()` blocks in a spec will run serially. For example,
`runs()` blocks share functional scope -- `this` properties will be common to all blocks, but declared `var`'s will not! `runs()` blocks share functional scope -- `this` properties will be common to all blocks, but declared `var`'s will not!
it('should be a test', function () { it('should be a test', function () {
runs( function () { runs( function () {
this.foo = 0 this.foo = 0
this.foo++; this.foo++;
@ -437,26 +439,26 @@ multiple `runs()` blocks in a spec will run serially. For example,
`runs()` blocks exist so you can test asynchronous processes. The function `waits()` works with `runs()` to provide a naive `runs()` blocks exist so you can test asynchronous processes. The function `waits()` works with `runs()` to provide a naive
timeout before the next block is run. You supply a time to wait before the next `runs()` function is executed. For example: timeout before the next block is run. You supply a time to wait before the next `runs()` function is executed. For example:
it('should be a test', function () { it('should be a test', function () {
runs(function () { runs(function () {
this.foo = 0; this.foo = 0;
var that = this; var that = this;
setTimeout(function () { setTimeout(function () {
that.foo++; that.foo++;
}, 250); }, 250);
});
runs(function () {
this.expects(this.foo).toEqual(0);
});
waits(500);
runs(function () {
this.expects(this.foo).toEqual(1);
});
}); });
runs(function () {
this.expects(this.foo).toEqual(0);
});
waits(500);
runs(function () {
this.expects(this.foo).toEqual(1);
});
});
What's happening here? What's happening here?
* The first call to `runs()` sets call for 1/4 of a second in the future that increments `this.foo`. * The first call to `runs()` sets call for 1/4 of a second in the future that increments `this.foo`.