Compare commits
3 Commits
master
...
jsdoc-temp
Author | SHA1 | Date | |
---|---|---|---|
|
196a49357b | ||
|
abd020556f | ||
|
138c5081e9 |
3
.gitignore
vendored
@ -1,7 +1,6 @@
|
|||||||
.idea/
|
.idea/
|
||||||
.svn/
|
.svn/
|
||||||
.DS_Store
|
.DS_Store
|
||||||
site/
|
_site/
|
||||||
.bundle/
|
.bundle/
|
||||||
.pairs
|
.pairs
|
||||||
.rvmrc
|
|
||||||
|
4
Gemfile
@ -1,6 +1,6 @@
|
|||||||
source :rubygems
|
source :gemcutter
|
||||||
|
|
||||||
|
gem "jekyll", "0.6.2"
|
||||||
gem "json_pure", "~>1.4.3"
|
gem "json_pure", "~>1.4.3"
|
||||||
gem "frank"
|
|
||||||
gem "ragaskar-jsdoc_helper"
|
gem "ragaskar-jsdoc_helper"
|
||||||
gem "rake", "0.8.7"
|
gem "rake", "0.8.7"
|
||||||
|
33
Gemfile.lock
@ -1,33 +0,0 @@
|
|||||||
GEM
|
|
||||||
remote: http://rubygems.org/
|
|
||||||
specs:
|
|
||||||
daemons (1.0.10)
|
|
||||||
frank (1.0.8)
|
|
||||||
haml (>= 3.0)
|
|
||||||
mongrel (>= 1.2.0.pre2)
|
|
||||||
net-scp (>= 1.0)
|
|
||||||
net-ssh (>= 2.0)
|
|
||||||
rack (>= 1.0)
|
|
||||||
tilt (= 0.9)
|
|
||||||
gem_plugin (0.2.3)
|
|
||||||
haml (3.0.25)
|
|
||||||
json_pure (1.4.6)
|
|
||||||
mongrel (1.2.0.pre2)
|
|
||||||
daemons (~> 1.0.10)
|
|
||||||
gem_plugin (~> 0.2.3)
|
|
||||||
net-scp (1.0.4)
|
|
||||||
net-ssh (>= 1.99.1)
|
|
||||||
net-ssh (2.1.0)
|
|
||||||
rack (1.2.1)
|
|
||||||
ragaskar-jsdoc_helper (0.0.2.1)
|
|
||||||
rake (0.8.7)
|
|
||||||
tilt (0.9)
|
|
||||||
|
|
||||||
PLATFORMS
|
|
||||||
ruby
|
|
||||||
|
|
||||||
DEPENDENCIES
|
|
||||||
frank
|
|
||||||
json_pure (~> 1.4.3)
|
|
||||||
ragaskar-jsdoc_helper
|
|
||||||
rake (= 0.8.7)
|
|
@ -1,42 +0,0 @@
|
|||||||
|
|
||||||
|
|
||||||
## Development
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## Release
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Making a Release of Jasmine Core
|
|
||||||
|
|
||||||
'Jasmine' is the Github repo for Jasmine Core and contains all the JavaScript code for the Jasmine BDD framework.
|
|
||||||
|
|
||||||
It also contains two HTML pages for the Github Pages at http://pivotal.github.com/jasmine.
|
|
||||||
|
|
||||||
## The Repo
|
|
||||||
|
|
||||||
All of the JS for Jasmine is in the src directory. The specs for each file are in the specs directory. There are rake tasks to build the various files for distribution.
|
|
||||||
|
|
||||||
## Running Specs
|
|
||||||
|
|
||||||
There are rake tasks to help with getting green:
|
|
||||||
|
|
||||||
* `rake spec:browser` opens `spec/runner.html` in the default browser. Please run this in at least Firefox and Chrome before comitting
|
|
||||||
* `rake spec:node` runs all the Jasmine specs in Node.js
|
|
||||||
* `rake jasmine:lint` runs all the files through JSHint and will complain about potential viable issues with your code. Fix them.
|
|
||||||
|
|
||||||
## The Pages
|
|
||||||
|
|
||||||
Github pages have to exist in a branch called gh-pages in order for their app to serve them. This repo adds that branch as a submodule under the `pages` directory. This is a bit of a hack, but it allows us to work with the pages and the source at the same time and with one set of rake tasks.
|
|
||||||
|
|
||||||
If you want to submit changes to this repo and aren't a Pivotal Labs employee, you can fork and work in the gh-pages branch. You won't be able to edit the pages in the submodule off of master.
|
|
||||||
|
|
||||||
The pages are built with [Frank](https://github.com/blahed/frank). All the source for these pages live in the pages_source directory.
|
|
||||||
|
|
||||||
## Releasing
|
|
||||||
|
|
||||||
Once all specs are green and you've updated the version in `version.json`, you need to run the rake task to make a distribution: `rake jasmine:dist`.
|
|
@ -1,4 +1,4 @@
|
|||||||
Copyright (c) 2008-2011 Pivotal Labs
|
Copyright (c) 2008-2010 Pivotal Labs
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
a copy of this software and associated documentation files (the
|
a copy of this software and associated documentation files (the
|
||||||
|
@ -2,49 +2,27 @@
|
|||||||
=======
|
=======
|
||||||
**A JavaScript Testing Framework**
|
**A JavaScript Testing Framework**
|
||||||
|
|
||||||
Jasmine is a Behavior Driven Development testing framework for JavaScript. It does not rely on browsers, DOM, or any JavaScript framework. Thus it's suited for websites, [Node.js](http://nodejs.org) projects, or anywhere that JavaScript can run.
|
Want to use Jasmine in a project? Go HERE: [http://pivotal.github.com/jasmine/](http://pivotal.github.com/jasmine/)
|
||||||
|
|
||||||
Documentation & guides live here: [http://pivotal.github.com/jasmine/](http://pivotal.github.com/jasmine/)
|
Want to contribute to Jasmine? Read on...
|
||||||
|
|
||||||
|
<i>(More developer docs to come...)</i>
|
||||||
|
|
||||||
## Support
|
## Support
|
||||||
|
We now have a Google Group for support & discussion.
|
||||||
|
|
||||||
* Search past discussions: [http://groups.google.com/group/jasmine-js](http://groups.google.com/group/jasmine-js)
|
* Discussion: [http://groups.google.com/group/jasmine-js](http://groups.google.com/group/jasmine-js)
|
||||||
* Send an email to the list: [jasmine-js@googlegroups.com](jasmine-js@googlegroups.com)
|
* Group email: [jasmine-js@googlegroups.com](jasmine-js@googlegroups.com)
|
||||||
* Check the current build status: [ci.pivotallabs.com](http://ci.pivotallabs.com)
|
* Current build status of Jasmine is visible at [ci.pivotallabs.com](http://ci.pivotallabs.com)
|
||||||
* View the project backlog at Pivotal Tracker: [http://www.pivotaltracker.com/projects/10606](http://www.pivotaltracker.com/projects/10606)
|
* Pivotal Tracker project: [http://www.pivotaltracker.com/projects/10606](http://www.pivotaltracker.com/projects/10606)
|
||||||
* Follow us on Twitter: [@JasmineBDD](http://twitter.com/JasmineBDD)
|
* Twitter: [@JasmineBDD](http://twitter.com/JasmineBDD)
|
||||||
|
|
||||||
## How to Contribute
|
|
||||||
|
|
||||||
We welcome your contributions - Thanks for helping make Jasmine a better project for everyone. Please review the backlog and discussion lists (the main group - [http://groups.google.com/group/jasmine-js](http://groups.google.com/group/jasmine-js) and the developer's list - [http://groups.google.com/group/jasmine-js-dev](http://groups.google.com/group/jasmine-js-dev)) before starting work - what you're looking for may already have been done. If it hasn't, the community can help make your contribution better.
|
|
||||||
|
|
||||||
### Development Environment
|
|
||||||
|
|
||||||
Jasmine Core relies on Ruby for executing the test suite and building the project for release. The spec suite runs in any major, modern browser (Firefox, Safari, Chrome, and yes various IE's) and in [Node.js](http://nodejs.org). While you probably have browsers installed, you want to make sure that Ruby and Node are present.
|
|
||||||
|
|
||||||
### How to Develop for Jasmine Core
|
|
||||||
|
|
||||||
* Write specs
|
|
||||||
* Make them pass in a browser (or three):
|
|
||||||
* open `spec/runner.html` in your browsers
|
|
||||||
* `rake spec:browser` will run in the default browser on MacOS
|
|
||||||
* Make them pass in Node: `rake spec:node`
|
|
||||||
* Fix any warnings or errors from JSHint: `rake jasmine:lint`
|
|
||||||
|
|
||||||
Running `rake spec` will run the browser tests, then run specs in Node, then run JSHint. But this will only run in the default browser and only on MacOS (for now).
|
|
||||||
|
|
||||||
|
|
||||||
### Making a Successful Pull Request
|
|
||||||
|
|
||||||
* __Include specs for your work__ - it helps us understand your intent and makes sure that future development doesn't break your work
|
|
||||||
* __Ensure the full test suite is green__ in all the big browsers, Node, and JSHint - your contribution shouldn't break Jasmine for other users
|
|
||||||
|
|
||||||
Do these things and we'll take a look.
|
|
||||||
|
|
||||||
## Maintainers
|
## Maintainers
|
||||||
|
|
||||||
* [Davis W. Frank](mailto:dwfrank@pivotallabs.com), Pivotal Labs
|
* [Davis W. Frank](mailto:dwfrank@pivotallabs.com), Pivotal Labs
|
||||||
* [Rajan Agaskar](mailto:rajan@pivotallabs.com), Pivotal Labs
|
* [Rajan Agaskar](mailto:rajan@pivotallabs.com), Pivotal Labs
|
||||||
* [Christian Williams](mailto:antixian666@gmail.com), Square
|
* [Christian Williams](mailto:xian@pivotallabs.com), Pivotal Labs
|
||||||
|
|
||||||
Copyright (c) 2008-2011 Pivotal Labs. This software is licensed under the MIT License.
|
## Developers
|
||||||
|
We welcome your contributions! Jasmine is currently maintained by Davis Frank ([infews](http://github.com/infews)), Rajan Agaskar ([ragaskar](http://github.com/ragaskar)), and Christian Williams ([Xian](http://github.com/Xian)). You can help us by removing all other recipients from your pull request.
|
||||||
|
|
||||||
|
Copyright (c) 2008-2010 Pivotal Labs. This software is licensed under the MIT License.
|
||||||
|
108
Rakefile
@ -1,10 +1,6 @@
|
|||||||
require 'json'
|
|
||||||
|
|
||||||
def jasmine_sources
|
def jasmine_sources
|
||||||
first_sources = JSON.parse(File.read('src/SourcesList.json')).collect {|f| "src/core/#{f}"}
|
sources = ["src/base.js", "src/util.js", "src/Env.js", "src/Reporter.js", "src/Block.js"]
|
||||||
|
sources += Dir.glob('src/*.js').reject { |f| f == 'src/base.js' || sources.include?(f) }.sort
|
||||||
sources = first_sources
|
|
||||||
sources += Dir.glob('src/core/*.js').reject {|f| first_sources.include?(f)}.sort
|
|
||||||
sources
|
sources
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -18,9 +14,10 @@ end
|
|||||||
|
|
||||||
def version_hash
|
def version_hash
|
||||||
require 'json'
|
require 'json'
|
||||||
@version ||= JSON.parse(File.new("src/core/version.json").read);
|
@version ||= JSON.parse(File.new("src/version.json").read);
|
||||||
end
|
end
|
||||||
|
|
||||||
|
task :default => 'jasmine:dist'
|
||||||
|
|
||||||
def substitute_jasmine_version(filename)
|
def substitute_jasmine_version(filename)
|
||||||
contents = File.read(filename)
|
contents = File.read(filename)
|
||||||
@ -29,40 +26,36 @@ def substitute_jasmine_version(filename)
|
|||||||
File.open(filename, 'w') { |f| f.write(contents) }
|
File.open(filename, 'w') { |f| f.write(contents) }
|
||||||
end
|
end
|
||||||
|
|
||||||
task :default => :spec
|
|
||||||
|
|
||||||
desc "Run spec suite: Browser, Node, JSHint"
|
|
||||||
task :spec => ["jasmine:build", "spec:node", "spec:browser"]
|
|
||||||
|
|
||||||
namespace :spec do
|
|
||||||
desc 'Run specs in Node.js'
|
|
||||||
task :node do
|
|
||||||
raise "Node is required to run all jasmine specs" unless system("node spec/node_suite.js")
|
|
||||||
end
|
|
||||||
|
|
||||||
desc "Run specs in the default browser (MacOS only)"
|
|
||||||
task :browser do
|
|
||||||
system("open spec/runner.html")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
namespace :jasmine do
|
namespace :jasmine do
|
||||||
|
|
||||||
desc 'Prepares for distribution'
|
desc 'Prepares for distribution'
|
||||||
task :dist => ['jasmine:build',
|
task :dist => ['jasmine:build', 'jasmine:doc', 'jasmine:build_example_project', 'jasmine:fill_index_downloads']
|
||||||
'jasmine:doc',
|
|
||||||
'jasmine:build_pages',
|
|
||||||
'jasmine:build_example_project',
|
|
||||||
'jasmine:fill_index_downloads']
|
|
||||||
|
|
||||||
desc 'Check jasmine sources for coding problems'
|
desc 'Check jasmine sources for coding problems'
|
||||||
task :lint do
|
task :lint do
|
||||||
puts "Running JSHint via Node.js"
|
passed = true
|
||||||
system("node jshint/run.js") || exit(1)
|
jasmine_sources.each do |src|
|
||||||
|
lines = File.read(src).split(/\n/)
|
||||||
|
lines.each_index do |i|
|
||||||
|
line = lines[i]
|
||||||
|
undefineds = line.scan(/.?undefined/)
|
||||||
|
if undefineds.include?(" undefined") || undefineds.include?("\tundefined")
|
||||||
|
puts "Dangerous undefined at #{src}:#{i}:\n > #{line}"
|
||||||
|
passed = false
|
||||||
end
|
end
|
||||||
|
|
||||||
desc "Alias to JSHint"
|
if line.scan(/window/).length > 0
|
||||||
task :hint => :lint
|
puts "Dangerous window at #{src}:#{i}:\n > #{line}"
|
||||||
|
passed = false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
unless passed
|
||||||
|
puts "Lint failed!"
|
||||||
|
exit 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
desc 'Builds lib/jasmine from source'
|
desc 'Builds lib/jasmine from source'
|
||||||
task :build => :lint do
|
task :build => :lint do
|
||||||
@ -71,6 +64,9 @@ namespace :jasmine do
|
|||||||
sources = jasmine_sources
|
sources = jasmine_sources
|
||||||
version = version_hash
|
version = version_hash
|
||||||
|
|
||||||
|
old_jasmine_files = Dir.glob('lib/jasmine*.js')
|
||||||
|
old_jasmine_files.each { |file| File.delete(file) }
|
||||||
|
|
||||||
File.open("lib/jasmine.js", 'w') do |jasmine|
|
File.open("lib/jasmine.js", 'w') do |jasmine|
|
||||||
sources.each do |source_filename|
|
sources.each do |source_filename|
|
||||||
jasmine.puts(File.read(source_filename))
|
jasmine.puts(File.read(source_filename))
|
||||||
@ -95,25 +91,12 @@ jasmine.version_= {
|
|||||||
FileUtils.cp("src/html/jasmine.css", "lib/jasmine.css")
|
FileUtils.cp("src/html/jasmine.css", "lib/jasmine.css")
|
||||||
end
|
end
|
||||||
|
|
||||||
downloads_file = 'pages/download.html'
|
|
||||||
task :need_pages_submodule do
|
task :need_pages_submodule do
|
||||||
unless File.exist?(downloads_file)
|
unless File.exists?('pages/index.html.md')
|
||||||
raise "Jasmine pages submodule isn't present. Run git submodule update --init"
|
raise "Jasmine pages submodule isn't present. Run git submodule update --init"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
desc "Build the Github pages HTML"
|
|
||||||
task :build_pages => :need_pages_submodule do
|
|
||||||
Dir.chdir("pages") do
|
|
||||||
FileUtils.rm_r('pages_output') if File.exist?('pages_output')
|
|
||||||
Dir.chdir('pages_source') do
|
|
||||||
system("frank export ../pages_output")
|
|
||||||
end
|
|
||||||
puts "\nCopying Frank output to the root of the gh-pages branch\n\n"
|
|
||||||
system("cp -r pages_output/* .")
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
desc "Build jasmine documentation"
|
desc "Build jasmine documentation"
|
||||||
task :doc => :need_pages_submodule do
|
task :doc => :need_pages_submodule do
|
||||||
puts 'Creating Jasmine Documentation'
|
puts 'Creating Jasmine Documentation'
|
||||||
@ -138,7 +121,7 @@ jasmine.version_= {
|
|||||||
|
|
||||||
temp_dir = File.join(Dir.tmpdir, 'jasmine-standalone-project')
|
temp_dir = File.join(Dir.tmpdir, 'jasmine-standalone-project')
|
||||||
puts "Building Example Project in #{temp_dir}"
|
puts "Building Example Project in #{temp_dir}"
|
||||||
FileUtils.rm_r temp_dir if File.exist?(temp_dir)
|
FileUtils.rm_r temp_dir if File.exists?(temp_dir)
|
||||||
Dir.mkdir(temp_dir)
|
Dir.mkdir(temp_dir)
|
||||||
|
|
||||||
root = File.expand_path(File.dirname(__FILE__))
|
root = File.expand_path(File.dirname(__FILE__))
|
||||||
@ -167,4 +150,33 @@ jasmine.version_= {
|
|||||||
exec "cd #{temp_dir} && zip -r #{zip_file_name} . -x .[a-zA-Z0-9]*"
|
exec "cd #{temp_dir} && zip -r #{zip_file_name} . -x .[a-zA-Z0-9]*"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
task :fill_index_downloads do
|
||||||
|
require 'digest/sha1'
|
||||||
|
|
||||||
|
download_html = "<!-- START_DOWNLOADS -->\n"
|
||||||
|
download_html += "<table id=\"standalone-downloads\">\n<tr><th></th><th>Version</th><th>Size</th><th>Date</th><th>SHA1</th></tr>\n"
|
||||||
|
Dir.glob('pages/downloads/*.zip').sort.reverse.each do |f|
|
||||||
|
sha1 = Digest::SHA1.hexdigest File.read(f)
|
||||||
|
|
||||||
|
fn = f.sub(/^pages\//, '')
|
||||||
|
version = /jasmine-standalone-(.*).zip/.match(f)[1]
|
||||||
|
prerelease = /\.rc/.match(f)
|
||||||
|
download_html += prerelease ? "<tr class=\"rc\">\n" : "<tr>\n"
|
||||||
|
download_html += "<td class=\"link\"><a href='#{fn}'>#{fn.sub(/downloads\//, '')}</a></td>\n"
|
||||||
|
download_html += "<td class=\"version\">#{version}</td>\n"
|
||||||
|
download_html += "<td class=\"size\">#{File.size(f) / 1024}k</td>\n"
|
||||||
|
download_html += "<td class=\"date\">#{File.mtime(f).strftime("%Y/%m/%d %H:%M:%S %Z")}</td>\n"
|
||||||
|
download_html += "<td class=\"sha\">#{sha1}</td>\n"
|
||||||
|
download_html += "</tr>\n"
|
||||||
|
end
|
||||||
|
download_html += "</table>\n<!-- END_DOWNLOADS -->"
|
||||||
|
|
||||||
|
index_page = File.read('pages/index.html')
|
||||||
|
matcher = /<!-- START_DOWNLOADS -->.*<!-- END_DOWNLOADS -->/m
|
||||||
|
index_page = index_page.sub(matcher, download_html)
|
||||||
|
File.open('pages/index.html', 'w') {|f| f.write(index_page)}
|
||||||
|
puts "rewrote that file"
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
task :jasmine => ['jasmine:dist']
|
||||||
|
@ -2,8 +2,8 @@ beforeEach(function() {
|
|||||||
this.addMatchers({
|
this.addMatchers({
|
||||||
toBePlaying: function(expectedSong) {
|
toBePlaying: function(expectedSong) {
|
||||||
var player = this.actual;
|
var player = this.actual;
|
||||||
return player.currentlyPlayingSong === expectedSong &&
|
return player.currentlyPlayingSong === expectedSong
|
||||||
player.isPlaying;
|
&& player.isPlaying;
|
||||||
}
|
}
|
||||||
});
|
})
|
||||||
});
|
});
|
||||||
|
BIN
images/fail-16.png
Executable file
After Width: | Height: | Size: 722 B |
BIN
images/fail.png
Executable file
After Width: | Height: | Size: 2.1 KiB |
BIN
images/go-16.png
Normal file
After Width: | Height: | Size: 759 B |
BIN
images/go.png
Normal file
After Width: | Height: | Size: 2.2 KiB |
Before Width: | Height: | Size: 905 B |
BIN
images/pending-16.png
Executable file
After Width: | Height: | Size: 802 B |
BIN
images/pending.png
Executable file
After Width: | Height: | Size: 2.7 KiB |
BIN
images/question-bk.png
Executable file
After Width: | Height: | Size: 2.5 KiB |
BIN
images/questionbk-16.png
Executable file
After Width: | Height: | Size: 768 B |
BIN
images/spinner.gif
Executable file
After Width: | Height: | Size: 1.7 KiB |
@ -1,25 +1,19 @@
|
|||||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
---
|
||||||
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
layout: default
|
||||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
title: "API - File Index"
|
||||||
<head>
|
jdsoc_template: allfiles.tmpl
|
||||||
<meta http-equiv="content-type" content="text/html; charset={+IO.encoding+}"" />
|
---
|
||||||
{! Link.base = ""; /* all generated links will be relative to this */ !}
|
|
||||||
<title>JsDoc Reference - File Index</title>
|
|
||||||
<meta name="generator" content="JsDoc Toolkit" />
|
|
||||||
|
|
||||||
<style type="text/css">
|
{! Link.base = ""; /* all generated links will be relative to this */ !}
|
||||||
{+include("static/default.css")+}
|
<style type="text/css">
|
||||||
</style>
|
{+include("static/default.css")+}
|
||||||
</head>
|
</style>
|
||||||
|
|
||||||
<body>
|
<div id="index">
|
||||||
{+include("static/header.html")+}
|
|
||||||
|
|
||||||
<div id="index">
|
|
||||||
{+publish.classesIndex+}
|
{+publish.classesIndex+}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="content">
|
<div id="content">
|
||||||
<h1 class="classTitle">File Index</h1>
|
<h1 class="classTitle">File Index</h1>
|
||||||
|
|
||||||
<for each="item" in="data">
|
<for each="item" in="data">
|
||||||
@ -47,10 +41,9 @@
|
|||||||
<hr />
|
<hr />
|
||||||
</for>
|
</for>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="fineprint" style="clear:both">
|
|
||||||
|
<div class="fineprint" style="clear:both">
|
||||||
<if test="JSDOC.opt.D.copyright">©{+JSDOC.opt.D.copyright+}<br /></if>
|
<if test="JSDOC.opt.D.copyright">©{+JSDOC.opt.D.copyright+}<br /></if>
|
||||||
Documentation generated by <a href="http://www.jsdoctoolkit.org/" target="_blankt">JsDoc Toolkit</a> {+JSDOC.VERSION+} on {+new Date()+}
|
Documentation generated by <a href="http://www.jsdoctoolkit.org/" target="_blankt">JsDoc Toolkit</a> {+JSDOC.VERSION+} on {+new Date()+}
|
||||||
</div>
|
</div>
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
|
@ -1,33 +1,24 @@
|
|||||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
---
|
||||||
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
layout: default
|
||||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
title: "API - {+data.alias+}"
|
||||||
<head>
|
jdsoc_template: class.tmpl
|
||||||
<meta http-equiv="content-type" content="text/html; charset={+IO.encoding+}" />
|
---
|
||||||
<meta name="generator" content="JsDoc Toolkit" />
|
|
||||||
{! Link.base = "../"; /* all generated links will be relative to this */ !}
|
|
||||||
<title>JsDoc Reference - {+data.alias+}</title>
|
|
||||||
|
|
||||||
<style type="text/css">
|
{! Link.base = "../"; /* all generated links will be relative to this */ !}
|
||||||
|
<style type="text/css">
|
||||||
{+include("static/default.css")+}
|
{+include("static/default.css")+}
|
||||||
</style>
|
</style>
|
||||||
</head>
|
|
||||||
|
|
||||||
<body>
|
|
||||||
<!-- ============================== header ================================= -->
|
|
||||||
<!-- begin static/header.html -->
|
|
||||||
{+include("static/header.html")+}
|
|
||||||
<!-- end static/header.html -->
|
|
||||||
|
|
||||||
<!-- ============================== classes index ============================ -->
|
<!-- ============================== classes index ============================ -->
|
||||||
<div id="index">
|
<div id="index">
|
||||||
<!-- begin publish.classesIndex -->
|
<!-- begin publish.classesIndex -->
|
||||||
{+publish.classesIndex+}
|
{+publish.classesIndex+}
|
||||||
<!-- end publish.classesIndex -->
|
<!-- end publish.classesIndex -->
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="content">
|
<div id="content">
|
||||||
<!-- ============================== class title ============================ -->
|
<!-- ============================== class title ============================ -->
|
||||||
<h1 class="classTitle">
|
<h1 class="classTitle">
|
||||||
{!
|
{!
|
||||||
var classType = "";
|
var classType = "";
|
||||||
|
|
||||||
@ -46,10 +37,10 @@
|
|||||||
}
|
}
|
||||||
!}
|
!}
|
||||||
{+classType+}{+data.alias+}
|
{+classType+}{+data.alias+}
|
||||||
</h1>
|
</h1>
|
||||||
|
|
||||||
<!-- ============================== class summary ========================== -->
|
<!-- ============================== class summary ========================== -->
|
||||||
<p class="description">
|
<p class="description">
|
||||||
<if test="data.augments.length"><br />Extends
|
<if test="data.augments.length"><br />Extends
|
||||||
{+
|
{+
|
||||||
data.augments
|
data.augments
|
||||||
@ -66,11 +57,11 @@
|
|||||||
<if test="!data.isBuiltin()">{# isn't defined in any file #}
|
<if test="!data.isBuiltin()">{# isn't defined in any file #}
|
||||||
<br /><i>Defined in: </i> {+new Link().toSrc(data.srcFile)+}.
|
<br /><i>Defined in: </i> {+new Link().toSrc(data.srcFile)+}.
|
||||||
</if>
|
</if>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
<!-- ============================== constructor summary ==================== -->
|
<!-- ============================== constructor summary ==================== -->
|
||||||
<if test="!data.isBuiltin() && (data.isNamespace || data.is('CONSTRUCTOR'))">
|
<if test="!data.isBuiltin() && (data.isNamespace || data.is('CONSTRUCTOR'))">
|
||||||
<table class="summaryTable" cellspacing="0" summary="A summary of the constructor documented in the class {+data.alias+}.">
|
<table class="summaryTable" cellspacing="0" summary="A summary of the constructor documented in the class {+data.alias+}.">
|
||||||
<caption>{+classType+}Summary</caption>
|
<caption>{+classType+}Summary</caption>
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
@ -92,11 +83,11 @@
|
|||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
</if>
|
</if>
|
||||||
|
|
||||||
<!-- ============================== properties summary ===================== -->
|
<!-- ============================== properties summary ===================== -->
|
||||||
<if test="data.properties.length">
|
<if test="data.properties.length">
|
||||||
{! var ownProperties = data.properties.filter(function($){return $.memberOf == data.alias && !$.isNamespace}).sort(makeSortby("name")); !}
|
{! var ownProperties = data.properties.filter(function($){return $.memberOf == data.alias && !$.isNamespace}).sort(makeSortby("name")); !}
|
||||||
<if test="ownProperties.length">
|
<if test="ownProperties.length">
|
||||||
<table class="summaryTable" cellspacing="0" summary="A summary of the fields documented in the class {+data.alias+}.">
|
<table class="summaryTable" cellspacing="0" summary="A summary of the fields documented in the class {+data.alias+}.">
|
||||||
@ -155,10 +146,10 @@
|
|||||||
!}
|
!}
|
||||||
</dl>
|
</dl>
|
||||||
</if>
|
</if>
|
||||||
</if>
|
</if>
|
||||||
|
|
||||||
<!-- ============================== methods summary ======================== -->
|
<!-- ============================== methods summary ======================== -->
|
||||||
<if test="data.methods.length">
|
<if test="data.methods.length">
|
||||||
{! var ownMethods = data.methods.filter(function($){return $.memberOf == data.alias && !$.isNamespace}).sort(makeSortby("name")); !}
|
{! var ownMethods = data.methods.filter(function($){return $.memberOf == data.alias && !$.isNamespace}).sort(makeSortby("name")); !}
|
||||||
<if test="ownMethods.length">
|
<if test="ownMethods.length">
|
||||||
<table class="summaryTable" cellspacing="0" summary="A summary of the methods documented in the class {+data.alias+}.">
|
<table class="summaryTable" cellspacing="0" summary="A summary of the methods documented in the class {+data.alias+}.">
|
||||||
@ -215,9 +206,9 @@
|
|||||||
!}
|
!}
|
||||||
</dl>
|
</dl>
|
||||||
</if>
|
</if>
|
||||||
</if>
|
</if>
|
||||||
<!-- ============================== events summary ======================== -->
|
<!-- ============================== events summary ======================== -->
|
||||||
<if test="data.events.length">
|
<if test="data.events.length">
|
||||||
{! var ownEvents = data.events.filter(function($){return $.memberOf == data.alias && !$.isNamespace}).sort(makeSortby("name")); !}
|
{! var ownEvents = data.events.filter(function($){return $.memberOf == data.alias && !$.isNamespace}).sort(makeSortby("name")); !}
|
||||||
<if test="ownEvents.length">
|
<if test="ownEvents.length">
|
||||||
<table class="summaryTable" cellspacing="0" summary="A summary of the events documented in the class {+data.alias+}.">
|
<table class="summaryTable" cellspacing="0" summary="A summary of the events documented in the class {+data.alias+}.">
|
||||||
@ -274,11 +265,11 @@
|
|||||||
!}
|
!}
|
||||||
</dl>
|
</dl>
|
||||||
</if>
|
</if>
|
||||||
</if>
|
</if>
|
||||||
|
|
||||||
<!-- ============================== constructor details ==================== -->
|
<!-- ============================== constructor details ==================== -->
|
||||||
<if test="!data.isBuiltin() && (data.isNamespace || data.is('CONSTRUCTOR'))">
|
<if test="!data.isBuiltin() && (data.isNamespace || data.is('CONSTRUCTOR'))">
|
||||||
<div class="details"><a name="constructor"> </a>
|
<div class="details"><a name="constructor"> </a>
|
||||||
<div class="sectionTitle">
|
<div class="sectionTitle">
|
||||||
{+classType+}Detail
|
{+classType+}Detail
|
||||||
</div>
|
</div>
|
||||||
@ -364,11 +355,11 @@
|
|||||||
</dl>
|
</dl>
|
||||||
</if>
|
</if>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</if>
|
</if>
|
||||||
|
|
||||||
<!-- ============================== field details ========================== -->
|
<!-- ============================== field details ========================== -->
|
||||||
<if test="defined(ownProperties) && ownProperties.length">
|
<if test="defined(ownProperties) && ownProperties.length">
|
||||||
<div class="sectionTitle">
|
<div class="sectionTitle">
|
||||||
Field Detail
|
Field Detail
|
||||||
</div>
|
</div>
|
||||||
@ -433,10 +424,10 @@
|
|||||||
|
|
||||||
<if test="!$member_last"><hr /></if>
|
<if test="!$member_last"><hr /></if>
|
||||||
</for>
|
</for>
|
||||||
</if>
|
</if>
|
||||||
|
|
||||||
<!-- ============================== method details ========================= -->
|
<!-- ============================== method details ========================= -->
|
||||||
<if test="defined(ownMethods) && ownMethods.length">
|
<if test="defined(ownMethods) && ownMethods.length">
|
||||||
<div class="sectionTitle">
|
<div class="sectionTitle">
|
||||||
Method Detail
|
Method Detail
|
||||||
</div>
|
</div>
|
||||||
@ -532,10 +523,10 @@
|
|||||||
|
|
||||||
<if test="!$member_last"><hr /></if>
|
<if test="!$member_last"><hr /></if>
|
||||||
</for>
|
</for>
|
||||||
</if>
|
</if>
|
||||||
|
|
||||||
<!-- ============================== event details ========================= -->
|
<!-- ============================== event details ========================= -->
|
||||||
<if test="defined(ownEvents) && ownEvents.length">
|
<if test="defined(ownEvents) && ownEvents.length">
|
||||||
<div class="sectionTitle">
|
<div class="sectionTitle">
|
||||||
Event Detail
|
Event Detail
|
||||||
</div>
|
</div>
|
||||||
@ -631,10 +622,10 @@
|
|||||||
|
|
||||||
<if test="!$member_last"><hr /></if>
|
<if test="!$member_last"><hr /></if>
|
||||||
</for>
|
</for>
|
||||||
</if>
|
</if>
|
||||||
|
|
||||||
<hr />
|
<hr />
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
<!-- ============================== footer ================================= -->
|
<!-- ============================== footer ================================= -->
|
||||||
@ -642,5 +633,3 @@
|
|||||||
<if test="JSDOC.opt.D.copyright">©{+JSDOC.opt.D.copyright+}<br /></if>
|
<if test="JSDOC.opt.D.copyright">©{+JSDOC.opt.D.copyright+}<br /></if>
|
||||||
Documentation generated by <a href="http://www.jsdoctoolkit.org/" target="_blank">JsDoc Toolkit</a> {+JSDOC.VERSION+} on {+new Date()+}
|
Documentation generated by <a href="http://www.jsdoctoolkit.org/" target="_blank">JsDoc Toolkit</a> {+JSDOC.VERSION+} on {+new Date()+}
|
||||||
</div>
|
</div>
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
|
@ -1,25 +1,18 @@
|
|||||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
|
---
|
||||||
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
layout: default
|
||||||
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
|
title: "API - Index"
|
||||||
<head>
|
jdsoc_template: index.tmpl
|
||||||
<meta http-equiv="content-type" content="text/html; charset={+IO.encoding+}"" />
|
---
|
||||||
|
|
||||||
<title>JsDoc Reference - Index</title>
|
<style type="text/css">
|
||||||
<meta name="generator" content="JsDoc Toolkit" />
|
{+include("static/default.css")+}
|
||||||
|
</style>
|
||||||
|
|
||||||
<style type="text/css">
|
<div id="index">
|
||||||
{+include("static/default.css")+}
|
|
||||||
</style>
|
|
||||||
</head>
|
|
||||||
|
|
||||||
<body>
|
|
||||||
{+include("static/header.html")+}
|
|
||||||
|
|
||||||
<div id="index">
|
|
||||||
{+publish.classesIndex+}
|
{+publish.classesIndex+}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="content">
|
<div id="content">
|
||||||
<h1 class="classTitle">Class Index</h1>
|
<h1 class="classTitle">Class Index</h1>
|
||||||
|
|
||||||
<for each="thisClass" in="data">
|
<for each="thisClass" in="data">
|
||||||
@ -30,10 +23,9 @@
|
|||||||
<hr />
|
<hr />
|
||||||
</for>
|
</for>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div class="fineprint" style="clear:both">
|
|
||||||
|
<div class="fineprint" style="clear:both">
|
||||||
<if test="JSDOC.opt.D.copyright">©{+JSDOC.opt.D.copyright+}<br /></if>
|
<if test="JSDOC.opt.D.copyright">©{+JSDOC.opt.D.copyright+}<br /></if>
|
||||||
Documentation generated by <a href="http://www.jsdoctoolkit.org/" target="_blankt">JsDoc Toolkit</a> {+JSDOC.VERSION+} on {+new Date()+}
|
Documentation generated by <a href="http://www.jsdoctoolkit.org/" target="_blankt">JsDoc Toolkit</a> {+JSDOC.VERSION+} on {+new Date()+}
|
||||||
</div>
|
</div>
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -64,7 +64,7 @@ function publish(symbolSet) {
|
|||||||
var output = "";
|
var output = "";
|
||||||
output = classTemplate.process(symbol);
|
output = classTemplate.process(symbol);
|
||||||
|
|
||||||
IO.saveFile(publish.conf.outDir+"symbols/", symbol.alias+publish.conf.ext, output);
|
IO.saveFile(publish.conf.outDir+"symbols/", symbol.alias+publish.conf.ext+".md", output);
|
||||||
}
|
}
|
||||||
|
|
||||||
// regenerate the index with different relative links, used in the index pages
|
// regenerate the index with different relative links, used in the index pages
|
||||||
@ -78,7 +78,7 @@ function publish(symbolSet) {
|
|||||||
catch(e) { print(e.message); quit(); }
|
catch(e) { print(e.message); quit(); }
|
||||||
|
|
||||||
var classesIndex = classesindexTemplate.process(classes);
|
var classesIndex = classesindexTemplate.process(classes);
|
||||||
IO.saveFile(publish.conf.outDir, "index"+publish.conf.ext, classesIndex);
|
IO.saveFile(publish.conf.outDir, "index"+publish.conf.ext+".md", classesIndex);
|
||||||
classesindexTemplate = classesIndex = classes = null;
|
classesindexTemplate = classesIndex = classes = null;
|
||||||
|
|
||||||
// create the file index page
|
// create the file index page
|
||||||
@ -103,7 +103,7 @@ function publish(symbolSet) {
|
|||||||
|
|
||||||
// output the file index page
|
// output the file index page
|
||||||
var filesIndex = fileindexTemplate.process(allFiles);
|
var filesIndex = fileindexTemplate.process(allFiles);
|
||||||
IO.saveFile(publish.conf.outDir, "files"+publish.conf.ext, filesIndex);
|
IO.saveFile(publish.conf.outDir, "files"+publish.conf.ext+".md", filesIndex);
|
||||||
fileindexTemplate = filesIndex = files = null;
|
fileindexTemplate = filesIndex = files = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -149,7 +149,7 @@ function makeSrcFile(path, srcDir, name) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (src.hilited) {
|
if (src.hilited) {
|
||||||
IO.saveFile(srcDir, name+publish.conf.ext, src.hilited);
|
IO.saveFile(srcDir, name+publish.conf.ext+".md", src.hilited);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
5919
jshint/jshint.js
@ -1,99 +0,0 @@
|
|||||||
var fs = require("fs");
|
|
||||||
var sys = require("sys");
|
|
||||||
var path = require("path");
|
|
||||||
var JSHINT = require("./jshint").JSHINT;
|
|
||||||
|
|
||||||
// DWF TODO: Standardize this?
|
|
||||||
function isExcluded(fullPath) {
|
|
||||||
var fileName = path.basename(fullPath);
|
|
||||||
var excludeFiles = ["json2.js", "jshint.js", "publish.js", "node_suite.js", "jasmine.js", "jasmine-html.js"];
|
|
||||||
for (var i = 0; i < excludeFiles.length; i++) {
|
|
||||||
if (fileName == excludeFiles[i]) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// DWF TODO: This function could/should be re-written
|
|
||||||
function allJasmineJsFiles(rootDir) {
|
|
||||||
var files = [];
|
|
||||||
fs.readdirSync(rootDir).filter(function(filename) {
|
|
||||||
|
|
||||||
var fullPath = rootDir + "/" + filename;
|
|
||||||
if (fs.statSync(fullPath).isDirectory() && !fullPath.match(/pages/)) {
|
|
||||||
var subDirFiles = allJasmineJsFiles(fullPath);
|
|
||||||
if (subDirFiles.length > 0) {
|
|
||||||
files = files.concat();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (fullPath.match(/\.js$/) && !isExcluded(fullPath)) {
|
|
||||||
files.push(fullPath);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
|
|
||||||
return files;
|
|
||||||
}
|
|
||||||
|
|
||||||
var jasmineJsFiles = allJasmineJsFiles(".");
|
|
||||||
jasmineJsFiles.reverse(); //cheap way to do the stuff in src stuff first
|
|
||||||
|
|
||||||
var jasmineJsHintConfig = {
|
|
||||||
|
|
||||||
forin:true, //while it's possible that we could be
|
|
||||||
//considering unwanted prototype methods, mostly
|
|
||||||
//we're doing this because the jsobjects are being
|
|
||||||
//used as maps.
|
|
||||||
|
|
||||||
loopfunc:true //we're fine with functions defined inside loops (setTimeout functions, etc)
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
var jasmineGlobals = {};
|
|
||||||
|
|
||||||
|
|
||||||
//jasmine.undefined is a jasmine-ism, let's let it go...
|
|
||||||
function removeJasmineUndefinedErrors(errors) {
|
|
||||||
var keepErrors = [];
|
|
||||||
for (var i = 0; i < errors.length; i++) {
|
|
||||||
if (!(errors[i] &&
|
|
||||||
errors[i].raw &&
|
|
||||||
errors[i].evidence &&
|
|
||||||
( errors[i].evidence.match(/jasmine\.undefined/) ||
|
|
||||||
errors[i].evidence.match(/diz be undefined yo/) )
|
|
||||||
)) {
|
|
||||||
keepErrors.push(errors[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return keepErrors;
|
|
||||||
}
|
|
||||||
|
|
||||||
(function() {
|
|
||||||
var ansi = {
|
|
||||||
green: '\033[32m',
|
|
||||||
red: '\033[31m',
|
|
||||||
yellow: '\033[33m',
|
|
||||||
none: '\033[0m'
|
|
||||||
};
|
|
||||||
|
|
||||||
for (var i = 0; i < jasmineJsFiles.length; i++) {
|
|
||||||
var file = jasmineJsFiles[i];
|
|
||||||
JSHINT(fs.readFileSync(file, "utf8"), jasmineJsHintConfig);
|
|
||||||
var errors = JSHINT.data().errors || [];
|
|
||||||
errors = removeJasmineUndefinedErrors(errors);
|
|
||||||
|
|
||||||
if (errors.length >= 1) {
|
|
||||||
console.log(ansi.red + "Jasmine JSHint failure: " + ansi.none);
|
|
||||||
console.log(file);
|
|
||||||
console.log(errors);
|
|
||||||
process.exit(1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log(ansi.green + "Jasmine JSHint PASSED." + ansi.none);
|
|
||||||
})();
|
|
||||||
|
|
@ -70,16 +70,16 @@ jasmine.TrivialReporter.prototype.reportRunnerStarting = function(runner) {
|
|||||||
this.startedAt = new Date();
|
this.startedAt = new Date();
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
showPassed.onclick = function(evt) {
|
showPassed.onchange = function(evt) {
|
||||||
if (showPassed.checked) {
|
if (evt.target.checked) {
|
||||||
self.outerDiv.className += ' show-passed';
|
self.outerDiv.className += ' show-passed';
|
||||||
} else {
|
} else {
|
||||||
self.outerDiv.className = self.outerDiv.className.replace(/ show-passed/, '');
|
self.outerDiv.className = self.outerDiv.className.replace(/ show-passed/, '');
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
showSkipped.onclick = function(evt) {
|
showSkipped.onchange = function(evt) {
|
||||||
if (showSkipped.checked) {
|
if (evt.target.checked) {
|
||||||
self.outerDiv.className += ' show-skipped';
|
self.outerDiv.className += ' show-skipped';
|
||||||
} else {
|
} else {
|
||||||
self.outerDiv.className = self.outerDiv.className.replace(/ show-skipped/, '');
|
self.outerDiv.className = self.outerDiv.className.replace(/ show-skipped/, '');
|
||||||
@ -110,7 +110,7 @@ jasmine.TrivialReporter.prototype.reportRunnerResults = function(runner) {
|
|||||||
jasmine.TrivialReporter.prototype.reportSuiteResults = function(suite) {
|
jasmine.TrivialReporter.prototype.reportSuiteResults = function(suite) {
|
||||||
var results = suite.results();
|
var results = suite.results();
|
||||||
var status = results.passed() ? 'passed' : 'failed';
|
var status = results.passed() ? 'passed' : 'failed';
|
||||||
if (results.totalCount === 0) { // todo: change this to check results.skipped
|
if (results.totalCount == 0) { // todo: change this to check results.skipped
|
||||||
status = 'skipped';
|
status = 'skipped';
|
||||||
}
|
}
|
||||||
this.suiteDivs[suite.id].className += " " + status;
|
this.suiteDivs[suite.id].className += " " + status;
|
||||||
@ -162,13 +162,7 @@ jasmine.TrivialReporter.prototype.reportSpecResults = function(spec) {
|
|||||||
|
|
||||||
jasmine.TrivialReporter.prototype.log = function() {
|
jasmine.TrivialReporter.prototype.log = function() {
|
||||||
var console = jasmine.getGlobal().console;
|
var console = jasmine.getGlobal().console;
|
||||||
if (console && console.log) {
|
if (console && console.log) console.log.apply(console, arguments);
|
||||||
if (console.log.apply) {
|
|
||||||
console.log.apply(console, arguments);
|
|
||||||
} else {
|
|
||||||
console.log(arguments); // ie fix: console.log.apply doesn't exist on ie
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
jasmine.TrivialReporter.prototype.getLocation = function() {
|
jasmine.TrivialReporter.prototype.getLocation = function() {
|
||||||
@ -183,8 +177,6 @@ jasmine.TrivialReporter.prototype.specFilter = function(spec) {
|
|||||||
paramMap[decodeURIComponent(p[0])] = decodeURIComponent(p[1]);
|
paramMap[decodeURIComponent(p[0])] = decodeURIComponent(p[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!paramMap.spec) {
|
if (!paramMap["spec"]) return true;
|
||||||
return true;
|
return spec.getFullName().indexOf(paramMap["spec"]) == 0;
|
||||||
}
|
|
||||||
return spec.getFullName().indexOf(paramMap.spec) === 0;
|
|
||||||
};
|
};
|
||||||
|
124
lib/jasmine.js
@ -1,12 +1,10 @@
|
|||||||
var isCommonJS = typeof window == "undefined";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Top level namespace for Jasmine, a lightweight JavaScript BDD/spec/testing framework.
|
* Top level namespace for Jasmine, a lightweight JavaScript BDD/spec/testing framework.
|
||||||
*
|
*
|
||||||
* @namespace
|
* @namespace
|
||||||
*/
|
*/
|
||||||
var jasmine = {};
|
var jasmine = {};
|
||||||
if (isCommonJS) exports.jasmine = jasmine;
|
|
||||||
/**
|
/**
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
@ -22,12 +20,6 @@ jasmine.unimplementedMethod_ = function() {
|
|||||||
*/
|
*/
|
||||||
jasmine.undefined = jasmine.___undefined___;
|
jasmine.undefined = jasmine.___undefined___;
|
||||||
|
|
||||||
/**
|
|
||||||
* Show diagnostic messages in the console if set to true
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
jasmine.VERBOSE = false;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default interval in milliseconds for event loop yields (e.g. to allow network activity or to refresh the screen with the HTML-based runner). Small values here may result in slow test running. Zero means no updates until all tests have completed.
|
* Default interval in milliseconds for event loop yields (e.g. to allow network activity or to refresh the screen with the HTML-based runner). Small values here may result in slow test running. Zero means no updates until all tests have completed.
|
||||||
*
|
*
|
||||||
@ -80,7 +72,7 @@ jasmine.MessageResult = function(values) {
|
|||||||
|
|
||||||
jasmine.MessageResult.prototype.toString = function() {
|
jasmine.MessageResult.prototype.toString = function() {
|
||||||
var text = "";
|
var text = "";
|
||||||
for (var i = 0; i < this.values.length; i++) {
|
for(var i = 0; i < this.values.length; i++) {
|
||||||
if (i > 0) text += " ";
|
if (i > 0) text += " ";
|
||||||
if (jasmine.isString_(this.values[i])) {
|
if (jasmine.isString_(this.values[i])) {
|
||||||
text += this.values[i];
|
text += this.values[i];
|
||||||
@ -97,10 +89,9 @@ jasmine.ExpectationResult = function(params) {
|
|||||||
this.passed_ = params.passed;
|
this.passed_ = params.passed;
|
||||||
this.expected = params.expected;
|
this.expected = params.expected;
|
||||||
this.actual = params.actual;
|
this.actual = params.actual;
|
||||||
this.message = this.passed_ ? 'Passed.' : params.message;
|
|
||||||
|
|
||||||
var trace = (params.trace || new Error(this.message));
|
this.message = this.passed_ ? 'Passed.' : params.message;
|
||||||
this.trace = this.passed_ ? '' : trace;
|
this.trace = this.passed_ ? '' : new Error(this.message);
|
||||||
};
|
};
|
||||||
|
|
||||||
jasmine.ExpectationResult.prototype.toString = function () {
|
jasmine.ExpectationResult.prototype.toString = function () {
|
||||||
@ -115,8 +106,7 @@ jasmine.ExpectationResult.prototype.passed = function () {
|
|||||||
* Getter for the Jasmine environment. Ensures one gets created
|
* Getter for the Jasmine environment. Ensures one gets created
|
||||||
*/
|
*/
|
||||||
jasmine.getEnv = function() {
|
jasmine.getEnv = function() {
|
||||||
var env = jasmine.currentEnv_ = jasmine.currentEnv_ || new jasmine.Env();
|
return jasmine.currentEnv_ = jasmine.currentEnv_ || new jasmine.Env();
|
||||||
return env;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -179,7 +169,7 @@ jasmine.pp = function(value) {
|
|||||||
* @returns {Boolean}
|
* @returns {Boolean}
|
||||||
*/
|
*/
|
||||||
jasmine.isDomNode = function(obj) {
|
jasmine.isDomNode = function(obj) {
|
||||||
return obj.nodeType > 0;
|
return obj['nodeType'] > 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -415,7 +405,7 @@ jasmine.isSpy = function(putativeSpy) {
|
|||||||
* @param {Array} methodNames array of names of methods to make spies
|
* @param {Array} methodNames array of names of methods to make spies
|
||||||
*/
|
*/
|
||||||
jasmine.createSpyObj = function(baseName, methodNames) {
|
jasmine.createSpyObj = function(baseName, methodNames) {
|
||||||
if (!jasmine.isArray_(methodNames) || methodNames.length === 0) {
|
if (!jasmine.isArray_(methodNames) || methodNames.length == 0) {
|
||||||
throw new Error('createSpyObj requires a non-empty array of method names to create spies for');
|
throw new Error('createSpyObj requires a non-empty array of method names to create spies for');
|
||||||
}
|
}
|
||||||
var obj = {};
|
var obj = {};
|
||||||
@ -453,7 +443,6 @@ jasmine.log = function() {
|
|||||||
var spyOn = function(obj, methodName) {
|
var spyOn = function(obj, methodName) {
|
||||||
return jasmine.getEnv().currentSpec.spyOn(obj, methodName);
|
return jasmine.getEnv().currentSpec.spyOn(obj, methodName);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.spyOn = spyOn;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a Jasmine spec that will be added to the current suite.
|
* Creates a Jasmine spec that will be added to the current suite.
|
||||||
@ -471,7 +460,6 @@ if (isCommonJS) exports.spyOn = spyOn;
|
|||||||
var it = function(desc, func) {
|
var it = function(desc, func) {
|
||||||
return jasmine.getEnv().it(desc, func);
|
return jasmine.getEnv().it(desc, func);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.it = it;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a <em>disabled</em> Jasmine spec.
|
* Creates a <em>disabled</em> Jasmine spec.
|
||||||
@ -484,7 +472,6 @@ if (isCommonJS) exports.it = it;
|
|||||||
var xit = function(desc, func) {
|
var xit = function(desc, func) {
|
||||||
return jasmine.getEnv().xit(desc, func);
|
return jasmine.getEnv().xit(desc, func);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.xit = xit;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Starts a chain for a Jasmine expectation.
|
* Starts a chain for a Jasmine expectation.
|
||||||
@ -497,7 +484,6 @@ if (isCommonJS) exports.xit = xit;
|
|||||||
var expect = function(actual) {
|
var expect = function(actual) {
|
||||||
return jasmine.getEnv().currentSpec.expect(actual);
|
return jasmine.getEnv().currentSpec.expect(actual);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.expect = expect;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines part of a jasmine spec. Used in cominbination with waits or waitsFor in asynchrnous specs.
|
* Defines part of a jasmine spec. Used in cominbination with waits or waitsFor in asynchrnous specs.
|
||||||
@ -507,7 +493,6 @@ if (isCommonJS) exports.expect = expect;
|
|||||||
var runs = function(func) {
|
var runs = function(func) {
|
||||||
jasmine.getEnv().currentSpec.runs(func);
|
jasmine.getEnv().currentSpec.runs(func);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.runs = runs;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Waits a fixed time period before moving to the next block.
|
* Waits a fixed time period before moving to the next block.
|
||||||
@ -518,7 +503,6 @@ if (isCommonJS) exports.runs = runs;
|
|||||||
var waits = function(timeout) {
|
var waits = function(timeout) {
|
||||||
jasmine.getEnv().currentSpec.waits(timeout);
|
jasmine.getEnv().currentSpec.waits(timeout);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.waits = waits;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Waits for the latchFunction to return true before proceeding to the next block.
|
* Waits for the latchFunction to return true before proceeding to the next block.
|
||||||
@ -530,7 +514,6 @@ if (isCommonJS) exports.waits = waits;
|
|||||||
var waitsFor = function(latchFunction, optional_timeoutMessage, optional_timeout) {
|
var waitsFor = function(latchFunction, optional_timeoutMessage, optional_timeout) {
|
||||||
jasmine.getEnv().currentSpec.waitsFor.apply(jasmine.getEnv().currentSpec, arguments);
|
jasmine.getEnv().currentSpec.waitsFor.apply(jasmine.getEnv().currentSpec, arguments);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.waitsFor = waitsFor;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A function that is called before each spec in a suite.
|
* A function that is called before each spec in a suite.
|
||||||
@ -542,7 +525,6 @@ if (isCommonJS) exports.waitsFor = waitsFor;
|
|||||||
var beforeEach = function(beforeEachFunction) {
|
var beforeEach = function(beforeEachFunction) {
|
||||||
jasmine.getEnv().beforeEach(beforeEachFunction);
|
jasmine.getEnv().beforeEach(beforeEachFunction);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.beforeEach = beforeEach;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A function that is called after each spec in a suite.
|
* A function that is called after each spec in a suite.
|
||||||
@ -554,7 +536,6 @@ if (isCommonJS) exports.beforeEach = beforeEach;
|
|||||||
var afterEach = function(afterEachFunction) {
|
var afterEach = function(afterEachFunction) {
|
||||||
jasmine.getEnv().afterEach(afterEachFunction);
|
jasmine.getEnv().afterEach(afterEachFunction);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.afterEach = afterEach;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines a suite of specifications.
|
* Defines a suite of specifications.
|
||||||
@ -574,7 +555,6 @@ if (isCommonJS) exports.afterEach = afterEach;
|
|||||||
var describe = function(description, specDefinitions) {
|
var describe = function(description, specDefinitions) {
|
||||||
return jasmine.getEnv().describe(description, specDefinitions);
|
return jasmine.getEnv().describe(description, specDefinitions);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.describe = describe;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Disables a suite of specifications. Used to disable some suites in a file, or files, temporarily during development.
|
* Disables a suite of specifications. Used to disable some suites in a file, or files, temporarily during development.
|
||||||
@ -585,35 +565,27 @@ if (isCommonJS) exports.describe = describe;
|
|||||||
var xdescribe = function(description, specDefinitions) {
|
var xdescribe = function(description, specDefinitions) {
|
||||||
return jasmine.getEnv().xdescribe(description, specDefinitions);
|
return jasmine.getEnv().xdescribe(description, specDefinitions);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.xdescribe = xdescribe;
|
|
||||||
|
|
||||||
|
|
||||||
// Provide the XMLHttpRequest class for IE 5.x-6.x:
|
// Provide the XMLHttpRequest class for IE 5.x-6.x:
|
||||||
jasmine.XmlHttpRequest = (typeof XMLHttpRequest == "undefined") ? function() {
|
jasmine.XmlHttpRequest = (typeof XMLHttpRequest == "undefined") ? function() {
|
||||||
function tryIt(f) {
|
|
||||||
try {
|
try {
|
||||||
return f();
|
return new ActiveXObject("Msxml2.XMLHTTP.6.0");
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
}
|
}
|
||||||
return null;
|
try {
|
||||||
}
|
|
||||||
|
|
||||||
var xhr = tryIt(function() {
|
|
||||||
return new ActiveXObject("Msxml2.XMLHTTP.6.0");
|
|
||||||
}) ||
|
|
||||||
tryIt(function() {
|
|
||||||
return new ActiveXObject("Msxml2.XMLHTTP.3.0");
|
return new ActiveXObject("Msxml2.XMLHTTP.3.0");
|
||||||
}) ||
|
} catch(e) {
|
||||||
tryIt(function() {
|
}
|
||||||
|
try {
|
||||||
return new ActiveXObject("Msxml2.XMLHTTP");
|
return new ActiveXObject("Msxml2.XMLHTTP");
|
||||||
}) ||
|
} catch(e) {
|
||||||
tryIt(function() {
|
}
|
||||||
|
try {
|
||||||
return new ActiveXObject("Microsoft.XMLHTTP");
|
return new ActiveXObject("Microsoft.XMLHTTP");
|
||||||
});
|
} catch(e) {
|
||||||
|
}
|
||||||
if (!xhr) throw new Error("This browser does not support XMLHttpRequest.");
|
throw new Error("This browser does not support XMLHttpRequest.");
|
||||||
|
|
||||||
return xhr;
|
|
||||||
} : XMLHttpRequest;
|
} : XMLHttpRequest;
|
||||||
/**
|
/**
|
||||||
* @namespace
|
* @namespace
|
||||||
@ -634,7 +606,7 @@ jasmine.util.inherit = function(childClass, parentClass) {
|
|||||||
var subclass = function() {
|
var subclass = function() {
|
||||||
};
|
};
|
||||||
subclass.prototype = parentClass.prototype;
|
subclass.prototype = parentClass.prototype;
|
||||||
childClass.prototype = new subclass();
|
childClass.prototype = new subclass;
|
||||||
};
|
};
|
||||||
|
|
||||||
jasmine.util.formatException = function(e) {
|
jasmine.util.formatException = function(e) {
|
||||||
@ -788,14 +760,14 @@ jasmine.Env.prototype.describe = function(description, specDefinitions) {
|
|||||||
declarationError = e;
|
declarationError = e;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.currentSuite = parentSuite;
|
||||||
|
|
||||||
if (declarationError) {
|
if (declarationError) {
|
||||||
this.it("encountered a declaration exception", function() {
|
this.it("encountered a declaration exception", function() {
|
||||||
throw declarationError;
|
throw declarationError;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
this.currentSuite = parentSuite;
|
|
||||||
|
|
||||||
return suite;
|
return suite;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -856,7 +828,7 @@ jasmine.Env.prototype.compareObjects_ = function(a, b, mismatchKeys, mismatchVal
|
|||||||
b.__Jasmine_been_here_before__ = a;
|
b.__Jasmine_been_here_before__ = a;
|
||||||
|
|
||||||
var hasKey = function(obj, keyName) {
|
var hasKey = function(obj, keyName) {
|
||||||
return obj !== null && obj[keyName] !== jasmine.undefined;
|
return obj != null && obj[keyName] !== jasmine.undefined;
|
||||||
};
|
};
|
||||||
|
|
||||||
for (var property in b) {
|
for (var property in b) {
|
||||||
@ -882,7 +854,7 @@ jasmine.Env.prototype.compareObjects_ = function(a, b, mismatchKeys, mismatchVal
|
|||||||
|
|
||||||
delete a.__Jasmine_been_here_before__;
|
delete a.__Jasmine_been_here_before__;
|
||||||
delete b.__Jasmine_been_here_before__;
|
delete b.__Jasmine_been_here_before__;
|
||||||
return (mismatchKeys.length === 0 && mismatchValues.length === 0);
|
return (mismatchKeys.length == 0 && mismatchValues.length == 0);
|
||||||
};
|
};
|
||||||
|
|
||||||
jasmine.Env.prototype.equals_ = function(a, b, mismatchKeys, mismatchValues) {
|
jasmine.Env.prototype.equals_ = function(a, b, mismatchKeys, mismatchValues) {
|
||||||
@ -1330,16 +1302,16 @@ jasmine.Matchers.prototype.toHaveBeenCalledWith = function() {
|
|||||||
throw new Error('Expected a spy, but got ' + jasmine.pp(this.actual) + '.');
|
throw new Error('Expected a spy, but got ' + jasmine.pp(this.actual) + '.');
|
||||||
}
|
}
|
||||||
this.message = function() {
|
this.message = function() {
|
||||||
if (this.actual.callCount === 0) {
|
if (this.actual.callCount == 0) {
|
||||||
// todo: what should the failure message for .not.toHaveBeenCalledWith() be? is this right? test better. [xw]
|
// todo: what should the failure message for .not.toHaveBeenCalledWith() be? is this right? test better. [xw]
|
||||||
return [
|
return [
|
||||||
"Expected spy " + this.actual.identity + " to have been called with " + jasmine.pp(expectedArgs) + " but it was never called.",
|
"Expected spy to have been called with " + jasmine.pp(expectedArgs) + " but it was never called.",
|
||||||
"Expected spy " + this.actual.identity + " not to have been called with " + jasmine.pp(expectedArgs) + " but it was."
|
"Expected spy not to have been called with " + jasmine.pp(expectedArgs) + " but it was."
|
||||||
];
|
];
|
||||||
} else {
|
} else {
|
||||||
return [
|
return [
|
||||||
"Expected spy " + this.actual.identity + " to have been called with " + jasmine.pp(expectedArgs) + " but was called with " + jasmine.pp(this.actual.argsForCall),
|
"Expected spy to have been called with " + jasmine.pp(expectedArgs) + " but was called with " + jasmine.pp(this.actual.argsForCall),
|
||||||
"Expected spy " + this.actual.identity + " not to have been called with " + jasmine.pp(expectedArgs) + " but was called with " + jasmine.pp(this.actual.argsForCall)
|
"Expected spy not to have been called with " + jasmine.pp(expectedArgs) + " but was called with " + jasmine.pp(this.actual.argsForCall)
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -1361,7 +1333,7 @@ jasmine.Matchers.prototype.wasNotCalledWith = function() {
|
|||||||
return [
|
return [
|
||||||
"Expected spy not to have been called with " + jasmine.pp(expectedArgs) + " but it was",
|
"Expected spy not to have been called with " + jasmine.pp(expectedArgs) + " but it was",
|
||||||
"Expected spy to have been called with " + jasmine.pp(expectedArgs) + " but it was"
|
"Expected spy to have been called with " + jasmine.pp(expectedArgs) + " but it was"
|
||||||
];
|
]
|
||||||
};
|
};
|
||||||
|
|
||||||
return !this.env.contains_(this.actual.argsForCall, expectedArgs);
|
return !this.env.contains_(this.actual.argsForCall, expectedArgs);
|
||||||
@ -1394,23 +1366,6 @@ jasmine.Matchers.prototype.toBeGreaterThan = function(expected) {
|
|||||||
return this.actual > expected;
|
return this.actual > expected;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* Matcher that checks that the expected item is equal to the actual item
|
|
||||||
* up to a given level of decimal precision (default 2).
|
|
||||||
*
|
|
||||||
* @param {Number} expected
|
|
||||||
* @param {Number} precision
|
|
||||||
*/
|
|
||||||
jasmine.Matchers.prototype.toBeCloseTo = function(expected, precision) {
|
|
||||||
if (!(precision === 0)) {
|
|
||||||
precision = precision || 2;
|
|
||||||
}
|
|
||||||
var multiplier = Math.pow(10, precision);
|
|
||||||
var actual = Math.round(this.actual * multiplier);
|
|
||||||
expected = Math.round(expected * multiplier);
|
|
||||||
return expected == actual;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Matcher that checks that the expected exception was thrown by the actual.
|
* Matcher that checks that the expected exception was thrown by the actual.
|
||||||
*
|
*
|
||||||
@ -1435,7 +1390,7 @@ jasmine.Matchers.prototype.toThrow = function(expected) {
|
|||||||
|
|
||||||
this.message = function() {
|
this.message = function() {
|
||||||
if (exception && (expected === jasmine.undefined || !this.env.equals_(exception.message || exception, expected.message || expected))) {
|
if (exception && (expected === jasmine.undefined || !this.env.equals_(exception.message || exception, expected.message || expected))) {
|
||||||
return ["Expected function " + not + "to throw", expected ? expected.message || expected : "an exception", ", but it threw", exception.message || exception].join(' ');
|
return ["Expected function " + not + "to throw", expected ? expected.message || expected : " an exception", ", but it threw", exception.message || exception].join(' ');
|
||||||
} else {
|
} else {
|
||||||
return "Expected function to throw an exception.";
|
return "Expected function to throw an exception.";
|
||||||
}
|
}
|
||||||
@ -1647,8 +1602,7 @@ jasmine.PrettyPrinter.prototype.format = function(value) {
|
|||||||
jasmine.PrettyPrinter.prototype.iterateObject = function(obj, fn) {
|
jasmine.PrettyPrinter.prototype.iterateObject = function(obj, fn) {
|
||||||
for (var property in obj) {
|
for (var property in obj) {
|
||||||
if (property == '__Jasmine_been_here_before__') continue;
|
if (property == '__Jasmine_been_here_before__') continue;
|
||||||
fn(property, obj.__lookupGetter__ ? (obj.__lookupGetter__(property) !== jasmine.undefined &&
|
fn(property, obj.__lookupGetter__ ? (obj.__lookupGetter__(property) != null) : false);
|
||||||
obj.__lookupGetter__(property) !== null) : false);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1917,8 +1871,7 @@ jasmine.Spec = function(env, suite, description) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
jasmine.Spec.prototype.getFullName = function() {
|
jasmine.Spec.prototype.getFullName = function() {
|
||||||
var description = (this.description.apply ? this.description.name : this.description);
|
return this.suite.getFullName() + ' ' + this.description + '.';
|
||||||
return this.suite.getFullName() + ' ' + description + '.';
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -2009,8 +1962,7 @@ jasmine.Spec.prototype.waitsFor = function(latchFunction, optional_timeoutMessag
|
|||||||
jasmine.Spec.prototype.fail = function (e) {
|
jasmine.Spec.prototype.fail = function (e) {
|
||||||
var expectationResult = new jasmine.ExpectationResult({
|
var expectationResult = new jasmine.ExpectationResult({
|
||||||
passed: false,
|
passed: false,
|
||||||
message: e ? jasmine.util.formatException(e) : 'Exception',
|
message: e ? jasmine.util.formatException(e) : 'Exception'
|
||||||
trace: { stack: e.stack }
|
|
||||||
});
|
});
|
||||||
this.results_.addResult(expectationResult);
|
this.results_.addResult(expectationResult);
|
||||||
};
|
};
|
||||||
@ -2154,7 +2106,7 @@ jasmine.Suite = function(env, description, specDefinitions, parentSuite) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
jasmine.Suite.prototype.getFullName = function() {
|
jasmine.Suite.prototype.getFullName = function() {
|
||||||
var fullName = (this.description.apply ? this.description.name : this.description);
|
var fullName = this.description;
|
||||||
for (var parentSuite = this.parentSuite; parentSuite; parentSuite = parentSuite.parentSuite) {
|
for (var parentSuite = this.parentSuite; parentSuite; parentSuite = parentSuite.parentSuite) {
|
||||||
fullName = parentSuite.description + ' ' + fullName;
|
fullName = parentSuite.description + ' ' + fullName;
|
||||||
}
|
}
|
||||||
@ -2220,9 +2172,7 @@ jasmine.WaitsBlock = function(env, timeout, spec) {
|
|||||||
jasmine.util.inherit(jasmine.WaitsBlock, jasmine.Block);
|
jasmine.util.inherit(jasmine.WaitsBlock, jasmine.Block);
|
||||||
|
|
||||||
jasmine.WaitsBlock.prototype.execute = function (onComplete) {
|
jasmine.WaitsBlock.prototype.execute = function (onComplete) {
|
||||||
if (jasmine.VERBOSE) {
|
|
||||||
this.env.reporter.log('>> Jasmine waiting for ' + this.timeout + ' ms...');
|
this.env.reporter.log('>> Jasmine waiting for ' + this.timeout + ' ms...');
|
||||||
}
|
|
||||||
this.env.setTimeout(function () {
|
this.env.setTimeout(function () {
|
||||||
onComplete();
|
onComplete();
|
||||||
}, this.timeout);
|
}, this.timeout);
|
||||||
@ -2250,9 +2200,7 @@ jasmine.util.inherit(jasmine.WaitsForBlock, jasmine.Block);
|
|||||||
jasmine.WaitsForBlock.TIMEOUT_INCREMENT = 10;
|
jasmine.WaitsForBlock.TIMEOUT_INCREMENT = 10;
|
||||||
|
|
||||||
jasmine.WaitsForBlock.prototype.execute = function(onComplete) {
|
jasmine.WaitsForBlock.prototype.execute = function(onComplete) {
|
||||||
if (jasmine.VERBOSE) {
|
|
||||||
this.env.reporter.log('>> Jasmine waiting for ' + (this.message || 'something to happen'));
|
this.env.reporter.log('>> Jasmine waiting for ' + (this.message || 'something to happen'));
|
||||||
}
|
|
||||||
var latchFunctionResult;
|
var latchFunctionResult;
|
||||||
try {
|
try {
|
||||||
latchFunctionResult = this.latchFunction.apply(this.spec);
|
latchFunctionResult = this.latchFunction.apply(this.spec);
|
||||||
@ -2467,7 +2415,7 @@ jasmine.getGlobal().clearInterval = function(timeoutKey) {
|
|||||||
|
|
||||||
jasmine.version_= {
|
jasmine.version_= {
|
||||||
"major": 1,
|
"major": 1,
|
||||||
"minor": 1,
|
"minor": 0,
|
||||||
"build": 0,
|
"build": 0,
|
||||||
"revision": 1307455841
|
"revision": 1284494074
|
||||||
};
|
};
|
||||||
|
2
pages
@ -1 +1 @@
|
|||||||
Subproject commit d08ce2de245d6782c09c652045a12e93af0dc7ec
|
Subproject commit fef4a2da3c808762d5c54a6dbd4e65951712468d
|
@ -1,127 +0,0 @@
|
|||||||
var fs = require('fs');
|
|
||||||
var sys = require('sys');
|
|
||||||
var path = require('path');
|
|
||||||
|
|
||||||
// yes, really keep this here to keep us honest, but only for jasmine's own runner! [xw]
|
|
||||||
// undefined = "diz be undefined yo";
|
|
||||||
|
|
||||||
|
|
||||||
var jasmineGlobals = require('../lib/jasmine.js');
|
|
||||||
for (var k in jasmineGlobals) {
|
|
||||||
global[k] = jasmineGlobals[k];
|
|
||||||
}
|
|
||||||
require('../src/console/TrivialConsoleReporter.js');
|
|
||||||
|
|
||||||
/*
|
|
||||||
Pulling in code from jasmine-node.
|
|
||||||
|
|
||||||
We can't just depend on jasmine-node because it has its own jasmine that it uses.
|
|
||||||
*/
|
|
||||||
|
|
||||||
global.window = {
|
|
||||||
setTimeout: setTimeout,
|
|
||||||
clearTimeout: clearTimeout,
|
|
||||||
setInterval: setInterval,
|
|
||||||
clearInterval: clearInterval
|
|
||||||
};
|
|
||||||
|
|
||||||
delete global.window;
|
|
||||||
|
|
||||||
function noop() {
|
|
||||||
}
|
|
||||||
|
|
||||||
jasmine.executeSpecs = function(specs, done) {
|
|
||||||
for (var i = 0, len = specs.length; i < len; ++i) {
|
|
||||||
var filename = specs[i];
|
|
||||||
require(filename.replace(/\.\w+$/, ""));
|
|
||||||
}
|
|
||||||
|
|
||||||
var jasmineEnv = jasmine.getEnv();
|
|
||||||
var consoleReporter = new jasmine.TrivialConsoleReporter(sys.print, done);
|
|
||||||
|
|
||||||
jasmineEnv.addReporter(consoleReporter);
|
|
||||||
jasmineEnv.execute();
|
|
||||||
};
|
|
||||||
|
|
||||||
jasmine.getAllSpecFiles = function(dir, matcher) {
|
|
||||||
var specs = [];
|
|
||||||
|
|
||||||
if (fs.statSync(dir).isFile() && dir.match(matcher)) {
|
|
||||||
specs.push(dir);
|
|
||||||
} else {
|
|
||||||
var files = fs.readdirSync(dir);
|
|
||||||
for (var i = 0, len = files.length; i < len; ++i) {
|
|
||||||
var filename = dir + '/' + files[i];
|
|
||||||
if (fs.statSync(filename).isFile() && filename.match(matcher)) {
|
|
||||||
specs.push(filename);
|
|
||||||
} else if (fs.statSync(filename).isDirectory()) {
|
|
||||||
var subfiles = this.getAllSpecFiles(filename, matcher);
|
|
||||||
subfiles.forEach(function(result) {
|
|
||||||
specs.push(result);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return specs;
|
|
||||||
};
|
|
||||||
|
|
||||||
function now() {
|
|
||||||
return new Date().getTime();
|
|
||||||
}
|
|
||||||
|
|
||||||
jasmine.asyncSpecWait = function() {
|
|
||||||
var wait = jasmine.asyncSpecWait;
|
|
||||||
wait.start = now();
|
|
||||||
wait.done = false;
|
|
||||||
(function innerWait() {
|
|
||||||
waits(10);
|
|
||||||
runs(function() {
|
|
||||||
if (wait.start + wait.timeout < now()) {
|
|
||||||
expect('timeout waiting for spec').toBeNull();
|
|
||||||
} else if (wait.done) {
|
|
||||||
wait.done = false;
|
|
||||||
} else {
|
|
||||||
innerWait();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
})();
|
|
||||||
};
|
|
||||||
jasmine.asyncSpecWait.timeout = 4 * 1000;
|
|
||||||
jasmine.asyncSpecDone = function() {
|
|
||||||
jasmine.asyncSpecWait.done = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
for (var key in jasmine) {
|
|
||||||
exports[key] = jasmine[key];
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
End jasmine-node runner
|
|
||||||
*/
|
|
||||||
|
|
||||||
var isVerbose = false;
|
|
||||||
var showColors = true;
|
|
||||||
process.argv.forEach(function(arg) {
|
|
||||||
switch (arg) {
|
|
||||||
case '--color': showColors = true; break;
|
|
||||||
case '--noColor': showColors = false; break;
|
|
||||||
case '--verbose': isVerbose = true; break;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
var specs = jasmine.getAllSpecFiles(__dirname + '/suites', new RegExp(".js$"));
|
|
||||||
var domIndependentSpecs = [];
|
|
||||||
for (var i = 0; i < specs.length; i++) {
|
|
||||||
if (fs.readFileSync(specs[i], "utf8").indexOf("document.createElement") < 0) {
|
|
||||||
domIndependentSpecs.push(specs[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
jasmine.executeSpecs(domIndependentSpecs, function(runner, log) {
|
|
||||||
if (runner.results().failedCount === 0) {
|
|
||||||
process.exit(0);
|
|
||||||
} else {
|
|
||||||
process.exit(1);
|
|
||||||
}
|
|
||||||
}, isVerbose, showColors);
|
|
@ -8,11 +8,27 @@
|
|||||||
// yes, really keep this here to keep us honest, but only for jasmine's own runner! [xw]
|
// yes, really keep this here to keep us honest, but only for jasmine's own runner! [xw]
|
||||||
undefined = "diz be undefined yo";
|
undefined = "diz be undefined yo";
|
||||||
</script>
|
</script>
|
||||||
<link rel="shortcut icon" type="image/png" href="../images/jasmine_favicon.png">
|
|
||||||
<script type="text/javascript" src="../lib/jasmine.js"></script>
|
<script type="text/javascript" src="../src/base.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/util.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/Env.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/Reporter.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/Block.js"></script>
|
||||||
|
|
||||||
|
<script type="text/javascript" src="../src/JsApiReporter.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/Matchers.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/mock-timeout.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/MultiReporter.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/NestedResults.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/PrettyPrinter.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/Queue.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/Runner.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/Spec.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/Suite.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/WaitsBlock.js"></script>
|
||||||
|
<script type="text/javascript" src="../src/WaitsForBlock.js"></script>
|
||||||
|
|
||||||
<script type="text/javascript" src="../src/html/TrivialReporter.js"></script>
|
<script type="text/javascript" src="../src/html/TrivialReporter.js"></script>
|
||||||
<script type="text/javascript" src="../src/console/TrivialConsoleReporter.js"></script>
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -34,7 +50,6 @@
|
|||||||
<script type="text/javascript" src="suites/SpySpec.js"></script>
|
<script type="text/javascript" src="suites/SpySpec.js"></script>
|
||||||
<script type="text/javascript" src="suites/SuiteSpec.js"></script>
|
<script type="text/javascript" src="suites/SuiteSpec.js"></script>
|
||||||
<script type="text/javascript" src="suites/TrivialReporterSpec.js"></script>
|
<script type="text/javascript" src="suites/TrivialReporterSpec.js"></script>
|
||||||
<script type="text/javascript" src="suites/TrivialConsoleReporterSpec.js"></script>
|
|
||||||
<script type="text/javascript" src="suites/WaitsForBlockSpec.js"></script>
|
<script type="text/javascript" src="suites/WaitsForBlockSpec.js"></script>
|
||||||
|
|
||||||
|
|
||||||
|
@ -108,7 +108,7 @@ describe("jasmine.Env", function() {
|
|||||||
|
|
||||||
it("should give custom equality testers precedence", function() {
|
it("should give custom equality testers precedence", function() {
|
||||||
expect(env.equals_('abc', 'abc')).toBeFalsy();
|
expect(env.equals_('abc', 'abc')).toBeFalsy();
|
||||||
var o = {};
|
var o = new Object();
|
||||||
expect(env.equals_(o, o)).toBeFalsy();
|
expect(env.equals_(o, o)).toBeFalsy();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -89,9 +89,9 @@ describe('Exceptions:', function() {
|
|||||||
expect(blockResults[0].message).toMatch(/fake error 1/);
|
expect(blockResults[0].message).toMatch(/fake error 1/);
|
||||||
|
|
||||||
expect(specResults[1].passed()).toEqual(false);
|
expect(specResults[1].passed()).toEqual(false);
|
||||||
blockResults = specResults[1].getItems();
|
var blockResults = specResults[1].getItems();
|
||||||
expect(blockResults[0].passed()).toEqual(false);
|
expect(blockResults[0].passed()).toEqual(false);
|
||||||
expect(blockResults[0].message).toMatch(/fake error 2/);
|
expect(blockResults[0].message).toMatch(/fake error 2/),
|
||||||
expect(blockResults[1].passed()).toEqual(true);
|
expect(blockResults[1].passed()).toEqual(true);
|
||||||
|
|
||||||
expect(specResults[2].passed()).toEqual(true);
|
expect(specResults[2].passed()).toEqual(true);
|
||||||
@ -101,49 +101,7 @@ describe('Exceptions:', function() {
|
|||||||
expect(blockResults[0].message).toMatch(/fake error 3/);
|
expect(blockResults[0].message).toMatch(/fake error 3/);
|
||||||
|
|
||||||
expect(specResults[4].passed()).toEqual(true);
|
expect(specResults[4].passed()).toEqual(true);
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
it("should handle exceptions thrown directly in top-level describe blocks and continue", function () {
|
|
||||||
var suite = env.describe("a top level describe block that throws an exception", function () {
|
|
||||||
env.it("is a test that should pass", function () {
|
|
||||||
this.expect(true).toEqual(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
throw new Error("top level error");
|
|
||||||
});
|
|
||||||
|
|
||||||
suite.execute();
|
|
||||||
var suiteResults = suite.results();
|
|
||||||
var specResults = suiteResults.getItems();
|
|
||||||
|
|
||||||
expect(suiteResults.passed()).toEqual(false);
|
|
||||||
expect(specResults.length).toEqual(2);
|
|
||||||
|
|
||||||
expect(specResults[1].description).toMatch(/encountered a declaration exception/);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should handle exceptions thrown directly in nested describe blocks and continue", function () {
|
|
||||||
var suite = env.describe("a top level describe", function () {
|
|
||||||
env.describe("a mid-level describe that throws an exception", function () {
|
|
||||||
env.it("is a test that should pass", function () {
|
|
||||||
this.expect(true).toEqual(true);
|
|
||||||
});
|
|
||||||
|
|
||||||
throw new Error("a mid-level error");
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
suite.execute();
|
|
||||||
var suiteResults = suite.results();
|
|
||||||
var specResults = suiteResults.getItems();
|
|
||||||
|
|
||||||
expect(suiteResults.passed()).toEqual(false);
|
|
||||||
expect(specResults.length).toEqual(1);
|
|
||||||
|
|
||||||
var nestedSpecResults = specResults[0].getItems();
|
|
||||||
|
|
||||||
expect(nestedSpecResults.length).toEqual(2);
|
|
||||||
expect(nestedSpecResults[1].description).toMatch(/encountered a declaration exception/);
|
|
||||||
});
|
|
||||||
});
|
});
|
@ -21,7 +21,7 @@ describe('jasmine.jsApiReporter', function() {
|
|||||||
nestedSuite = env.describe("nested suite", function() {
|
nestedSuite = env.describe("nested suite", function() {
|
||||||
nestedSpec = env.it("nested spec", function() {
|
nestedSpec = env.it("nested spec", function() {
|
||||||
expect(true).toEqual(true);
|
expect(true).toEqual(true);
|
||||||
});
|
})
|
||||||
});
|
});
|
||||||
|
|
||||||
spec3 = env.it("spec 3", function() {
|
spec3 = env.it("spec 3", function() {
|
||||||
|
@ -18,7 +18,7 @@ describe("jasmine.Matchers", function() {
|
|||||||
toFail: function() {
|
toFail: function() {
|
||||||
return !lastResult().passed();
|
return !lastResult().passed();
|
||||||
}
|
}
|
||||||
});
|
})
|
||||||
});
|
});
|
||||||
|
|
||||||
function match(value) {
|
function match(value) {
|
||||||
@ -68,13 +68,13 @@ describe("jasmine.Matchers", function() {
|
|||||||
expect((match(['a', 'b']).toEqual(['a', jasmine.undefined]))).toFail();
|
expect((match(['a', 'b']).toEqual(['a', jasmine.undefined]))).toFail();
|
||||||
expect((match(['a', 'b']).toEqual(['a', 'b', jasmine.undefined]))).toFail();
|
expect((match(['a', 'b']).toEqual(['a', 'b', jasmine.undefined]))).toFail();
|
||||||
|
|
||||||
expect((match("cat").toEqual("cat"))).toPass();
|
expect((match(new String("cat")).toEqual("cat"))).toPass();
|
||||||
expect((match("cat").toNotEqual("cat"))).toFail();
|
expect((match(new String("cat")).toNotEqual("cat"))).toFail();
|
||||||
|
|
||||||
expect((match(5).toEqual(5))).toPass();
|
expect((match(new Number(5)).toEqual(5))).toPass();
|
||||||
expect((match(parseInt('5', 10)).toEqual(5))).toPass();
|
expect((match(new Number('5')).toEqual(5))).toPass();
|
||||||
expect((match(5).toNotEqual(5))).toFail();
|
expect((match(new Number(5)).toNotEqual(5))).toFail();
|
||||||
expect((match(parseInt('5', 10)).toNotEqual(5))).toFail();
|
expect((match(new Number('5')).toNotEqual(5))).toFail();
|
||||||
});
|
});
|
||||||
|
|
||||||
it("toEqual with DOM nodes", function() {
|
it("toEqual with DOM nodes", function() {
|
||||||
@ -348,12 +348,10 @@ describe("jasmine.Matchers", function() {
|
|||||||
expect(match("foo").toEqual(jasmine.any(Object))).toFail();
|
expect(match("foo").toEqual(jasmine.any(Object))).toFail();
|
||||||
expect(match({someObj:'foo'}).toEqual(jasmine.any(Object))).toPass();
|
expect(match({someObj:'foo'}).toEqual(jasmine.any(Object))).toPass();
|
||||||
expect(match({someObj:'foo'}).toEqual(jasmine.any(Function))).toFail();
|
expect(match({someObj:'foo'}).toEqual(jasmine.any(Function))).toFail();
|
||||||
expect(match(
|
expect(match(function() {
|
||||||
function() {
|
|
||||||
}).toEqual(jasmine.any(Object))).toFail();
|
}).toEqual(jasmine.any(Object))).toFail();
|
||||||
expect(match(["foo", "goo"]).toEqual(["foo", jasmine.any(String)])).toPass();
|
expect(match(["foo", "goo"]).toEqual(["foo", jasmine.any(String)])).toPass();
|
||||||
expect(match(
|
expect(match(function() {
|
||||||
function() {
|
|
||||||
}).toEqual(jasmine.any(Function))).toPass();
|
}).toEqual(jasmine.any(Function))).toPass();
|
||||||
expect(match(["a", function() {
|
expect(match(["a", function() {
|
||||||
}]).toEqual(["a", jasmine.any(Function)])).toPass();
|
}]).toEqual(["a", jasmine.any(Function)])).toPass();
|
||||||
@ -473,47 +471,6 @@ describe("jasmine.Matchers", function() {
|
|||||||
expect(result.expected).toEqual(expected);
|
expect(result.expected).toEqual(expected);
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("toBeCloseTo", function() {
|
|
||||||
it("returns 'true' iff actual and expected are equal within 2 decimal points of precision", function() {
|
|
||||||
expect(0).toBeCloseTo(0);
|
|
||||||
expect(1).toBeCloseTo(1);
|
|
||||||
expect(1).not.toBeCloseTo(1.1);
|
|
||||||
expect(1).not.toBeCloseTo(1.01);
|
|
||||||
expect(1).toBeCloseTo(1.001);
|
|
||||||
|
|
||||||
expect(1.23).toBeCloseTo(1.234);
|
|
||||||
expect(1.23).toBeCloseTo(1.233);
|
|
||||||
expect(1.23).toBeCloseTo(1.232);
|
|
||||||
expect(1.23).not.toBeCloseTo(1.24);
|
|
||||||
|
|
||||||
expect(-1.23).toBeCloseTo(-1.234);
|
|
||||||
expect(-1.23).not.toBeCloseTo(-1.24);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("accepts an optional precision argument", function() {
|
|
||||||
expect(1).toBeCloseTo(1.1, 0);
|
|
||||||
expect(1.2).toBeCloseTo(1.23, 1);
|
|
||||||
|
|
||||||
expect(1.234).toBeCloseTo(1.2343, 3);
|
|
||||||
expect(1.234).not.toBeCloseTo(1.233, 3);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("rounds", function() {
|
|
||||||
expect(1.23).toBeCloseTo(1.229);
|
|
||||||
expect(1.23).toBeCloseTo(1.226);
|
|
||||||
expect(1.23).toBeCloseTo(1.225);
|
|
||||||
expect(1.23).not.toBeCloseTo(1.2249999);
|
|
||||||
|
|
||||||
expect(1.23).toBeCloseTo(1.234);
|
|
||||||
expect(1.23).toBeCloseTo(1.2349999);
|
|
||||||
expect(1.23).not.toBeCloseTo(1.235);
|
|
||||||
|
|
||||||
expect(-1.23).toBeCloseTo(-1.234);
|
|
||||||
expect(-1.23).not.toBeCloseTo(-1.235);
|
|
||||||
expect(-1.23).not.toBeCloseTo(-1.236);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("toThrow", function() {
|
describe("toThrow", function() {
|
||||||
describe("when code block throws an exception", function() {
|
describe("when code block throws an exception", function() {
|
||||||
var throwingFn;
|
var throwingFn;
|
||||||
@ -583,8 +540,7 @@ describe("jasmine.Matchers", function() {
|
|||||||
|
|
||||||
describe("when code block does not throw an exception", function() {
|
describe("when code block does not throw an exception", function() {
|
||||||
it("should fail (or pass when inverted with .not)", function() {
|
it("should fail (or pass when inverted with .not)", function() {
|
||||||
expect(match(
|
expect(match(function() {
|
||||||
function() {
|
|
||||||
}).toThrow()).toFail();
|
}).toThrow()).toFail();
|
||||||
expect(lastResult().message).toEqual('Expected function to throw an exception.');
|
expect(lastResult().message).toEqual('Expected function to throw an exception.');
|
||||||
});
|
});
|
||||||
@ -640,23 +596,19 @@ describe("jasmine.Matchers", function() {
|
|||||||
|
|
||||||
function shouldThrowAnExceptionWhenInvokedOnANonSpy(methodName) {
|
function shouldThrowAnExceptionWhenInvokedOnANonSpy(methodName) {
|
||||||
return function() {
|
return function() {
|
||||||
expect(
|
expect(function() {
|
||||||
function() {
|
|
||||||
match(TestClass.normalFunction)[methodName]();
|
match(TestClass.normalFunction)[methodName]();
|
||||||
}).toThrow('Expected a spy, but got Function.');
|
}).toThrow('Expected a spy, but got Function.');
|
||||||
|
|
||||||
expect(
|
expect(function() {
|
||||||
function() {
|
|
||||||
match(jasmine.undefined)[methodName]();
|
match(jasmine.undefined)[methodName]();
|
||||||
}).toThrow('Expected a spy, but got undefined.');
|
}).toThrow('Expected a spy, but got undefined.');
|
||||||
|
|
||||||
expect(
|
expect(function() {
|
||||||
function() {
|
|
||||||
match({some:'object'})[methodName]();
|
match({some:'object'})[methodName]();
|
||||||
}).toThrow('Expected a spy, but got { some : \'object\' }.');
|
}).toThrow('Expected a spy, but got { some : \'object\' }.');
|
||||||
|
|
||||||
expect(
|
expect(function() {
|
||||||
function() {
|
|
||||||
match("<b>")[methodName]();
|
match("<b>")[methodName]();
|
||||||
}).toThrow('Expected a spy, but got \'<b>\'.');
|
}).toThrow('Expected a spy, but got \'<b>\'.');
|
||||||
};
|
};
|
||||||
@ -671,8 +623,7 @@ describe("jasmine.Matchers", function() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("should throw an exception when invoked with any arguments", function() {
|
it("should throw an exception when invoked with any arguments", function() {
|
||||||
expect(
|
expect(function() {
|
||||||
function() {
|
|
||||||
match(TestClass.normalFunction).toHaveBeenCalled("unwanted argument");
|
match(TestClass.normalFunction).toHaveBeenCalled("unwanted argument");
|
||||||
}).toThrow('toHaveBeenCalled does not take arguments, use toHaveBeenCalledWith');
|
}).toThrow('toHaveBeenCalled does not take arguments, use toHaveBeenCalledWith');
|
||||||
});
|
});
|
||||||
@ -700,8 +651,7 @@ describe("jasmine.Matchers", function() {
|
|||||||
});
|
});
|
||||||
|
|
||||||
it("should throw an exception when invoked with any arguments", function() {
|
it("should throw an exception when invoked with any arguments", function() {
|
||||||
expect(
|
expect(function() {
|
||||||
function() {
|
|
||||||
match(TestClass.normalFunction).wasNotCalled("unwanted argument");
|
match(TestClass.normalFunction).wasNotCalled("unwanted argument");
|
||||||
}).toThrow('wasNotCalled does not take arguments');
|
}).toThrow('wasNotCalled does not take arguments');
|
||||||
});
|
});
|
||||||
@ -751,7 +701,7 @@ describe("jasmine.Matchers", function() {
|
|||||||
TestClass.spyFunction('d', 'e', 'f');
|
TestClass.spyFunction('d', 'e', 'f');
|
||||||
var expected = match(TestClass.spyFunction);
|
var expected = match(TestClass.spyFunction);
|
||||||
expect(expected.toHaveBeenCalledWith('a', 'b')).toFail();
|
expect(expected.toHaveBeenCalledWith('a', 'b')).toFail();
|
||||||
expect(lastResult().message).toEqual("Expected spy My spy to have been called with [ 'a', 'b' ] but was called with [ [ 'a', 'b', 'c' ], [ 'd', 'e', 'f' ] ]");
|
expect(lastResult().message).toEqual("Expected spy to have been called with [ 'a', 'b' ] but was called with [ [ 'a', 'b', 'c' ], [ 'd', 'e', 'f' ] ]");
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should return a decent message when inverted", function() {
|
it("should return a decent message when inverted", function() {
|
||||||
@ -759,7 +709,7 @@ describe("jasmine.Matchers", function() {
|
|||||||
TestClass.spyFunction('d', 'e', 'f');
|
TestClass.spyFunction('d', 'e', 'f');
|
||||||
var expected = match(TestClass.spyFunction);
|
var expected = match(TestClass.spyFunction);
|
||||||
expect(expected.not.toHaveBeenCalledWith('a', 'b', 'c')).toFail();
|
expect(expected.not.toHaveBeenCalledWith('a', 'b', 'c')).toFail();
|
||||||
expect(lastResult().message).toEqual("Expected spy My spy not to have been called with [ 'a', 'b', 'c' ] but was called with [ [ 'a', 'b', 'c' ], [ 'd', 'e', 'f' ] ]");
|
expect(lastResult().message).toEqual("Expected spy not to have been called with [ 'a', 'b', 'c' ] but was called with [ [ 'a', 'b', 'c' ], [ 'd', 'e', 'f' ] ]");
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should throw an exception when invoked on a non-spy', shouldThrowAnExceptionWhenInvokedOnANonSpy('toHaveBeenCalledWith'));
|
it('should throw an exception when invoked on a non-spy', shouldThrowAnExceptionWhenInvokedOnANonSpy('toHaveBeenCalledWith'));
|
||||||
|
@ -18,9 +18,9 @@ describe("jasmine.MultiReporter", function() {
|
|||||||
delegate[methodName] = jasmine.createSpy(methodName);
|
delegate[methodName] = jasmine.createSpy(methodName);
|
||||||
this.actual[methodName]("whatever argument");
|
this.actual[methodName]("whatever argument");
|
||||||
|
|
||||||
return delegate[methodName].wasCalled &&
|
return delegate[methodName].wasCalled
|
||||||
delegate[methodName].mostRecentCall.args.length == 1 &&
|
&& delegate[methodName].mostRecentCall.args.length == 1
|
||||||
delegate[methodName].mostRecentCall.args[0] == "whatever argument";
|
&& delegate[methodName].mostRecentCall.args[0] == "whatever argument";
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -107,6 +107,7 @@ describe('RunnerTest', function() {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
it('should run child suites and specs and generate results when execute is called', function() {
|
it('should run child suites and specs and generate results when execute is called', function() {
|
||||||
env.describe('one suite description', function () {
|
env.describe('one suite description', function () {
|
||||||
env.it('should be a test', function() {
|
env.it('should be a test', function() {
|
||||||
|
@ -54,7 +54,7 @@ describe("jasmine spec running", function () {
|
|||||||
this.expect(foo).toEqual('baz');
|
this.expect(foo).toEqual('baz');
|
||||||
});
|
});
|
||||||
|
|
||||||
specWithMultipleExpectations = env.it('spec with multiple expectations').runs(function () {
|
specWithMultipleExpectations = env.it('spec with multiple assertions').runs(function () {
|
||||||
var foo = 'bar';
|
var foo = 'bar';
|
||||||
var baz = 'quux';
|
var baz = 'quux';
|
||||||
|
|
||||||
@ -1225,9 +1225,6 @@ describe("jasmine spec running", function () {
|
|||||||
this.expect(true).toEqual(true);
|
this.expect(true).toEqual(true);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
throw new Error("fake error");
|
|
||||||
|
|
||||||
});
|
});
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
}
|
}
|
||||||
@ -1244,12 +1241,10 @@ describe("jasmine spec running", function () {
|
|||||||
expect(specs.join('')).toMatch(new RegExp(
|
expect(specs.join('')).toMatch(new RegExp(
|
||||||
'Spec: outer1 inner1 should thingy.' +
|
'Spec: outer1 inner1 should thingy.' +
|
||||||
'Result: Passed.' +
|
'Result: Passed.' +
|
||||||
'Spec: outer1 inner1 encountered a declaration exception.' +
|
'Spec: outer1 encountered a declaration exception.' +
|
||||||
'Result: Error: fake error.*' +
|
'Result: Error: fake error.*' +
|
||||||
'Spec: outer1 inner2 should other thingy.' +
|
'Spec: outer1 inner2 should other thingy.' +
|
||||||
'Result: Passed.' +
|
'Result: Passed.' +
|
||||||
'Spec: outer1 encountered a declaration exception.' +
|
|
||||||
'Result: Error: fake error.*' +
|
|
||||||
'Spec: outer2 should xxx.' +
|
'Spec: outer2 should xxx.' +
|
||||||
'Result: Passed.'
|
'Result: Passed.'
|
||||||
));
|
));
|
||||||
|
@ -36,22 +36,9 @@ describe('Spec', function () {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('full name', function() {
|
|
||||||
describe('with string', function() {
|
|
||||||
it('getFullName returns suite & spec description', function () {
|
it('getFullName returns suite & spec description', function () {
|
||||||
var spec = new jasmine.Spec(env, suite, 'spec 1');
|
var spec = new jasmine.Spec(env, suite, 'spec 1');
|
||||||
expect(spec.getFullName()).toEqual('suite 1 spec 1.');
|
expect(spec.getFullName()).toEqual('suite 1 spec 1.')
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('with class name', function () {
|
|
||||||
function MyClass() {}
|
|
||||||
|
|
||||||
it('getFullName returns suite & spec description', function () {
|
|
||||||
var spec = new jasmine.Spec(env, suite, MyClass);
|
|
||||||
expect(spec.getFullName()).toEqual('suite 1 MyClass.');
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('results', function () {
|
describe('results', function () {
|
||||||
|
@ -67,22 +67,6 @@ describe('Suite', function() {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('getFullName', function() {
|
|
||||||
describe('with class', function() {
|
|
||||||
function MyClass() {}
|
|
||||||
|
|
||||||
it('should use the name of the class if provided as the description', function() {
|
|
||||||
suite = env.describe(MyClass, function() {
|
|
||||||
env.it('should be something', function() {
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
expect(suite.getFullName()).toEqual("MyClass");
|
|
||||||
expect(suite.children()[0].getFullName()).toEqual("MyClass should be something.");
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('SpecCount', function () {
|
describe('SpecCount', function () {
|
||||||
|
|
||||||
it('should keep a count of the number of specs that are run', function() {
|
it('should keep a count of the number of specs that are run', function() {
|
||||||
|
@ -1,490 +0,0 @@
|
|||||||
describe("TrivialConsoleReporter", function() {
|
|
||||||
//keep these literal. otherwise the test loses value as a test.
|
|
||||||
function green(str) {
|
|
||||||
return '\033[32m' + str + '\033[0m';
|
|
||||||
}
|
|
||||||
|
|
||||||
function red(str) {
|
|
||||||
return '\033[31m' + str + '\033[0m';
|
|
||||||
}
|
|
||||||
|
|
||||||
function yellow(str) {
|
|
||||||
return '\033[33m' + str + '\033[0m';
|
|
||||||
}
|
|
||||||
|
|
||||||
function prefixGreen(str) {
|
|
||||||
return '\033[32m' + str;
|
|
||||||
}
|
|
||||||
|
|
||||||
function prefixRed(str) {
|
|
||||||
return '\033[31m' + str;
|
|
||||||
}
|
|
||||||
|
|
||||||
var newline = "\n";
|
|
||||||
|
|
||||||
var passingSpec = {
|
|
||||||
results: function() {
|
|
||||||
return {
|
|
||||||
passed: function() {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
},
|
|
||||||
failingSpec = {
|
|
||||||
results: function() {
|
|
||||||
return {
|
|
||||||
passed: function() {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
},
|
|
||||||
skippedSpec = {
|
|
||||||
results: function() {
|
|
||||||
return {skipped: true};
|
|
||||||
}
|
|
||||||
},
|
|
||||||
passingRun = {
|
|
||||||
specs: function() {
|
|
||||||
return [null, null, null];
|
|
||||||
},
|
|
||||||
results: function() {
|
|
||||||
return {failedCount: 0, items_: [null, null, null]};
|
|
||||||
}
|
|
||||||
},
|
|
||||||
failingRun = {
|
|
||||||
specs: function() {
|
|
||||||
return [null, null, null];
|
|
||||||
},
|
|
||||||
results: function() {
|
|
||||||
return {
|
|
||||||
failedCount: 7, items_: [null, null, null]};
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
function repeatedlyInvoke(f, times) {
|
|
||||||
for (var i = 0; i < times; i++) f(times + 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
function repeat(thing, times) {
|
|
||||||
var arr = [];
|
|
||||||
for (var i = 0; i < times; i++) arr.push(thing);
|
|
||||||
return arr;
|
|
||||||
}
|
|
||||||
|
|
||||||
function simulateRun(reporter, specResults, suiteResults, finalRunner, startTime, endTime) {
|
|
||||||
reporter.reportRunnerStarting();
|
|
||||||
for (var i = 0; i < specResults.length; i++) {
|
|
||||||
reporter.reportSpecResults(specResults[i]);
|
|
||||||
}
|
|
||||||
for (i = 0; i < suiteResults.length; i++) {
|
|
||||||
reporter.reportSuiteResults(suiteResults[i]);
|
|
||||||
}
|
|
||||||
reporter.runnerStartTime = startTime;
|
|
||||||
reporter.now = function() {
|
|
||||||
return endTime;
|
|
||||||
};
|
|
||||||
reporter.reportRunnerResults(finalRunner);
|
|
||||||
}
|
|
||||||
|
|
||||||
var reporter, out, done;
|
|
||||||
|
|
||||||
beforeEach(function() {
|
|
||||||
out = (function() {
|
|
||||||
var output = "";
|
|
||||||
return {
|
|
||||||
print:function(str) {
|
|
||||||
output += str;
|
|
||||||
},
|
|
||||||
getOutput:function() {
|
|
||||||
return output;
|
|
||||||
},
|
|
||||||
clear: function() {
|
|
||||||
output = "";
|
|
||||||
}
|
|
||||||
};
|
|
||||||
})();
|
|
||||||
|
|
||||||
done = false;
|
|
||||||
reporter = new jasmine.TrivialConsoleReporter(out.print, function(runner) {
|
|
||||||
done = true
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
describe('Integration', function() {
|
|
||||||
it("prints the proper output under a pass scenario. small numbers.", function() {
|
|
||||||
simulateRun(reporter,
|
|
||||||
repeat(passingSpec, 3),
|
|
||||||
[],
|
|
||||||
{
|
|
||||||
specs: function() {
|
|
||||||
return [null, null, null];
|
|
||||||
},
|
|
||||||
results:function() {
|
|
||||||
return {
|
|
||||||
items_: [null, null, null],
|
|
||||||
totalCount: 7,
|
|
||||||
failedCount: 0
|
|
||||||
};
|
|
||||||
}
|
|
||||||
},
|
|
||||||
1000,
|
|
||||||
1777
|
|
||||||
);
|
|
||||||
|
|
||||||
expect(out.getOutput()).toEqual(
|
|
||||||
[
|
|
||||||
"Started",
|
|
||||||
green(".") + green(".") + green("."),
|
|
||||||
"",
|
|
||||||
"Finished in 0.777 seconds",
|
|
||||||
green("3 specs, 7 expectations, 0 failures"),
|
|
||||||
""
|
|
||||||
].join("\n") + "\n"
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
it("prints the proper output under a pass scenario. large numbers.", function() {
|
|
||||||
simulateRun(reporter,
|
|
||||||
repeat(passingSpec, 57),
|
|
||||||
[],
|
|
||||||
{
|
|
||||||
specs: function() {
|
|
||||||
return [null, null, null];
|
|
||||||
},
|
|
||||||
results:function() {
|
|
||||||
return {
|
|
||||||
items_: [null, null, null],
|
|
||||||
totalCount: 7,
|
|
||||||
failedCount: 0
|
|
||||||
};
|
|
||||||
}
|
|
||||||
},
|
|
||||||
1000,
|
|
||||||
1777);
|
|
||||||
|
|
||||||
expect(out.getOutput()).toEqual(
|
|
||||||
[
|
|
||||||
"Started",
|
|
||||||
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") + //50 green dots
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") +
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") +
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") +
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") +
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") +
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") +
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") +
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") +
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") +
|
|
||||||
|
|
||||||
green(".") + green(".") + green(".") + green(".") + green(".") + //7 green dots
|
|
||||||
green(".") + green("."),
|
|
||||||
|
|
||||||
"",
|
|
||||||
"Finished in 0.777 seconds",
|
|
||||||
green("3 specs, 7 expectations, 0 failures"),
|
|
||||||
""
|
|
||||||
].join("\n") + "\n"
|
|
||||||
);
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
it("prints the proper output under a failure scenario.", function() {
|
|
||||||
simulateRun(reporter,
|
|
||||||
[failingSpec, passingSpec, failingSpec],
|
|
||||||
[
|
|
||||||
{description:"The oven",
|
|
||||||
results:function() {
|
|
||||||
return {
|
|
||||||
items_:[
|
|
||||||
{failedCount:2,
|
|
||||||
description:"heats up",
|
|
||||||
items_:[
|
|
||||||
{trace:{stack:"stack trace one\n second line"}},
|
|
||||||
{trace:{stack:"stack trace two"}}
|
|
||||||
]}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
}},
|
|
||||||
{description:"The washing machine",
|
|
||||||
results:function() {
|
|
||||||
return {
|
|
||||||
items_:[
|
|
||||||
{failedCount:2,
|
|
||||||
description:"washes clothes",
|
|
||||||
items_:[
|
|
||||||
{trace:{stack:"stack trace one"}}
|
|
||||||
]}
|
|
||||||
]
|
|
||||||
};
|
|
||||||
}}
|
|
||||||
],
|
|
||||||
{
|
|
||||||
specs: function() {
|
|
||||||
return [null, null, null];
|
|
||||||
},
|
|
||||||
results:function() {
|
|
||||||
return {
|
|
||||||
items_: [null, null, null],
|
|
||||||
totalCount: 7,
|
|
||||||
failedCount: 2
|
|
||||||
};
|
|
||||||
}
|
|
||||||
},
|
|
||||||
1000,
|
|
||||||
1777);
|
|
||||||
|
|
||||||
expect(out.getOutput()).toEqual(
|
|
||||||
[
|
|
||||||
"Started",
|
|
||||||
red("F") + green(".") + red("F"),
|
|
||||||
"",
|
|
||||||
"The oven heats up",
|
|
||||||
" stack trace one",
|
|
||||||
" second line",
|
|
||||||
" stack trace two",
|
|
||||||
"",
|
|
||||||
"The washing machine washes clothes",
|
|
||||||
" stack trace one",
|
|
||||||
"",
|
|
||||||
"Finished in 0.777 seconds",
|
|
||||||
red("3 specs, 7 expectations, 2 failures"),
|
|
||||||
""
|
|
||||||
].join("\n") + "\n"
|
|
||||||
);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('When a Jasmine environment executes', function() {
|
|
||||||
beforeEach(function() {
|
|
||||||
reporter.reportRunnerStarting();
|
|
||||||
});
|
|
||||||
|
|
||||||
it("should print 'Started' to the console", function() {
|
|
||||||
expect(out.getOutput()).toEqual("Started" + newline);
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('when a spec reports', function() {
|
|
||||||
beforeEach(function() {
|
|
||||||
out.clear();
|
|
||||||
});
|
|
||||||
|
|
||||||
it("prints a green dot if the spec passes", function() {
|
|
||||||
reporter.reportSpecResults(passingSpec);
|
|
||||||
|
|
||||||
expect(out.getOutput()).toEqual(green("."));
|
|
||||||
});
|
|
||||||
|
|
||||||
it("prints a red dot if the spec fails", function() {
|
|
||||||
reporter.reportSpecResults(failingSpec);
|
|
||||||
|
|
||||||
expect(out.getOutput()).toEqual(red("F"));
|
|
||||||
});
|
|
||||||
|
|
||||||
it("prints a yellow star if the spec was skipped", function() {
|
|
||||||
reporter.reportSpecResults(skippedSpec);
|
|
||||||
|
|
||||||
expect(out.getOutput()).toEqual(yellow("*"));
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('when a suite reports', function() {
|
|
||||||
var emptyResults;
|
|
||||||
beforeEach(function() {
|
|
||||||
emptyResults = function() {
|
|
||||||
return {
|
|
||||||
items_:[]
|
|
||||||
};
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
it("remembers suite results", function() {
|
|
||||||
reporter.reportSuiteResults({description: "Oven", results: emptyResults});
|
|
||||||
reporter.reportSuiteResults({description: "Mixer", results: emptyResults});
|
|
||||||
|
|
||||||
expect(reporter.suiteResults[0].description).toEqual('Oven');
|
|
||||||
expect(reporter.suiteResults[1].description).toEqual('Mixer');
|
|
||||||
});
|
|
||||||
|
|
||||||
it("creates a description out of the current suite and any parent suites", function() {
|
|
||||||
var grandparentSuite = {
|
|
||||||
description: "My house",
|
|
||||||
results: emptyResults
|
|
||||||
};
|
|
||||||
var parentSuite = {
|
|
||||||
description: "kitchen",
|
|
||||||
parentSuite: grandparentSuite,
|
|
||||||
results: emptyResults
|
|
||||||
};
|
|
||||||
reporter.reportSuiteResults({ description: "oven", parentSuite: parentSuite, results: emptyResults });
|
|
||||||
|
|
||||||
expect(reporter.suiteResults[0].description).toEqual("My house kitchen oven");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("gathers failing spec results from the suite - the spec must have a description.", function() {
|
|
||||||
reporter.reportSuiteResults({description:"Oven",
|
|
||||||
results: function() {
|
|
||||||
return {
|
|
||||||
items_:[
|
|
||||||
{ failedCount: 0, description: "specOne" },
|
|
||||||
{ failedCount: 99, description: "specTwo" },
|
|
||||||
{ failedCount: 0, description: "specThree" },
|
|
||||||
{ failedCount: 88, description: "specFour" },
|
|
||||||
{ failedCount: 3 }
|
|
||||||
]
|
|
||||||
};
|
|
||||||
}});
|
|
||||||
|
|
||||||
expect(reporter.suiteResults[0].failedSpecResults).
|
|
||||||
toEqual([
|
|
||||||
{ failedCount: 99, description: "specTwo" },
|
|
||||||
{ failedCount: 88, description: "specFour" }
|
|
||||||
]);
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('and finishes', function() {
|
|
||||||
|
|
||||||
describe('when reporting spec failure information', function() {
|
|
||||||
|
|
||||||
it("prints suite and spec descriptions together as a sentence", function() {
|
|
||||||
reporter.suiteResults = [
|
|
||||||
{description:"The oven", failedSpecResults:[
|
|
||||||
{description:"heats up", items_:[]},
|
|
||||||
{description:"cleans itself", items_:[]}
|
|
||||||
]},
|
|
||||||
{description:"The mixer", failedSpecResults:[
|
|
||||||
{description:"blends things together", items_:[]}
|
|
||||||
]}
|
|
||||||
];
|
|
||||||
|
|
||||||
reporter.reportRunnerResults(failingRun);
|
|
||||||
|
|
||||||
expect(out.getOutput()).toContain("The oven heats up");
|
|
||||||
expect(out.getOutput()).toContain("The oven cleans itself");
|
|
||||||
expect(out.getOutput()).toContain("The mixer blends things together");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("prints stack trace of spec failure", function() {
|
|
||||||
reporter.suiteResults = [
|
|
||||||
{description:"The oven", failedSpecResults:[
|
|
||||||
{description:"heats up",
|
|
||||||
items_:[
|
|
||||||
{trace:{stack:"stack trace one"}},
|
|
||||||
{trace:{stack:"stack trace two"}}
|
|
||||||
]}
|
|
||||||
]}
|
|
||||||
];
|
|
||||||
|
|
||||||
reporter.reportRunnerResults(failingRun);
|
|
||||||
|
|
||||||
expect(out.getOutput()).toContain("The oven heats up");
|
|
||||||
expect(out.getOutput()).toContain("stack trace one");
|
|
||||||
expect(out.getOutput()).toContain("stack trace two");
|
|
||||||
});
|
|
||||||
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('when reporting the execution time', function() {
|
|
||||||
|
|
||||||
it("prints the full finished message", function() {
|
|
||||||
reporter.now = function() {
|
|
||||||
return 1000;
|
|
||||||
};
|
|
||||||
reporter.reportRunnerStarting();
|
|
||||||
reporter.now = function() {
|
|
||||||
return 1777;
|
|
||||||
};
|
|
||||||
reporter.reportRunnerResults(failingRun);
|
|
||||||
expect(out.getOutput()).toContain("Finished in 0.777 seconds");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("prints round time numbers correctly", function() {
|
|
||||||
function run(startTime, endTime) {
|
|
||||||
out.clear();
|
|
||||||
reporter.runnerStartTime = startTime;
|
|
||||||
reporter.now = function() {
|
|
||||||
return endTime;
|
|
||||||
};
|
|
||||||
reporter.reportRunnerResults(passingRun);
|
|
||||||
}
|
|
||||||
|
|
||||||
run(1000, 11000);
|
|
||||||
expect(out.getOutput()).toContain("10 seconds");
|
|
||||||
|
|
||||||
run(1000, 2000);
|
|
||||||
expect(out.getOutput()).toContain("1 seconds");
|
|
||||||
|
|
||||||
run(1000, 1100);
|
|
||||||
expect(out.getOutput()).toContain("0.1 seconds");
|
|
||||||
|
|
||||||
run(1000, 1010);
|
|
||||||
expect(out.getOutput()).toContain("0.01 seconds");
|
|
||||||
|
|
||||||
run(1000, 1001);
|
|
||||||
expect(out.getOutput()).toContain("0.001 seconds");
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("when reporting the results summary", function() {
|
|
||||||
it("prints statistics in green if there were no failures", function() {
|
|
||||||
reporter.reportRunnerResults({
|
|
||||||
specs: function() {
|
|
||||||
return [null, null, null];
|
|
||||||
},
|
|
||||||
results:function() {
|
|
||||||
return {items_: [null, null, null], totalCount: 7, failedCount: 0};
|
|
||||||
}
|
|
||||||
});
|
|
||||||
expect(out.getOutput()).
|
|
||||||
toContain("3 specs, 7 expectations, 0 failures");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("prints statistics in red if there was a failure", function() {
|
|
||||||
reporter.reportRunnerResults({
|
|
||||||
specs: function() {
|
|
||||||
return [null, null, null];
|
|
||||||
},
|
|
||||||
results:function() {
|
|
||||||
return {items_: [null, null, null], totalCount: 7, failedCount: 3};
|
|
||||||
}
|
|
||||||
});
|
|
||||||
expect(out.getOutput()).
|
|
||||||
toContain("3 specs, 7 expectations, 3 failures");
|
|
||||||
});
|
|
||||||
|
|
||||||
it("handles pluralization with 1's ones appropriately", function() {
|
|
||||||
reporter.reportRunnerResults({
|
|
||||||
specs: function() {
|
|
||||||
return [null];
|
|
||||||
},
|
|
||||||
results:function() {
|
|
||||||
return {items_: [null], totalCount: 1, failedCount: 1};
|
|
||||||
}
|
|
||||||
});
|
|
||||||
expect(out.getOutput()).
|
|
||||||
toContain("1 spec, 1 expectation, 1 failure");
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe("done callback", function() {
|
|
||||||
it("calls back when done", function() {
|
|
||||||
expect(done).toBeFalsy();
|
|
||||||
reporter.reportRunnerResults({
|
|
||||||
specs: function() {
|
|
||||||
return [null, null, null];
|
|
||||||
},
|
|
||||||
results:function() {
|
|
||||||
return {items_: [null, null, null], totalCount: 7, failedCount: 0};
|
|
||||||
}
|
|
||||||
});
|
|
||||||
expect(done).toBeTruthy();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
@ -172,9 +172,6 @@ describe("TrivialReporter", function() {
|
|||||||
var errorDiv = findElement(divs, 'resultMessage log');
|
var errorDiv = findElement(divs, 'resultMessage log');
|
||||||
expect(errorDiv.innerHTML).toEqual("this is a multipart log message");
|
expect(errorDiv.innerHTML).toEqual("this is a multipart log message");
|
||||||
});
|
});
|
||||||
|
|
||||||
xit("should work on IE without console.log.apply", function() {
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("duplicate example names", function() {
|
describe("duplicate example names", function() {
|
||||||
|
@ -25,6 +25,7 @@ describe("jasmine.util", function() {
|
|||||||
it("should return true if the argument is an array", function() {
|
it("should return true if the argument is an array", function() {
|
||||||
expect(jasmine.isArray_([])).toBe(true);
|
expect(jasmine.isArray_([])).toBe(true);
|
||||||
expect(jasmine.isArray_(['a'])).toBe(true);
|
expect(jasmine.isArray_(['a'])).toBe(true);
|
||||||
|
expect(jasmine.isArray_(new Array())).toBe(true);
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should return false if the argument is not an array", function() {
|
it("should return false if the argument is not an array", function() {
|
||||||
|
@ -10,37 +10,6 @@ describe('WaitsForBlock', function () {
|
|||||||
onComplete = jasmine.createSpy("onComplete");
|
onComplete = jasmine.createSpy("onComplete");
|
||||||
});
|
});
|
||||||
|
|
||||||
describe("jasmine.VERBOSE", function() {
|
|
||||||
var jasmineVerboseOriginal;
|
|
||||||
beforeEach(function() {
|
|
||||||
jasmineVerboseOriginal = jasmine.VERBOSE;
|
|
||||||
spyOn(env.reporter, 'log');
|
|
||||||
|
|
||||||
});
|
|
||||||
it('do not show information if jasmine.VERBOSE is set to false', function () {
|
|
||||||
jasmine.VERBOSE = false;
|
|
||||||
var latchFunction = function() {
|
|
||||||
return true;
|
|
||||||
};
|
|
||||||
var block = new jasmine.WaitsForBlock(env, timeout, latchFunction, message, spec);
|
|
||||||
expect(env.reporter.log).not.toHaveBeenCalled();
|
|
||||||
block.execute(onComplete);
|
|
||||||
expect(env.reporter.log).not.toHaveBeenCalled();
|
|
||||||
jasmine.VERBOSE = jasmineVerboseOriginal;
|
|
||||||
});
|
|
||||||
it('show information if jasmine.VERBOSE is set to true', function () {
|
|
||||||
jasmine.VERBOSE = true;
|
|
||||||
var latchFunction = function() {
|
|
||||||
return true;
|
|
||||||
};
|
|
||||||
var block = new jasmine.WaitsForBlock(env, timeout, latchFunction, message, spec);
|
|
||||||
expect(env.reporter.log).not.toHaveBeenCalled();
|
|
||||||
block.execute(onComplete);
|
|
||||||
expect(env.reporter.log).toHaveBeenCalled();
|
|
||||||
jasmine.VERBOSE = jasmineVerboseOriginal;
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
it('onComplete should be called if the latchFunction returns true', function () {
|
it('onComplete should be called if the latchFunction returns true', function () {
|
||||||
var latchFunction = function() {
|
var latchFunction = function() {
|
||||||
return true;
|
return true;
|
||||||
|
@ -104,14 +104,14 @@ jasmine.Env.prototype.describe = function(description, specDefinitions) {
|
|||||||
declarationError = e;
|
declarationError = e;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.currentSuite = parentSuite;
|
||||||
|
|
||||||
if (declarationError) {
|
if (declarationError) {
|
||||||
this.it("encountered a declaration exception", function() {
|
this.it("encountered a declaration exception", function() {
|
||||||
throw declarationError;
|
throw declarationError;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
this.currentSuite = parentSuite;
|
|
||||||
|
|
||||||
return suite;
|
return suite;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -172,7 +172,7 @@ jasmine.Env.prototype.compareObjects_ = function(a, b, mismatchKeys, mismatchVal
|
|||||||
b.__Jasmine_been_here_before__ = a;
|
b.__Jasmine_been_here_before__ = a;
|
||||||
|
|
||||||
var hasKey = function(obj, keyName) {
|
var hasKey = function(obj, keyName) {
|
||||||
return obj !== null && obj[keyName] !== jasmine.undefined;
|
return obj != null && obj[keyName] !== jasmine.undefined;
|
||||||
};
|
};
|
||||||
|
|
||||||
for (var property in b) {
|
for (var property in b) {
|
||||||
@ -198,7 +198,7 @@ jasmine.Env.prototype.compareObjects_ = function(a, b, mismatchKeys, mismatchVal
|
|||||||
|
|
||||||
delete a.__Jasmine_been_here_before__;
|
delete a.__Jasmine_been_here_before__;
|
||||||
delete b.__Jasmine_been_here_before__;
|
delete b.__Jasmine_been_here_before__;
|
||||||
return (mismatchKeys.length === 0 && mismatchValues.length === 0);
|
return (mismatchKeys.length == 0 && mismatchValues.length == 0);
|
||||||
};
|
};
|
||||||
|
|
||||||
jasmine.Env.prototype.equals_ = function(a, b, mismatchKeys, mismatchValues) {
|
jasmine.Env.prototype.equals_ = function(a, b, mismatchKeys, mismatchValues) {
|
@ -227,16 +227,16 @@ jasmine.Matchers.prototype.toHaveBeenCalledWith = function() {
|
|||||||
throw new Error('Expected a spy, but got ' + jasmine.pp(this.actual) + '.');
|
throw new Error('Expected a spy, but got ' + jasmine.pp(this.actual) + '.');
|
||||||
}
|
}
|
||||||
this.message = function() {
|
this.message = function() {
|
||||||
if (this.actual.callCount === 0) {
|
if (this.actual.callCount == 0) {
|
||||||
// todo: what should the failure message for .not.toHaveBeenCalledWith() be? is this right? test better. [xw]
|
// todo: what should the failure message for .not.toHaveBeenCalledWith() be? is this right? test better. [xw]
|
||||||
return [
|
return [
|
||||||
"Expected spy " + this.actual.identity + " to have been called with " + jasmine.pp(expectedArgs) + " but it was never called.",
|
"Expected spy to have been called with " + jasmine.pp(expectedArgs) + " but it was never called.",
|
||||||
"Expected spy " + this.actual.identity + " not to have been called with " + jasmine.pp(expectedArgs) + " but it was."
|
"Expected spy not to have been called with " + jasmine.pp(expectedArgs) + " but it was."
|
||||||
];
|
];
|
||||||
} else {
|
} else {
|
||||||
return [
|
return [
|
||||||
"Expected spy " + this.actual.identity + " to have been called with " + jasmine.pp(expectedArgs) + " but was called with " + jasmine.pp(this.actual.argsForCall),
|
"Expected spy to have been called with " + jasmine.pp(expectedArgs) + " but was called with " + jasmine.pp(this.actual.argsForCall),
|
||||||
"Expected spy " + this.actual.identity + " not to have been called with " + jasmine.pp(expectedArgs) + " but was called with " + jasmine.pp(this.actual.argsForCall)
|
"Expected spy not to have been called with " + jasmine.pp(expectedArgs) + " but was called with " + jasmine.pp(this.actual.argsForCall)
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -258,7 +258,7 @@ jasmine.Matchers.prototype.wasNotCalledWith = function() {
|
|||||||
return [
|
return [
|
||||||
"Expected spy not to have been called with " + jasmine.pp(expectedArgs) + " but it was",
|
"Expected spy not to have been called with " + jasmine.pp(expectedArgs) + " but it was",
|
||||||
"Expected spy to have been called with " + jasmine.pp(expectedArgs) + " but it was"
|
"Expected spy to have been called with " + jasmine.pp(expectedArgs) + " but it was"
|
||||||
];
|
]
|
||||||
};
|
};
|
||||||
|
|
||||||
return !this.env.contains_(this.actual.argsForCall, expectedArgs);
|
return !this.env.contains_(this.actual.argsForCall, expectedArgs);
|
||||||
@ -291,23 +291,6 @@ jasmine.Matchers.prototype.toBeGreaterThan = function(expected) {
|
|||||||
return this.actual > expected;
|
return this.actual > expected;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* Matcher that checks that the expected item is equal to the actual item
|
|
||||||
* up to a given level of decimal precision (default 2).
|
|
||||||
*
|
|
||||||
* @param {Number} expected
|
|
||||||
* @param {Number} precision
|
|
||||||
*/
|
|
||||||
jasmine.Matchers.prototype.toBeCloseTo = function(expected, precision) {
|
|
||||||
if (!(precision === 0)) {
|
|
||||||
precision = precision || 2;
|
|
||||||
}
|
|
||||||
var multiplier = Math.pow(10, precision);
|
|
||||||
var actual = Math.round(this.actual * multiplier);
|
|
||||||
expected = Math.round(expected * multiplier);
|
|
||||||
return expected == actual;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Matcher that checks that the expected exception was thrown by the actual.
|
* Matcher that checks that the expected exception was thrown by the actual.
|
||||||
*
|
*
|
||||||
@ -332,7 +315,7 @@ jasmine.Matchers.prototype.toThrow = function(expected) {
|
|||||||
|
|
||||||
this.message = function() {
|
this.message = function() {
|
||||||
if (exception && (expected === jasmine.undefined || !this.env.equals_(exception.message || exception, expected.message || expected))) {
|
if (exception && (expected === jasmine.undefined || !this.env.equals_(exception.message || exception, expected.message || expected))) {
|
||||||
return ["Expected function " + not + "to throw", expected ? expected.message || expected : "an exception", ", but it threw", exception.message || exception].join(' ');
|
return ["Expected function " + not + "to throw", expected ? expected.message || expected : " an exception", ", but it threw", exception.message || exception].join(' ');
|
||||||
} else {
|
} else {
|
||||||
return "Expected function to throw an exception.";
|
return "Expected function to throw an exception.";
|
||||||
}
|
}
|
@ -58,8 +58,7 @@ jasmine.PrettyPrinter.prototype.format = function(value) {
|
|||||||
jasmine.PrettyPrinter.prototype.iterateObject = function(obj, fn) {
|
jasmine.PrettyPrinter.prototype.iterateObject = function(obj, fn) {
|
||||||
for (var property in obj) {
|
for (var property in obj) {
|
||||||
if (property == '__Jasmine_been_here_before__') continue;
|
if (property == '__Jasmine_been_here_before__') continue;
|
||||||
fn(property, obj.__lookupGetter__ ? (obj.__lookupGetter__(property) !== jasmine.undefined &&
|
fn(property, obj.__lookupGetter__ ? (obj.__lookupGetter__(property) != null) : false);
|
||||||
obj.__lookupGetter__(property) !== null) : false);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
@ -1,7 +0,0 @@
|
|||||||
[
|
|
||||||
"base.js",
|
|
||||||
"util.js",
|
|
||||||
"Env.js",
|
|
||||||
"Reporter.js",
|
|
||||||
"Block.js"
|
|
||||||
]
|
|
@ -29,8 +29,7 @@ jasmine.Spec = function(env, suite, description) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
jasmine.Spec.prototype.getFullName = function() {
|
jasmine.Spec.prototype.getFullName = function() {
|
||||||
var description = (this.description.apply ? this.description.name : this.description);
|
return this.suite.getFullName() + ' ' + this.description + '.';
|
||||||
return this.suite.getFullName() + ' ' + description + '.';
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -121,8 +120,7 @@ jasmine.Spec.prototype.waitsFor = function(latchFunction, optional_timeoutMessag
|
|||||||
jasmine.Spec.prototype.fail = function (e) {
|
jasmine.Spec.prototype.fail = function (e) {
|
||||||
var expectationResult = new jasmine.ExpectationResult({
|
var expectationResult = new jasmine.ExpectationResult({
|
||||||
passed: false,
|
passed: false,
|
||||||
message: e ? jasmine.util.formatException(e) : 'Exception',
|
message: e ? jasmine.util.formatException(e) : 'Exception'
|
||||||
trace: { stack: e.stack }
|
|
||||||
});
|
});
|
||||||
this.results_.addResult(expectationResult);
|
this.results_.addResult(expectationResult);
|
||||||
};
|
};
|
@ -22,7 +22,7 @@ jasmine.Suite = function(env, description, specDefinitions, parentSuite) {
|
|||||||
};
|
};
|
||||||
|
|
||||||
jasmine.Suite.prototype.getFullName = function() {
|
jasmine.Suite.prototype.getFullName = function() {
|
||||||
var fullName = (this.description.apply ? this.description.name : this.description);
|
var fullName = this.description;
|
||||||
for (var parentSuite = this.parentSuite; parentSuite; parentSuite = parentSuite.parentSuite) {
|
for (var parentSuite = this.parentSuite; parentSuite; parentSuite = parentSuite.parentSuite) {
|
||||||
fullName = parentSuite.description + ' ' + fullName;
|
fullName = parentSuite.description + ' ' + fullName;
|
||||||
}
|
}
|
@ -6,9 +6,7 @@ jasmine.WaitsBlock = function(env, timeout, spec) {
|
|||||||
jasmine.util.inherit(jasmine.WaitsBlock, jasmine.Block);
|
jasmine.util.inherit(jasmine.WaitsBlock, jasmine.Block);
|
||||||
|
|
||||||
jasmine.WaitsBlock.prototype.execute = function (onComplete) {
|
jasmine.WaitsBlock.prototype.execute = function (onComplete) {
|
||||||
if (jasmine.VERBOSE) {
|
|
||||||
this.env.reporter.log('>> Jasmine waiting for ' + this.timeout + ' ms...');
|
this.env.reporter.log('>> Jasmine waiting for ' + this.timeout + ' ms...');
|
||||||
}
|
|
||||||
this.env.setTimeout(function () {
|
this.env.setTimeout(function () {
|
||||||
onComplete();
|
onComplete();
|
||||||
}, this.timeout);
|
}, this.timeout);
|
@ -21,9 +21,7 @@ jasmine.util.inherit(jasmine.WaitsForBlock, jasmine.Block);
|
|||||||
jasmine.WaitsForBlock.TIMEOUT_INCREMENT = 10;
|
jasmine.WaitsForBlock.TIMEOUT_INCREMENT = 10;
|
||||||
|
|
||||||
jasmine.WaitsForBlock.prototype.execute = function(onComplete) {
|
jasmine.WaitsForBlock.prototype.execute = function(onComplete) {
|
||||||
if (jasmine.VERBOSE) {
|
|
||||||
this.env.reporter.log('>> Jasmine waiting for ' + (this.message || 'something to happen'));
|
this.env.reporter.log('>> Jasmine waiting for ' + (this.message || 'something to happen'));
|
||||||
}
|
|
||||||
var latchFunctionResult;
|
var latchFunctionResult;
|
||||||
try {
|
try {
|
||||||
latchFunctionResult = this.latchFunction.apply(this.spec);
|
latchFunctionResult = this.latchFunction.apply(this.spec);
|
@ -1,12 +1,10 @@
|
|||||||
var isCommonJS = typeof window == "undefined";
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Top level namespace for Jasmine, a lightweight JavaScript BDD/spec/testing framework.
|
* Top level namespace for Jasmine, a lightweight JavaScript BDD/spec/testing framework.
|
||||||
*
|
*
|
||||||
* @namespace
|
* @namespace
|
||||||
*/
|
*/
|
||||||
var jasmine = {};
|
var jasmine = {};
|
||||||
if (isCommonJS) exports.jasmine = jasmine;
|
|
||||||
/**
|
/**
|
||||||
* @private
|
* @private
|
||||||
*/
|
*/
|
||||||
@ -22,12 +20,6 @@ jasmine.unimplementedMethod_ = function() {
|
|||||||
*/
|
*/
|
||||||
jasmine.undefined = jasmine.___undefined___;
|
jasmine.undefined = jasmine.___undefined___;
|
||||||
|
|
||||||
/**
|
|
||||||
* Show diagnostic messages in the console if set to true
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
jasmine.VERBOSE = false;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Default interval in milliseconds for event loop yields (e.g. to allow network activity or to refresh the screen with the HTML-based runner). Small values here may result in slow test running. Zero means no updates until all tests have completed.
|
* Default interval in milliseconds for event loop yields (e.g. to allow network activity or to refresh the screen with the HTML-based runner). Small values here may result in slow test running. Zero means no updates until all tests have completed.
|
||||||
*
|
*
|
||||||
@ -80,7 +72,7 @@ jasmine.MessageResult = function(values) {
|
|||||||
|
|
||||||
jasmine.MessageResult.prototype.toString = function() {
|
jasmine.MessageResult.prototype.toString = function() {
|
||||||
var text = "";
|
var text = "";
|
||||||
for (var i = 0; i < this.values.length; i++) {
|
for(var i = 0; i < this.values.length; i++) {
|
||||||
if (i > 0) text += " ";
|
if (i > 0) text += " ";
|
||||||
if (jasmine.isString_(this.values[i])) {
|
if (jasmine.isString_(this.values[i])) {
|
||||||
text += this.values[i];
|
text += this.values[i];
|
||||||
@ -97,10 +89,9 @@ jasmine.ExpectationResult = function(params) {
|
|||||||
this.passed_ = params.passed;
|
this.passed_ = params.passed;
|
||||||
this.expected = params.expected;
|
this.expected = params.expected;
|
||||||
this.actual = params.actual;
|
this.actual = params.actual;
|
||||||
this.message = this.passed_ ? 'Passed.' : params.message;
|
|
||||||
|
|
||||||
var trace = (params.trace || new Error(this.message));
|
this.message = this.passed_ ? 'Passed.' : params.message;
|
||||||
this.trace = this.passed_ ? '' : trace;
|
this.trace = this.passed_ ? '' : new Error(this.message);
|
||||||
};
|
};
|
||||||
|
|
||||||
jasmine.ExpectationResult.prototype.toString = function () {
|
jasmine.ExpectationResult.prototype.toString = function () {
|
||||||
@ -115,8 +106,7 @@ jasmine.ExpectationResult.prototype.passed = function () {
|
|||||||
* Getter for the Jasmine environment. Ensures one gets created
|
* Getter for the Jasmine environment. Ensures one gets created
|
||||||
*/
|
*/
|
||||||
jasmine.getEnv = function() {
|
jasmine.getEnv = function() {
|
||||||
var env = jasmine.currentEnv_ = jasmine.currentEnv_ || new jasmine.Env();
|
return jasmine.currentEnv_ = jasmine.currentEnv_ || new jasmine.Env();
|
||||||
return env;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -179,7 +169,7 @@ jasmine.pp = function(value) {
|
|||||||
* @returns {Boolean}
|
* @returns {Boolean}
|
||||||
*/
|
*/
|
||||||
jasmine.isDomNode = function(obj) {
|
jasmine.isDomNode = function(obj) {
|
||||||
return obj.nodeType > 0;
|
return obj['nodeType'] > 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -415,7 +405,7 @@ jasmine.isSpy = function(putativeSpy) {
|
|||||||
* @param {Array} methodNames array of names of methods to make spies
|
* @param {Array} methodNames array of names of methods to make spies
|
||||||
*/
|
*/
|
||||||
jasmine.createSpyObj = function(baseName, methodNames) {
|
jasmine.createSpyObj = function(baseName, methodNames) {
|
||||||
if (!jasmine.isArray_(methodNames) || methodNames.length === 0) {
|
if (!jasmine.isArray_(methodNames) || methodNames.length == 0) {
|
||||||
throw new Error('createSpyObj requires a non-empty array of method names to create spies for');
|
throw new Error('createSpyObj requires a non-empty array of method names to create spies for');
|
||||||
}
|
}
|
||||||
var obj = {};
|
var obj = {};
|
||||||
@ -453,7 +443,6 @@ jasmine.log = function() {
|
|||||||
var spyOn = function(obj, methodName) {
|
var spyOn = function(obj, methodName) {
|
||||||
return jasmine.getEnv().currentSpec.spyOn(obj, methodName);
|
return jasmine.getEnv().currentSpec.spyOn(obj, methodName);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.spyOn = spyOn;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a Jasmine spec that will be added to the current suite.
|
* Creates a Jasmine spec that will be added to the current suite.
|
||||||
@ -471,7 +460,6 @@ if (isCommonJS) exports.spyOn = spyOn;
|
|||||||
var it = function(desc, func) {
|
var it = function(desc, func) {
|
||||||
return jasmine.getEnv().it(desc, func);
|
return jasmine.getEnv().it(desc, func);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.it = it;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a <em>disabled</em> Jasmine spec.
|
* Creates a <em>disabled</em> Jasmine spec.
|
||||||
@ -484,7 +472,6 @@ if (isCommonJS) exports.it = it;
|
|||||||
var xit = function(desc, func) {
|
var xit = function(desc, func) {
|
||||||
return jasmine.getEnv().xit(desc, func);
|
return jasmine.getEnv().xit(desc, func);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.xit = xit;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Starts a chain for a Jasmine expectation.
|
* Starts a chain for a Jasmine expectation.
|
||||||
@ -497,7 +484,6 @@ if (isCommonJS) exports.xit = xit;
|
|||||||
var expect = function(actual) {
|
var expect = function(actual) {
|
||||||
return jasmine.getEnv().currentSpec.expect(actual);
|
return jasmine.getEnv().currentSpec.expect(actual);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.expect = expect;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines part of a jasmine spec. Used in cominbination with waits or waitsFor in asynchrnous specs.
|
* Defines part of a jasmine spec. Used in cominbination with waits or waitsFor in asynchrnous specs.
|
||||||
@ -507,7 +493,6 @@ if (isCommonJS) exports.expect = expect;
|
|||||||
var runs = function(func) {
|
var runs = function(func) {
|
||||||
jasmine.getEnv().currentSpec.runs(func);
|
jasmine.getEnv().currentSpec.runs(func);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.runs = runs;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Waits a fixed time period before moving to the next block.
|
* Waits a fixed time period before moving to the next block.
|
||||||
@ -518,7 +503,6 @@ if (isCommonJS) exports.runs = runs;
|
|||||||
var waits = function(timeout) {
|
var waits = function(timeout) {
|
||||||
jasmine.getEnv().currentSpec.waits(timeout);
|
jasmine.getEnv().currentSpec.waits(timeout);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.waits = waits;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Waits for the latchFunction to return true before proceeding to the next block.
|
* Waits for the latchFunction to return true before proceeding to the next block.
|
||||||
@ -530,7 +514,6 @@ if (isCommonJS) exports.waits = waits;
|
|||||||
var waitsFor = function(latchFunction, optional_timeoutMessage, optional_timeout) {
|
var waitsFor = function(latchFunction, optional_timeoutMessage, optional_timeout) {
|
||||||
jasmine.getEnv().currentSpec.waitsFor.apply(jasmine.getEnv().currentSpec, arguments);
|
jasmine.getEnv().currentSpec.waitsFor.apply(jasmine.getEnv().currentSpec, arguments);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.waitsFor = waitsFor;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A function that is called before each spec in a suite.
|
* A function that is called before each spec in a suite.
|
||||||
@ -542,7 +525,6 @@ if (isCommonJS) exports.waitsFor = waitsFor;
|
|||||||
var beforeEach = function(beforeEachFunction) {
|
var beforeEach = function(beforeEachFunction) {
|
||||||
jasmine.getEnv().beforeEach(beforeEachFunction);
|
jasmine.getEnv().beforeEach(beforeEachFunction);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.beforeEach = beforeEach;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A function that is called after each spec in a suite.
|
* A function that is called after each spec in a suite.
|
||||||
@ -554,7 +536,6 @@ if (isCommonJS) exports.beforeEach = beforeEach;
|
|||||||
var afterEach = function(afterEachFunction) {
|
var afterEach = function(afterEachFunction) {
|
||||||
jasmine.getEnv().afterEach(afterEachFunction);
|
jasmine.getEnv().afterEach(afterEachFunction);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.afterEach = afterEach;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defines a suite of specifications.
|
* Defines a suite of specifications.
|
||||||
@ -574,7 +555,6 @@ if (isCommonJS) exports.afterEach = afterEach;
|
|||||||
var describe = function(description, specDefinitions) {
|
var describe = function(description, specDefinitions) {
|
||||||
return jasmine.getEnv().describe(description, specDefinitions);
|
return jasmine.getEnv().describe(description, specDefinitions);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.describe = describe;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Disables a suite of specifications. Used to disable some suites in a file, or files, temporarily during development.
|
* Disables a suite of specifications. Used to disable some suites in a file, or files, temporarily during development.
|
||||||
@ -585,33 +565,25 @@ if (isCommonJS) exports.describe = describe;
|
|||||||
var xdescribe = function(description, specDefinitions) {
|
var xdescribe = function(description, specDefinitions) {
|
||||||
return jasmine.getEnv().xdescribe(description, specDefinitions);
|
return jasmine.getEnv().xdescribe(description, specDefinitions);
|
||||||
};
|
};
|
||||||
if (isCommonJS) exports.xdescribe = xdescribe;
|
|
||||||
|
|
||||||
|
|
||||||
// Provide the XMLHttpRequest class for IE 5.x-6.x:
|
// Provide the XMLHttpRequest class for IE 5.x-6.x:
|
||||||
jasmine.XmlHttpRequest = (typeof XMLHttpRequest == "undefined") ? function() {
|
jasmine.XmlHttpRequest = (typeof XMLHttpRequest == "undefined") ? function() {
|
||||||
function tryIt(f) {
|
|
||||||
try {
|
try {
|
||||||
return f();
|
return new ActiveXObject("Msxml2.XMLHTTP.6.0");
|
||||||
} catch(e) {
|
} catch(e) {
|
||||||
}
|
}
|
||||||
return null;
|
try {
|
||||||
}
|
|
||||||
|
|
||||||
var xhr = tryIt(function() {
|
|
||||||
return new ActiveXObject("Msxml2.XMLHTTP.6.0");
|
|
||||||
}) ||
|
|
||||||
tryIt(function() {
|
|
||||||
return new ActiveXObject("Msxml2.XMLHTTP.3.0");
|
return new ActiveXObject("Msxml2.XMLHTTP.3.0");
|
||||||
}) ||
|
} catch(e) {
|
||||||
tryIt(function() {
|
}
|
||||||
|
try {
|
||||||
return new ActiveXObject("Msxml2.XMLHTTP");
|
return new ActiveXObject("Msxml2.XMLHTTP");
|
||||||
}) ||
|
} catch(e) {
|
||||||
tryIt(function() {
|
}
|
||||||
|
try {
|
||||||
return new ActiveXObject("Microsoft.XMLHTTP");
|
return new ActiveXObject("Microsoft.XMLHTTP");
|
||||||
});
|
} catch(e) {
|
||||||
|
}
|
||||||
if (!xhr) throw new Error("This browser does not support XMLHttpRequest.");
|
throw new Error("This browser does not support XMLHttpRequest.");
|
||||||
|
|
||||||
return xhr;
|
|
||||||
} : XMLHttpRequest;
|
} : XMLHttpRequest;
|
@ -1,193 +0,0 @@
|
|||||||
jasmine.TrivialConsoleReporter = function(print, doneCallback) {
|
|
||||||
//inspired by mhevery's jasmine-node reporter
|
|
||||||
//https://github.com/mhevery/jasmine-node
|
|
||||||
|
|
||||||
doneCallback = doneCallback || function() {
|
|
||||||
};
|
|
||||||
|
|
||||||
var defaultColumnsPerLine = 50,
|
|
||||||
ansi = {
|
|
||||||
green: '\033[32m',
|
|
||||||
red: '\033[31m',
|
|
||||||
yellow: '\033[33m',
|
|
||||||
none: '\033[0m'
|
|
||||||
},
|
|
||||||
language = {
|
|
||||||
spec: "spec",
|
|
||||||
expectation: "expectation",
|
|
||||||
failure: "failure"
|
|
||||||
};
|
|
||||||
|
|
||||||
function coloredStr(color, str) {
|
|
||||||
return ansi[color] + str + ansi.none;
|
|
||||||
}
|
|
||||||
|
|
||||||
function greenStr(str) {
|
|
||||||
return coloredStr("green", str);
|
|
||||||
}
|
|
||||||
|
|
||||||
function redStr(str) {
|
|
||||||
return coloredStr("red", str);
|
|
||||||
}
|
|
||||||
|
|
||||||
function yellowStr(str) {
|
|
||||||
return coloredStr("yellow", str);
|
|
||||||
}
|
|
||||||
|
|
||||||
function newline() {
|
|
||||||
print("\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
function started() {
|
|
||||||
print("Started");
|
|
||||||
newline();
|
|
||||||
}
|
|
||||||
|
|
||||||
function greenDot() {
|
|
||||||
print(greenStr("."));
|
|
||||||
}
|
|
||||||
|
|
||||||
function redF() {
|
|
||||||
print(redStr("F"));
|
|
||||||
}
|
|
||||||
|
|
||||||
function yellowStar() {
|
|
||||||
print(yellowStr("*"));
|
|
||||||
}
|
|
||||||
|
|
||||||
function plural(str, count) {
|
|
||||||
return count == 1 ? str : str + "s";
|
|
||||||
}
|
|
||||||
|
|
||||||
function repeat(thing, times) {
|
|
||||||
var arr = [];
|
|
||||||
for (var i = 0; i < times; i++) arr.push(thing);
|
|
||||||
return arr;
|
|
||||||
}
|
|
||||||
|
|
||||||
function indent(str, spaces) {
|
|
||||||
var lines = (str || '').split("\n");
|
|
||||||
var newArr = [];
|
|
||||||
for (var i = 0; i < lines.length; i++) {
|
|
||||||
newArr.push(repeat(" ", spaces).join("") + lines[i]);
|
|
||||||
}
|
|
||||||
return newArr.join("\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
function specFailureDetails(suiteDescription, specDescription, stackTraces) {
|
|
||||||
newline();
|
|
||||||
print(suiteDescription + " " + specDescription);
|
|
||||||
newline();
|
|
||||||
for (var i = 0; i < stackTraces.length; i++) {
|
|
||||||
print(indent(stackTraces[i], 2));
|
|
||||||
newline();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function finished(elapsed) {
|
|
||||||
newline();
|
|
||||||
print("Finished in " + elapsed / 1000 + " seconds");
|
|
||||||
}
|
|
||||||
|
|
||||||
function summary(colorF, specs, expectations, failed) {
|
|
||||||
newline();
|
|
||||||
print(colorF(specs + " " + plural(language.spec, specs) + ", " +
|
|
||||||
expectations + " " + plural(language.expectation, expectations) + ", " +
|
|
||||||
failed + " " + plural(language.failure, failed)));
|
|
||||||
newline();
|
|
||||||
newline();
|
|
||||||
}
|
|
||||||
|
|
||||||
function greenSummary(specs, expectations, failed) {
|
|
||||||
summary(greenStr, specs, expectations, failed);
|
|
||||||
}
|
|
||||||
|
|
||||||
function redSummary(specs, expectations, failed) {
|
|
||||||
summary(redStr, specs, expectations, failed);
|
|
||||||
}
|
|
||||||
|
|
||||||
function lineEnder(columnsPerLine) {
|
|
||||||
var columnsSoFar = 0;
|
|
||||||
return function() {
|
|
||||||
columnsSoFar += 1;
|
|
||||||
if (columnsSoFar == columnsPerLine) {
|
|
||||||
newline();
|
|
||||||
columnsSoFar = 0;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
function fullSuiteDescription(suite) {
|
|
||||||
var fullDescription = suite.description;
|
|
||||||
if (suite.parentSuite) fullDescription = fullSuiteDescription(suite.parentSuite) + " " + fullDescription;
|
|
||||||
return fullDescription;
|
|
||||||
}
|
|
||||||
|
|
||||||
var startNewLineIfNecessary = lineEnder(defaultColumnsPerLine);
|
|
||||||
|
|
||||||
this.now = function() {
|
|
||||||
return new Date().getTime();
|
|
||||||
};
|
|
||||||
|
|
||||||
this.reportRunnerStarting = function() {
|
|
||||||
this.runnerStartTime = this.now();
|
|
||||||
started();
|
|
||||||
};
|
|
||||||
|
|
||||||
this.reportSpecStarting = function() { /* do nothing */
|
|
||||||
};
|
|
||||||
|
|
||||||
this.reportSpecResults = function(spec) {
|
|
||||||
var results = spec.results();
|
|
||||||
if (results.skipped) {
|
|
||||||
yellowStar();
|
|
||||||
} else if (results.passed()) {
|
|
||||||
greenDot();
|
|
||||||
} else {
|
|
||||||
redF();
|
|
||||||
}
|
|
||||||
// startNewLineIfNecessary();
|
|
||||||
};
|
|
||||||
|
|
||||||
this.suiteResults = [];
|
|
||||||
|
|
||||||
this.reportSuiteResults = function(suite) {
|
|
||||||
var suiteResult = {
|
|
||||||
description: fullSuiteDescription(suite),
|
|
||||||
failedSpecResults: []
|
|
||||||
};
|
|
||||||
|
|
||||||
suite.results().items_.forEach(function(spec) {
|
|
||||||
if (spec.failedCount > 0 && spec.description) suiteResult.failedSpecResults.push(spec);
|
|
||||||
});
|
|
||||||
|
|
||||||
this.suiteResults.push(suiteResult);
|
|
||||||
};
|
|
||||||
|
|
||||||
function eachSpecFailure(suiteResults, callback) {
|
|
||||||
for (var i = 0; i < suiteResults.length; i++) {
|
|
||||||
var suiteResult = suiteResults[i];
|
|
||||||
for (var j = 0; j < suiteResult.failedSpecResults.length; j++) {
|
|
||||||
var failedSpecResult = suiteResult.failedSpecResults[j];
|
|
||||||
var stackTraces = [];
|
|
||||||
for (var k = 0; k < failedSpecResult.items_.length; k++) stackTraces.push(failedSpecResult.items_[k].trace.stack);
|
|
||||||
callback(suiteResult.description, failedSpecResult.description, stackTraces);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
this.reportRunnerResults = function(runner) {
|
|
||||||
newline();
|
|
||||||
|
|
||||||
eachSpecFailure(this.suiteResults, function(suiteDescription, specDescription, stackTraces) {
|
|
||||||
specFailureDetails(suiteDescription, specDescription, stackTraces);
|
|
||||||
});
|
|
||||||
|
|
||||||
finished(this.now() - this.runnerStartTime);
|
|
||||||
|
|
||||||
var results = runner.results();
|
|
||||||
var summaryFunction = results.failedCount === 0 ? greenSummary : redSummary;
|
|
||||||
summaryFunction(runner.specs().length, results.totalCount, results.failedCount);
|
|
||||||
doneCallback(runner);
|
|
||||||
};
|
|
||||||
};
|
|
@ -70,16 +70,16 @@ jasmine.TrivialReporter.prototype.reportRunnerStarting = function(runner) {
|
|||||||
this.startedAt = new Date();
|
this.startedAt = new Date();
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
showPassed.onclick = function(evt) {
|
showPassed.onchange = function(evt) {
|
||||||
if (showPassed.checked) {
|
if (evt.target.checked) {
|
||||||
self.outerDiv.className += ' show-passed';
|
self.outerDiv.className += ' show-passed';
|
||||||
} else {
|
} else {
|
||||||
self.outerDiv.className = self.outerDiv.className.replace(/ show-passed/, '');
|
self.outerDiv.className = self.outerDiv.className.replace(/ show-passed/, '');
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
showSkipped.onclick = function(evt) {
|
showSkipped.onchange = function(evt) {
|
||||||
if (showSkipped.checked) {
|
if (evt.target.checked) {
|
||||||
self.outerDiv.className += ' show-skipped';
|
self.outerDiv.className += ' show-skipped';
|
||||||
} else {
|
} else {
|
||||||
self.outerDiv.className = self.outerDiv.className.replace(/ show-skipped/, '');
|
self.outerDiv.className = self.outerDiv.className.replace(/ show-skipped/, '');
|
||||||
@ -110,7 +110,7 @@ jasmine.TrivialReporter.prototype.reportRunnerResults = function(runner) {
|
|||||||
jasmine.TrivialReporter.prototype.reportSuiteResults = function(suite) {
|
jasmine.TrivialReporter.prototype.reportSuiteResults = function(suite) {
|
||||||
var results = suite.results();
|
var results = suite.results();
|
||||||
var status = results.passed() ? 'passed' : 'failed';
|
var status = results.passed() ? 'passed' : 'failed';
|
||||||
if (results.totalCount === 0) { // todo: change this to check results.skipped
|
if (results.totalCount == 0) { // todo: change this to check results.skipped
|
||||||
status = 'skipped';
|
status = 'skipped';
|
||||||
}
|
}
|
||||||
this.suiteDivs[suite.id].className += " " + status;
|
this.suiteDivs[suite.id].className += " " + status;
|
||||||
@ -162,13 +162,7 @@ jasmine.TrivialReporter.prototype.reportSpecResults = function(spec) {
|
|||||||
|
|
||||||
jasmine.TrivialReporter.prototype.log = function() {
|
jasmine.TrivialReporter.prototype.log = function() {
|
||||||
var console = jasmine.getGlobal().console;
|
var console = jasmine.getGlobal().console;
|
||||||
if (console && console.log) {
|
if (console && console.log) console.log.apply(console, arguments);
|
||||||
if (console.log.apply) {
|
|
||||||
console.log.apply(console, arguments);
|
|
||||||
} else {
|
|
||||||
console.log(arguments); // ie fix: console.log.apply doesn't exist on ie
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
jasmine.TrivialReporter.prototype.getLocation = function() {
|
jasmine.TrivialReporter.prototype.getLocation = function() {
|
||||||
@ -183,8 +177,6 @@ jasmine.TrivialReporter.prototype.specFilter = function(spec) {
|
|||||||
paramMap[decodeURIComponent(p[0])] = decodeURIComponent(p[1]);
|
paramMap[decodeURIComponent(p[0])] = decodeURIComponent(p[1]);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!paramMap.spec) {
|
if (!paramMap["spec"]) return true;
|
||||||
return true;
|
return spec.getFullName().indexOf(paramMap["spec"]) == 0;
|
||||||
}
|
|
||||||
return spec.getFullName().indexOf(paramMap.spec) === 0;
|
|
||||||
};
|
};
|
||||||
|
@ -17,7 +17,7 @@ jasmine.util.inherit = function(childClass, parentClass) {
|
|||||||
var subclass = function() {
|
var subclass = function() {
|
||||||
};
|
};
|
||||||
subclass.prototype = parentClass.prototype;
|
subclass.prototype = parentClass.prototype;
|
||||||
childClass.prototype = new subclass();
|
childClass.prototype = new subclass;
|
||||||
};
|
};
|
||||||
|
|
||||||
jasmine.util.formatException = function(e) {
|
jasmine.util.formatException = function(e) {
|
@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"major": 1,
|
"major": 1,
|
||||||
"minor": 1,
|
"minor": 0,
|
||||||
"build": 0
|
"build": 0
|
||||||
}
|
}
|