-
-
Save mhaylock/6068ede8fb7616c7292301694fae5edb to your computer and use it in GitHub Desktop.
Rack Middleware to disable Disable CSS3/jQuery Animations for Capybara
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
module Rack | |
# disable CSS3 and jQuery animations in test mode for speed, consistency and avoiding timing issues. | |
# Usage for Rails: | |
# in config/environments/test.rb | |
# config.middleware.use Rack::NoAnimations | |
class NoAnimations | |
def initialize(app, options = {}) | |
@app = app | |
end | |
def call(env) | |
@status, @headers, @body = @app.call(env) | |
return [@status, @headers, @body] unless html? | |
response = Rack::Response.new([], @status, @headers) | |
@body.each { |fragment| response.write inject(fragment) } | |
@body.close if @body.respond_to?(:close) | |
response.finish | |
end | |
private | |
def html? | |
@headers["Content-Type"] =~ /html/ | |
end | |
def inject(fragment) | |
disable_animations = <<~HTML | |
<script type="text/javascript"> | |
(typeof jQuery !== 'undefined') && (jQuery.fx.off = true); | |
</script> | |
<style> | |
* { | |
-o-transition: none !important; | |
-moz-transition: none !important; | |
-ms-transition: none !important; | |
-webkit-transition: none !important; | |
transition: none !important; | |
-webkit-animation: none !important; | |
-moz-animation: none !important; | |
-o-animation: none !important; | |
-ms-animation: none !important; | |
animation: none !important; | |
} | |
</style> | |
HTML | |
fragment.gsub(%r{</head>}, disable_animations + "</head>") | |
end | |
end | |
end |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment