mirror of
https://github.com/TracksApp/tracks.git
synced 2025-12-16 15:20:13 +01:00
* Ran rake rails:update * Added old actionwebservice framework * Updated RSpec and RSpec-Rails * Removed asset_packager plugin (not compatible, Scott no longer maintaining), and replaced with bundle_fu. See the bundle_fu README for more info. * Hacks to UJS and ARTS plugins, which are no longer supported. Probably should move off both UJS and RJS. * Hack to flashobject_helper plugin (upgrade to Rails 2.2-compatible version if/when it comes out.) * Hack to skinny-spec plugin, for Rails 2.2 compatibility. Should check for official release. * Hacks to resource_feeder plugin, for Rails 2.2 compatibility. Should check for official release (not likely) or move off it. * Addressed some deprecation warnings. More to come. * My mobile mime type hackery is no longer necessary with new Rails features. Yay! * Updated environment.rb.tmpl with changes TODO: * Restore view specs marked pending * Fix failing integration tests. * Try selenium tests. * Investigate OpenID support. * Address deprecation warnings. * Consider moving parts of environment.rb to initializers * Address annoying config.gem warning about highline gem
228 lines
No EOL
8.4 KiB
Ruby
228 lines
No EOL
8.4 KiB
Ruby
require File.join(File.dirname(__FILE__), '../test_helper.rb')
|
|
|
|
require "test/unit"
|
|
|
|
# require "library_file_name"
|
|
|
|
class BundleFuTest < Test::Unit::TestCase
|
|
def setup
|
|
@mock_view = MockView.new
|
|
BundleFu.init # resets BundleFu
|
|
end
|
|
|
|
def teardown
|
|
purge_cache
|
|
end
|
|
|
|
def test__bundle_js_files__should_include_js_content
|
|
@mock_view.bundle { @@content_include_all }
|
|
|
|
assert_public_files_match("/javascripts/cache/bundle.js", "function js_1()")
|
|
end
|
|
|
|
def test__bundle_js_files_with_asset_server_url
|
|
@mock_view.bundle { %(<script src="https://assets.server.com/javascripts/js_1.js?1000" type="text/javascript"></script>) }
|
|
assert_public_files_match("/javascripts/cache/bundle.js", "function js_1()")
|
|
end
|
|
|
|
def test__bundle_js_files__should_use_packr
|
|
Object.send :class_eval, <<EOF
|
|
class ::Object::Packr
|
|
def initialize
|
|
end
|
|
|
|
def pack(content, options={})
|
|
"PACKR!" + options.inspect
|
|
end
|
|
|
|
end
|
|
EOF
|
|
|
|
@mock_view.bundle() { @@content_include_all }
|
|
assert_public_files_match("/javascripts/cache/bundle.js", "PACKR")
|
|
purge_cache
|
|
|
|
@mock_view.bundle(:packr_options => {:packr_options_here => "hi_packr"}) { @@content_include_all }
|
|
assert_public_files_match("/javascripts/cache/bundle.js", "packr_options_here", "Should include packr_options")
|
|
|
|
|
|
Object.send :remove_const, "Packr"
|
|
|
|
end
|
|
|
|
def test__bundle_js_files__should_default_to_not_compressed_and_include_override_option
|
|
@mock_view.bundle() { @@content_include_all }
|
|
default_content = File.read(public_file("/javascripts/cache/bundle.js"))
|
|
purge_cache
|
|
|
|
@mock_view.bundle(:compress => false) { @@content_include_all }
|
|
uncompressed_content = File.read(public_file("/javascripts/cache/bundle.js"))
|
|
purge_cache
|
|
|
|
@mock_view.bundle(:compress => true) { @@content_include_all }
|
|
compressed_content = File.read(public_file("/javascripts/cache/bundle.js"))
|
|
purge_cache
|
|
|
|
assert default_content.length == compressed_content.length, "Should default to compressed"
|
|
assert uncompressed_content.length > compressed_content.length, "Didn't compress the content. (:compress => true) #{compressed_content.length}. (:compress => false) #{uncompressed_content.length}"
|
|
end
|
|
|
|
def test__content_remains_same__shouldnt_refresh_cache
|
|
@mock_view.bundle { @@content_include_some }
|
|
|
|
# check to see each bundle file exists and append some text to the bottom of each file
|
|
append_to_public_files(cache_files("bundle"), "BOGUS")
|
|
|
|
assert_public_files_match("/javascripts/cache/bundle.js", "BOGUS")
|
|
assert_public_files_match("/stylesheets/cache/bundle.css", "BOGUS")
|
|
|
|
@mock_view.bundle { @@content_include_some }
|
|
|
|
assert_public_files_match("/javascripts/cache/bundle.js", "BOGUS")
|
|
assert_public_files_match("/stylesheets/cache/bundle.css", "BOGUS")
|
|
end
|
|
|
|
def test__content_changes__should_refresh_cache
|
|
@mock_view.bundle { @@content_include_some }
|
|
|
|
# check to see each bundle file exists and append some text to the bottom of each file
|
|
append_to_public_files(cache_files("bundle"), "BOGUS")
|
|
assert_public_files_match(cache_files("bundle"), "BOGUS")
|
|
|
|
# now, pass in some new content. Make sure that the css/js files are regenerated
|
|
@mock_view.bundle { @@content_include_all }
|
|
assert_public_files_no_match(cache_files("bundle"), "BOGUS")
|
|
assert_public_files_no_match(cache_files("bundle"), "BOGUS")
|
|
end
|
|
|
|
def test__modified_time_differs_from_file__should_refresh_cache
|
|
@mock_view.bundle { @@content_include_some }
|
|
# we're gonna hack each of them and set all the modified times to 0
|
|
cache_files("bundle").each{|filename|
|
|
abs_filelist_path = public_file(filename + ".filelist")
|
|
b = BundleFu::FileList.open(abs_filelist_path)
|
|
b.filelist.each{|entry| entry[1] = entry[1] - 100 }
|
|
b.save_as(abs_filelist_path)
|
|
}
|
|
|
|
append_to_public_files(cache_files("bundle"), "BOGUS")
|
|
end
|
|
|
|
def test__content_remains_same_but_cache_files_dont_match_whats_in_content__shouldnt_refresh_cache
|
|
# it shouldnt parse the content unless if it differed from the last request. This scenario should never exist, and if it did it would be fixed when the server reboots.
|
|
@mock_view.bundle { @@content_include_some }
|
|
abs_filelist_path = public_file("/stylesheets/cache/bundle.css.filelist")
|
|
b = BundleFu::FileList.open(abs_filelist_path)
|
|
|
|
@mock_view.bundle { @@content_include_all }
|
|
b.save_as(abs_filelist_path)
|
|
append_to_public_files(cache_files("bundle"), "BOGUS")
|
|
|
|
@mock_view.bundle { @@content_include_all }
|
|
assert_public_files_match(cache_files("bundle"), "BOGUS")
|
|
|
|
end
|
|
|
|
def test__content_differs_slightly_but_cache_files_match__shouldnt_refresh_cache
|
|
@mock_view.bundle { @@content_include_all }
|
|
append_to_public_files(cache_files("bundle"), "BOGUS")
|
|
@mock_view.bundle { @@content_include_all + " " }
|
|
assert_public_files_match(cache_files("bundle"), "BOGUS")
|
|
end
|
|
|
|
def test__bundle__js_only__should_output_js_include_statement
|
|
@mock_view.bundle { @@content_include_some.split("\n").first }
|
|
lines = @mock_view.output.split("\n")
|
|
assert_equal(1, lines.length)
|
|
assert_match(/javascripts/, lines.first)
|
|
end
|
|
|
|
def test__bundle__css_only__should_output_css_include_statement
|
|
@mock_view.bundle { @@content_include_some.split("\n")[2] }
|
|
lines = @mock_view.output.split("\n")
|
|
|
|
assert_equal(1, lines.length)
|
|
assert_match(/stylesheets/, lines.first)
|
|
|
|
end
|
|
|
|
def test__nonexisting_file__should_use_blank_file_created_at_0_mtime
|
|
# dbg
|
|
@mock_view.bundle { %q{<script src="/javascripts/non_existing_file.js?1000" type="text/javascript"></script>} }
|
|
|
|
assert_public_files_match(cache_files("bundle").grep(/javascripts/), "FILE READ ERROR")
|
|
|
|
filelist = BundleFu::FileList.open(public_file("/javascripts/cache/bundle.js.filelist"))
|
|
assert_equal(0, filelist.filelist[0][1], "mtime for first file should be 0")
|
|
end
|
|
|
|
def test__missing_cache_filelist__should_regenerate
|
|
@mock_view.bundle { @@content_include_some }
|
|
append_to_public_files(cache_files("bundle"), "BOGUS")
|
|
|
|
# now delete the cache files
|
|
Dir[ public_file("**/*.filelist")].each{|filename| FileUtils.rm_f filename }
|
|
@mock_view.bundle { @@content_include_some }
|
|
assert_public_files_no_match(cache_files("bundle"), "BOGUS", "Should have regenerated the file, but it didn't")
|
|
end
|
|
|
|
def test__bypass__should_generate_files_but_render_normal_output
|
|
@mock_view.bundle(:bypass => true) { @@content_include_some }
|
|
assert_public_file_exists("/stylesheets/cache/bundle.css")
|
|
assert_public_file_exists("/stylesheets/cache/bundle.css.filelist")
|
|
|
|
assert_equal(@@content_include_some, @mock_view.output)
|
|
end
|
|
|
|
def test__bypass_param_set__should_honor_and_store_in_session
|
|
@mock_view.params[:bundle_fu] = "false"
|
|
@mock_view.bundle { @@content_include_some }
|
|
assert_equal(@@content_include_some, @mock_view.output)
|
|
|
|
@mock_view.params.delete(:bundle_bypass)
|
|
@mock_view.bundle { @@content_include_some }
|
|
assert_equal(@@content_include_some*2, @mock_view.output)
|
|
end
|
|
|
|
private
|
|
|
|
def purge_cache
|
|
# remove all fixtures named "bundle*"
|
|
Dir[ public_file("**/cache") ].each{|filename| FileUtils.rm_rf filename }
|
|
end
|
|
|
|
def assert_public_file_exists(filename, message=nil)
|
|
assert_file_exists(public_file(filename), message)
|
|
end
|
|
|
|
def assert_file_exists(filename, message=nil)
|
|
assert(File.exists?(filename), message || "File #{filename} expected to exist, but didnt.")
|
|
end
|
|
|
|
def assert_public_files_match(filenames, needle, message=nil)
|
|
filenames.each{|filename|
|
|
assert_public_file_exists(filename)
|
|
assert_match(needle.to_regexp, File.read(public_file(filename)), message || "expected #{filename} to match #{needle}, but doesn't.")
|
|
}
|
|
end
|
|
|
|
def assert_public_files_no_match(filenames, needle, message=nil)
|
|
filenames.each{ |filename|
|
|
assert_public_file_exists(filename)
|
|
assert_no_match(needle.to_regexp, File.read(public_file(filename)), message || "expected #{filename} to not match #{needle}, but does.")
|
|
}
|
|
end
|
|
|
|
def cache_files(name)
|
|
["/javascripts/cache/#{name}.js", "/stylesheets/cache/#{name}.css"]
|
|
end
|
|
|
|
def append_to_public_files(filenames, content)
|
|
for filename in filenames
|
|
assert_public_file_exists(filename)
|
|
File.open(public_file(filename), "a") {|f|
|
|
f.puts(content)
|
|
}
|
|
end
|
|
end
|
|
end |