2009-11-23 00:37:11 +01:00
|
|
|
Feature: Minify Javascript
|
|
|
|
In order reduce bytes sent to client and appease YSlow
|
2011-05-29 17:26:58 +02:00
|
|
|
|
2009-11-23 00:37:11 +01:00
|
|
|
Scenario: Rendering inline js with the feature disabled
|
2012-04-26 23:07:10 +02:00
|
|
|
Given a fixture app "minify-js-app"
|
|
|
|
And a file named "config.rb" with:
|
|
|
|
"""
|
|
|
|
"""
|
2011-12-30 04:28:49 +01:00
|
|
|
And the Server is running at "minify-js-app"
|
2009-11-23 00:37:11 +01:00
|
|
|
When I go to "/inline-js.html"
|
2012-04-08 05:00:24 +02:00
|
|
|
Then I should see:
|
|
|
|
"""
|
2013-02-18 04:40:17 +01:00
|
|
|
<script>
|
|
|
|
;(function() {
|
|
|
|
this;
|
|
|
|
should();
|
|
|
|
all.be();
|
|
|
|
on = { one: line };
|
|
|
|
})();
|
2012-04-08 05:00:24 +02:00
|
|
|
</script>
|
|
|
|
<script>
|
|
|
|
;(function() {
|
|
|
|
this;
|
|
|
|
should();
|
|
|
|
too();
|
|
|
|
})();
|
|
|
|
</script>
|
|
|
|
<script type='text/javascript'>
|
|
|
|
//<!--
|
|
|
|
;(function() {
|
|
|
|
one;
|
|
|
|
line();
|
|
|
|
here();
|
|
|
|
})();
|
|
|
|
//-->
|
|
|
|
</script>
|
|
|
|
<script type='text/html'>
|
|
|
|
I'm a jQuery {{template}}.
|
|
|
|
</script>
|
|
|
|
"""
|
2011-12-12 22:54:04 +01:00
|
|
|
|
|
|
|
Scenario: Rendering inline js with a passthrough minifier
|
2012-04-26 23:07:10 +02:00
|
|
|
Given a fixture app "passthrough-app"
|
|
|
|
And a file named "config.rb" with:
|
|
|
|
"""
|
|
|
|
module ::PassThrough
|
|
|
|
def self.compress(data)
|
|
|
|
data
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
activate :minify_javascript, :inline => true
|
|
|
|
|
|
|
|
set :js_compressor, ::PassThrough
|
|
|
|
|
|
|
|
page "/inline-js.html", :layout => false
|
|
|
|
"""
|
|
|
|
And the Server is running at "passthrough-app"
|
2011-12-12 22:54:04 +01:00
|
|
|
When I go to "/inline-js.html"
|
2012-04-08 05:00:24 +02:00
|
|
|
Then I should see:
|
|
|
|
"""
|
2013-02-18 04:40:17 +01:00
|
|
|
<script>
|
|
|
|
;(function() {
|
|
|
|
this;
|
|
|
|
should();
|
|
|
|
all.be();
|
|
|
|
on = { one: line };
|
|
|
|
})();
|
2012-04-08 05:00:24 +02:00
|
|
|
</script>
|
|
|
|
<script>
|
|
|
|
;(function() {
|
|
|
|
this;
|
|
|
|
should();
|
|
|
|
too();
|
|
|
|
})();
|
|
|
|
</script>
|
|
|
|
<script type='text/javascript'>
|
|
|
|
//<!--
|
|
|
|
;(function() {
|
|
|
|
one;
|
|
|
|
line();
|
|
|
|
here();
|
|
|
|
})();
|
|
|
|
//-->
|
|
|
|
</script>
|
|
|
|
<script type='text/html'>
|
|
|
|
I'm a jQuery {{template}}.
|
|
|
|
</script>
|
|
|
|
"""
|
2011-05-29 17:26:58 +02:00
|
|
|
|
2012-04-26 23:15:35 +02:00
|
|
|
Scenario: Rendering inline css with a passthrough minifier using activate-style compressor
|
|
|
|
Given a fixture app "passthrough-app"
|
|
|
|
And a file named "config.rb" with:
|
|
|
|
"""
|
|
|
|
module ::HelloCompressor
|
|
|
|
def self.compress(data)
|
|
|
|
"Hello"
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
activate :minify_javascript, :inline => true, :compressor => ::HelloCompressor
|
|
|
|
|
|
|
|
page "/inline-js.html", :layout => false
|
|
|
|
"""
|
|
|
|
And the Server is running at "passthrough-app"
|
|
|
|
When I go to "/inline-js.html"
|
|
|
|
Then I should see:
|
|
|
|
"""
|
2013-02-18 04:40:17 +01:00
|
|
|
<script>
|
|
|
|
Hello
|
2012-04-26 23:15:35 +02:00
|
|
|
</script>
|
|
|
|
<script>
|
|
|
|
Hello
|
|
|
|
</script>
|
|
|
|
<script type='text/javascript'>
|
|
|
|
//<!--
|
|
|
|
Hello
|
|
|
|
//-->
|
|
|
|
</script>
|
|
|
|
<script type='text/html'>
|
|
|
|
I'm a jQuery {{template}}.
|
|
|
|
</script>
|
|
|
|
"""
|
|
|
|
|
2011-05-29 17:26:58 +02:00
|
|
|
Scenario: Rendering inline js with the feature enabled
|
2012-04-26 23:07:10 +02:00
|
|
|
Given a fixture app "minify-js-app"
|
|
|
|
And a file named "config.rb" with:
|
|
|
|
"""
|
|
|
|
activate :minify_javascript, :inline => true
|
|
|
|
"""
|
2011-12-30 04:28:49 +01:00
|
|
|
And the Server is running at "minify-js-app"
|
2011-05-29 17:26:58 +02:00
|
|
|
When I go to "/inline-js.html"
|
2012-04-08 05:00:24 +02:00
|
|
|
Then I should see:
|
|
|
|
"""
|
2013-02-18 04:40:17 +01:00
|
|
|
<script>
|
2013-05-18 22:47:15 +02:00
|
|
|
!function(){should(),all.be(),on={one:line}}();
|
2012-04-08 05:00:24 +02:00
|
|
|
</script>
|
|
|
|
<script>
|
2013-05-18 22:47:15 +02:00
|
|
|
!function(){should(),too()}();
|
2012-04-08 05:00:24 +02:00
|
|
|
</script>
|
|
|
|
<script type='text/javascript'>
|
|
|
|
//<!--
|
2013-05-18 22:47:15 +02:00
|
|
|
!function(){line(),here()}();
|
2012-04-08 05:00:24 +02:00
|
|
|
//-->
|
|
|
|
</script>
|
|
|
|
<script type='text/html'>
|
|
|
|
I'm a jQuery {{template}}.
|
|
|
|
</script>
|
|
|
|
"""
|
2011-12-12 22:54:04 +01:00
|
|
|
|
|
|
|
Scenario: Rendering external js with the feature enabled
|
2012-04-26 23:07:10 +02:00
|
|
|
Given a fixture app "minify-js-app"
|
|
|
|
And a file named "config.rb" with:
|
|
|
|
"""
|
|
|
|
activate :minify_javascript
|
|
|
|
"""
|
2011-12-30 04:28:49 +01:00
|
|
|
And the Server is running at "minify-js-app"
|
2011-12-12 22:54:04 +01:00
|
|
|
When I go to "/javascripts/js_test.js"
|
|
|
|
Then I should see "1" lines
|
2012-04-08 05:00:24 +02:00
|
|
|
When I go to "/more-js/other.js"
|
|
|
|
Then I should see "1" lines
|
2011-12-12 22:54:04 +01:00
|
|
|
|
|
|
|
Scenario: Rendering external js with a passthrough minifier
|
|
|
|
And the Server is running at "passthrough-app"
|
|
|
|
When I go to "/javascripts/js_test.js"
|
2011-12-12 23:20:20 +01:00
|
|
|
Then I should see "8" lines
|
2011-05-29 17:26:58 +02:00
|
|
|
|
|
|
|
Scenario: Rendering inline js (coffeescript) with the feature enabled
|
2012-04-26 23:07:10 +02:00
|
|
|
Given a fixture app "minify-js-app"
|
|
|
|
And a file named "config.rb" with:
|
|
|
|
"""
|
|
|
|
activate :minify_javascript, :inline => true
|
|
|
|
"""
|
2011-12-30 04:28:49 +01:00
|
|
|
And the Server is running at "minify-js-app"
|
2011-05-29 17:26:58 +02:00
|
|
|
When I go to "/inline-coffeescript.html"
|
2013-02-18 04:40:17 +01:00
|
|
|
Then I should see "3" lines
|
2011-12-12 22:54:04 +01:00
|
|
|
|
|
|
|
Scenario: Rendering external js (coffeescript) with the feature enabled
|
2012-04-26 23:07:10 +02:00
|
|
|
Given a fixture app "minify-js-app"
|
|
|
|
And a file named "config.rb" with:
|
|
|
|
"""
|
|
|
|
activate :minify_javascript
|
|
|
|
"""
|
2011-12-30 04:28:49 +01:00
|
|
|
And the Server is running at "minify-js-app"
|
2011-12-12 22:54:04 +01:00
|
|
|
When I go to "/javascripts/coffee_test.js"
|
|
|
|
Then I should see "1" lines
|
|
|
|
|
|
|
|
Scenario: Rendering inline js (coffeescript) with a passthrough minifier
|
2012-04-26 23:07:10 +02:00
|
|
|
Given a fixture app "passthrough-app"
|
|
|
|
And a file named "config.rb" with:
|
|
|
|
"""
|
|
|
|
module ::PassThrough
|
|
|
|
def self.compress(data)
|
|
|
|
data
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
activate :minify_javascript, :inline => true
|
|
|
|
|
|
|
|
set :js_compressor, ::PassThrough
|
|
|
|
|
|
|
|
page "/inline-coffeescript.html", :layout => false
|
|
|
|
"""
|
|
|
|
And the Server is running at "passthrough-app"
|
2011-12-12 22:54:04 +01:00
|
|
|
When I go to "/inline-coffeescript.html"
|
2013-03-20 17:52:31 +01:00
|
|
|
Then I should see "14" lines
|
2011-12-12 22:54:04 +01:00
|
|
|
|
|
|
|
Scenario: Rendering external js (coffeescript) with a passthrough minifier
|
2012-04-26 23:07:10 +02:00
|
|
|
Given a fixture app "passthrough-app"
|
|
|
|
And a file named "config.rb" with:
|
|
|
|
"""
|
|
|
|
module ::PassThrough
|
|
|
|
def self.compress(data)
|
|
|
|
data
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
activate :minify_javascript
|
|
|
|
|
|
|
|
set :js_compressor, ::PassThrough
|
|
|
|
"""
|
2011-12-12 22:54:04 +01:00
|
|
|
And the Server is running at "passthrough-app"
|
|
|
|
When I go to "/javascripts/coffee_test.js"
|
2013-03-20 17:52:31 +01:00
|
|
|
Then I should see "12" lines
|
2012-04-08 05:00:24 +02:00
|
|
|
|