Forked from keithtom/no_animations.rb
Last active
October 5, 2019 07:49
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
Rails.application.configure do | |
# ... | |
require_relative '../../spec/support/no_animations' | |
config.middleware.use Rack::NoAnimations | |
end |
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 = <<-EOF | |
<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; | |
-o-transform: none !important; | |
-moz-transform: none !important; | |
-ms-transform: none !important; | |
-webkit-transform: none !important; | |
transform: none !important; | |
-webkit-animation: none !important; | |
-moz-animation: none !important; | |
-o-animation: none !important; | |
-ms-animation: none !important; | |
animation: none !important; | |
} | |
</style> | |
EOF | |
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