testing javascript files with jslint
This commit is contained in:
parent
969f834440
commit
c7d7be6ed2
@ -9,7 +9,7 @@ Gem::Specification.new do |s|
|
|||||||
|
|
||||||
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 = ["Nick Gauthier"]
|
s.authors = ["Nick Gauthier"]
|
||||||
s.date = %q{2010-05-10}
|
s.date = %q{2010-05-24}
|
||||||
s.description = %q{Spread your tests over multiple machines to test your code faster.}
|
s.description = %q{Spread your tests over multiple machines to test your code faster.}
|
||||||
s.email = %q{nick@smartlogicsolutions.com}
|
s.email = %q{nick@smartlogicsolutions.com}
|
||||||
s.extra_rdoc_files = [
|
s.extra_rdoc_files = [
|
||||||
|
5150
lib/hydra/js/lint.js
Normal file
5150
lib/hydra/js/lint.js
Normal file
File diff suppressed because it is too large
Load Diff
@ -39,6 +39,8 @@ module Hydra #:nodoc:
|
|||||||
output = run_rspec_file(file)
|
output = run_rspec_file(file)
|
||||||
elsif file =~ /.feature$/
|
elsif file =~ /.feature$/
|
||||||
output = run_cucumber_file(file)
|
output = run_cucumber_file(file)
|
||||||
|
elsif file =~ /.js$/
|
||||||
|
output = run_javascript_file(file)
|
||||||
else
|
else
|
||||||
output = run_test_unit_file(file)
|
output = run_test_unit_file(file)
|
||||||
end
|
end
|
||||||
@ -175,6 +177,48 @@ module Hydra #:nodoc:
|
|||||||
return hydra_response.read
|
return hydra_response.read
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def run_javascript_file(file)
|
||||||
|
puts "Running #{file}"
|
||||||
|
errors = []
|
||||||
|
require 'v8'
|
||||||
|
require 'pp' #TODO REMOVE!
|
||||||
|
V8::Context.open do |context|
|
||||||
|
context.load(File.expand_path(File.join(File.dirname(__FILE__), 'js', 'lint.js')))
|
||||||
|
context['input'] = lambda{
|
||||||
|
File.read(file)
|
||||||
|
}
|
||||||
|
context['reportErrors'] = lambda{|js_errors|
|
||||||
|
js_errors.each do |e|
|
||||||
|
e = V8::To.ruby(e)
|
||||||
|
errors << "Error at line #{e['line'].to_i + 1} " +
|
||||||
|
"character #{e['character'].to_i + 1}: #{e['reason']}"
|
||||||
|
errors << e['evidence']
|
||||||
|
end
|
||||||
|
}
|
||||||
|
context.eval %{
|
||||||
|
JSLINT(input(), {
|
||||||
|
sub: true,
|
||||||
|
onevar: true,
|
||||||
|
eqeqeq: true,
|
||||||
|
plusplus: true,
|
||||||
|
bitwise: true,
|
||||||
|
regexp: true,
|
||||||
|
newcap: true,
|
||||||
|
immed: true,
|
||||||
|
strict: true,
|
||||||
|
rhino: true
|
||||||
|
});
|
||||||
|
reportErrors(JSLINT.errors);
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
if errors.empty?
|
||||||
|
return '.'
|
||||||
|
else
|
||||||
|
return errors.join("\n")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
# find all the test unit classes in a given file, so we can run their suites
|
# find all the test unit classes in a given file, so we can run their suites
|
||||||
def self.find_classes_in_file(f)
|
def self.find_classes_in_file(f)
|
||||||
code = ""
|
code = ""
|
||||||
|
4
test/fixtures/js_file.js
vendored
Normal file
4
test/fixtures/js_file.js
vendored
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
"use strict";
|
||||||
|
var thisvar;
|
||||||
|
var thatvar
|
||||||
|
|
@ -37,6 +37,12 @@ class RunnerTest < Test::Unit::TestCase
|
|||||||
Process.wait(child)
|
Process.wait(child)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
should "run a js lint file and find errors" do
|
||||||
|
runner = Hydra::Runner.new(:io => File.new('/dev/null', 'w'))
|
||||||
|
results = runner.run_file(javascript_file)
|
||||||
|
assert results =~ /Missing semicolon/
|
||||||
|
end
|
||||||
|
|
||||||
should "run two rspec tests" do
|
should "run two rspec tests" do
|
||||||
runner = Hydra::Runner.new(:io => File.new('/dev/null', 'w'))
|
runner = Hydra::Runner.new(:io => File.new('/dev/null', 'w'))
|
||||||
runner.run_file(rspec_file)
|
runner.run_file(rspec_file)
|
||||||
|
@ -42,6 +42,10 @@ class Test::Unit::TestCase
|
|||||||
def alternate_cucumber_feature_file
|
def alternate_cucumber_feature_file
|
||||||
File.expand_path(File.join(File.dirname(__FILE__), 'fixtures', 'features', 'write_alternate_file.feature'))
|
File.expand_path(File.join(File.dirname(__FILE__), 'fixtures', 'features', 'write_alternate_file.feature'))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def javascript_file
|
||||||
|
File.expand_path(File.join(File.dirname(__FILE__), 'fixtures', 'js_file.js'))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
module Hydra #:nodoc:
|
module Hydra #:nodoc:
|
||||||
|
Loading…
Reference in New Issue
Block a user