Rearrange, refactor, ruin and raze.

This commit is contained in:
Christian Williams 2009-12-28 12:08:23 -06:00
parent 945b167131
commit 0c8258996e
13 changed files with 136 additions and 67 deletions

11
Gemfile
View File

@ -0,0 +1,11 @@
gem "rake", "0.8.7"
gem "jeweler", "1.4.0"
gem "gemcutter", "0.2.1"
gem "rspec", ">= 1.1.5", :only => :testing
gem "rack", ">= 1.0.0", :only => :testing
gem "thin", ">= 1.2.4", :only => :testing
gem "selenium-rc", ">=2.1.0", :only => :testing
gem "selenium-client", ">=1.2.17", :only => :testing
disable_system_gems

View File

@ -1,10 +1,52 @@
require "#{File.dirname(__FILE__)}/vendor/gems/environment"
Bundler.require_env :rake
$LOAD_PATH.unshift File.expand_path("#{File.dirname(__FILE__)}/lib")
require 'spec'
require 'spec/rake/spectask'
desc "Run all examples"
Spec::Rake::SpecTask.new('spec') do |t|
t.spec_files = FileList['spec/**/*.rb']
end
namespace :jasmine do
# require 'jasmine'
require 'spec/jasmine_self_test_runner'
# desc "Run continuous integration tests"
# require "spec"
# require 'spec/rake/spectask'
# Spec::Rake::SpecTask.new(:ci) do |t|
# t.spec_opts = ["--color", "--format", "specdoc"]
# t.verbose = true
# t.spec_files = [JasmineHelper.meta_spec_path]
# end
task :server do
puts "your tests are here:"
puts " http://localhost:8888/run.html"
JasmineSelfTestRunner.new.start_server
end
end
desc "Run specs via server"
task :jasmine => ['jasmine:server']
namespace :jeweler do namespace :jeweler do
begin unless File.exists?('jasmine/lib')
raise "Jasmine submodule isn't present. Run git submodule init && git submodule update."
end
require 'jeweler' require 'jeweler'
require 'rake' require 'rake'
Jeweler::Tasks.new do |gemspec| Jeweler::Tasks.new do |gemspec|
gemspec.name = "jasmine-ruby" gemspec.name = "xian-test-jasmine"
gemspec.summary = "Jasmine Ruby" gemspec.summary = "Jasmine Ruby"
gemspec.description = "Javascript BDD testings" gemspec.description = "Javascript BDD testings"
gemspec.email = "ragaskar@gmail.com" gemspec.email = "ragaskar@gmail.com"
@ -16,9 +58,9 @@ namespace :jeweler do
gemspec.add_dependency('rspec', '>= 1.1.5') gemspec.add_dependency('rspec', '>= 1.1.5')
gemspec.add_dependency('rack', '>= 1.0.0') gemspec.add_dependency('rack', '>= 1.0.0')
gemspec.add_dependency('thin', '>= 1.2.4') gemspec.add_dependency('thin', '>= 1.2.4')
gemspec.add_dependency('selenium-rc', '>=2.1.0')
gemspec.add_dependency('selenium-client', '>=1.2.17')
end end
Jeweler::GemcutterTasks.new Jeweler::GemcutterTasks.new
rescue LoadError
puts "Jeweler not available. Install it with: sudo gem install technicalpickles-jeweler -s http://gems.github.com"
end
end end

View File

@ -4,12 +4,12 @@
# -*- encoding: utf-8 -*- # -*- encoding: utf-8 -*-
Gem::Specification.new do |s| Gem::Specification.new do |s|
s.name = %q{jasmine-ruby} s.name = %q{jasmine}
s.version = "0.1.0" s.version = "0.1.0"
s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version= s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
s.authors = ["Rajan Agaskar"] s.authors = ["Rajan Agaskar"]
s.date = %q{2009-11-26} s.date = %q{2009-12-27}
s.default_executable = %q{jasmine} s.default_executable = %q{jasmine}
s.description = %q{Jasmine Ruby} s.description = %q{Jasmine Ruby}
s.email = %q{ragaskar@gmail.com} s.email = %q{ragaskar@gmail.com}
@ -19,26 +19,23 @@ Gem::Specification.new do |s|
] ]
s.files = [ s.files = [
"bin/jasmine", "bin/jasmine",
"jasmine/contrib/ruby/jasmine_runner.rb",
"jasmine/contrib/ruby/jasmine_spec_builder.rb",
"jasmine/contrib/ruby/run.html",
"jasmine/lib/TrivialReporter.js", "jasmine/lib/TrivialReporter.js",
"jasmine/lib/consolex.js", "jasmine/lib/consolex.js",
"jasmine/lib/jasmine-0.10.0.js", "jasmine/lib/jasmine-0.10.0.js",
"jasmine/lib/jasmine.css", "jasmine/lib/jasmine.css",
"jasmine/lib/json2.js", "jasmine/lib/json2.js",
"lib/jasmine-ruby.rb", "lib/jasmine.rb",
"lib/jasmine-ruby/jasmine_helper.rb", "lib/jasmine/jasmine_helper.rb",
"lib/jasmine-ruby/jasmine_meta_spec.rb", "lib/jasmine/jasmine_meta_spec.rb",
"lib/jasmine-ruby/jasmine_runner.rb", "lib/jasmine/jasmine_runner.rb",
"lib/jasmine-ruby/jasmine_spec_builder.rb", "lib/jasmine/jasmine_spec_builder.rb",
"lib/jasmine-ruby/run.html", "lib/jasmine/run.html",
"templates/Rakefile", "templates/Rakefile",
"templates/example_spec.js", "templates/example_spec.js",
"templates/jasmine_helper.rb", "templates/jasmine_helper.rb",
"templates/spec_helper.js" "templates/spec_helper.js"
] ]
s.homepage = %q{http://github.com/ragaskar/jasmine-ruby} s.homepage = %q{http://github.com/ragaskar/jasmine}
s.rdoc_options = ["--charset=UTF-8"] s.rdoc_options = ["--charset=UTF-8"]
s.require_paths = ["lib"] s.require_paths = ["lib"]
s.rubygems_version = %q{1.3.5} s.rubygems_version = %q{1.3.5}

View File

@ -1,3 +0,0 @@
require 'jasmine-ruby/jasmine_helper'
require 'jasmine-ruby/jasmine_runner'
require 'jasmine-ruby/jasmine_spec_builder'

3
lib/jasmine.rb Normal file
View File

@ -0,0 +1,3 @@
require 'jasmine/jasmine_helper'
require 'jasmine/jasmine_runner'
require 'jasmine/jasmine_spec_builder'

View File

@ -34,7 +34,7 @@ class JasmineHelper
end end
def self.meta_spec_path def self.meta_spec_path
File.expand_path(File.join(File.dirname(__FILE__), '..', '..', 'lib', 'jasmine-ruby', 'jasmine_meta_spec.rb')) File.expand_path(File.join(File.dirname(__FILE__), '..', '..', 'lib', 'jasmine', 'jasmine_meta_spec.rb'))
end end
def self.files def self.files

View File

@ -148,27 +148,22 @@ module Jasmine
end end
class SimpleServer class SimpleServer
def self.start(port, root_path, spec_files_or_proc, options = {}) def self.start(port, spec_files_or_proc, options = {})
require 'thin' require 'thin'
config = { config = {
'/__suite__' => Jasmine::FocusedSuite.new(spec_files_or_proc, options), '/__suite__' => Jasmine::FocusedSuite.new(spec_files_or_proc, options),
'/run.html' => Jasmine::Redirect.new('/'), '/run.html' => Jasmine::Redirect.new('/'),
'/' => Jasmine::RunAdapter.new(spec_files_or_proc, options) '/' => Jasmine::RunAdapter.new(spec_files_or_proc, options)
} }
if (options[:mappings])
raise "Need :mappings!" unless options[:mappings]
options[:mappings].each do |from, to| options[:mappings].each do |from, to|
config[from] = Rack::File.new(to) config[from] = Rack::File.new(to)
end end
end
config["/__JASMINE_ROOT__"] = Rack::File.new(Jasmine.root) config["/__JASMINE_ROOT__"] = Rack::File.new(Jasmine.root)
file_serve_config = {
'/' => Rack::File.new(root_path)
}
app = Rack::Cascade.new([ app = Rack::Cascade.new([
Rack::URLMap.new(file_serve_config),
Rack::URLMap.new(config), Rack::URLMap.new(config),
JsAlert.new JsAlert.new
]) ])
@ -226,17 +221,24 @@ module Jasmine
end end
class Runner class Runner
def initialize(selenium_jar_path, root_path, spec_files, options={}) def initialize(options = {})
@root_path = root_path require 'selenium_rc'
@selenium_jar_path = selenium_jar_path @selenium_jar_path = SeleniumRC::Server.allocate.jar_path
@spec_files = spec_files @spec_files = spec_files
@options = options @options = options
@browser = options[:browser] ? options[:browser].delete(:browser) : 'firefox' @browser = options[:browser] ? options.delete(:browser) : 'firefox'
@selenium_pid = nil @selenium_pid = nil
@jasmine_server_pid = nil @jasmine_server_pid = nil
end end
def start_server(port = 8888)
p spec_files
Jasmine::SimpleServer.start(port, lambda { spec_files }, :mappings => {
"/spec" => spec_dir
})
end
def start def start
start_servers start_servers
@client = Jasmine::SimpleClient.new("localhost", @selenium_server_port, "*#{@browser}", "http://localhost:#{@jasmine_server_port}/") @client = Jasmine::SimpleClient.new("localhost", @selenium_server_port, "*#{@browser}", "http://localhost:#{@jasmine_server_port}/")
@ -260,7 +262,7 @@ module Jasmine
@jasmine_server_pid = fork do @jasmine_server_pid = fork do
Process.setpgrp Process.setpgrp
Jasmine::SimpleServer.start(@jasmine_server_port, @root_path, @spec_files, @options) Jasmine::SimpleServer.start(@jasmine_server_port, @spec_files, @options)
exit! 0 exit! 0
end end
puts "jasmine server started. pid is #{@jasmine_server_pid}" puts "jasmine server started. pid is #{@jasmine_server_pid}"

View File

@ -4,8 +4,8 @@ module Jasmine
class SpecBuilder class SpecBuilder
attr_accessor :suites attr_accessor :suites
def initialize(spec_files, runner) def initialize(runner)
@spec_files = spec_files @spec_files = runner.spec_files
@runner = runner @runner = runner
@spec_ids = [] @spec_ids = []
end end

View File

@ -0,0 +1,27 @@
require 'jasmine'
class JasmineSelfTestRunner < Jasmine::Runner
def proj_root
File.expand_path(File.join(File.dirname(__FILE__), ".."))
end
def src_dir
File.join(proj_root, 'src')
end
def src_files
Dir.glob(File.join(src_dir, "**/*.js"))
end
def spec_dir
File.join(proj_root, 'jasmine/spec')
end
def spec_files
Dir.glob(File.join(spec_dir, "**/*[Ss]pec.js")).collect { |f| f.sub("#{spec_dir}/", "") }
end
#
# def specs
# Jasmine.cachebust(spec_files).collect {|f| f.sub(spec_dir, "/spec")}
# end
end

View File

@ -1,17 +1,7 @@
require 'rubygems' require 'jasmine_self_test_runner'
require "selenium_rc"
JASMINE_SPEC_DIR = File.join(File.dirname(__FILE__), "..", "jasmine", "spec") jasmine_runner = JasmineSelfTestRunner.new
spec_builder = Jasmine::SpecBuilder.new(jasmine_runner)
require File.expand_path(File.join(File.dirname(__FILE__), "..", "lib", "jasmine-ruby", "jasmine_helper.rb"))
require File.expand_path(File.join(JasmineHelper.root, "contrib/ruby/jasmine_spec_builder"))
jasmine_runner = Jasmine::Runner.new(SeleniumRC::Server.new.jar_path,
JasmineHelper.spec_file_urls,
JasmineHelper.dir_mappings,
:spec_helpers => JasmineHelper.spec_helpers)
spec_builder = Jasmine::SpecBuilder.new(JasmineHelper.raw_spec_files, jasmine_runner)
should_stop = false should_stop = false

View File

@ -1,5 +1,5 @@
namespace :jasmine do namespace :jasmine do
require 'jasmine-ruby' require 'jasmine'
helper_overrides = File.expand_path(File.join(File.dirname(__FILE__), "spec/helpers/jasmine_helper.rb")) helper_overrides = File.expand_path(File.join(File.dirname(__FILE__), "spec/helpers/jasmine_helper.rb"))
if File.exist?(helper_overrides) if File.exist?(helper_overrides)
require helper_overrides require helper_overrides