middleman/middleman-core/features/minify_css.feature

123 lines
3.2 KiB
Gherkin
Raw Normal View History

2009-11-23 00:37:11 +01:00
Feature: Minify CSS
In order reduce bytes sent to client and appease YSlow
Scenario: Rendering external css with the feature disabled
2012-04-26 22:54:38 +02:00
Given a fixture app "minify-css-app"
And a file named "config.rb" with:
"""
"""
2011-12-30 04:28:49 +01:00
And the Server is running at "minify-css-app"
2009-11-23 00:37:11 +01:00
When I go to "/stylesheets/site.css"
Then I should see "7" lines
2012-02-08 17:47:34 +01:00
And I should see "only screen and (device-width"
2009-11-23 00:37:11 +01:00
Scenario: Rendering external css with the feature enabled
2012-04-26 22:54:38 +02:00
Given a fixture app "minify-css-app"
And a file named "config.rb" with:
"""
activate :minify_css
"""
2011-12-30 04:28:49 +01:00
And the Server is running at "minify-css-app"
2009-11-23 00:37:11 +01:00
When I go to "/stylesheets/site.css"
Then I should see "1" lines
2012-02-08 17:47:34 +01:00
And I should see "only screen and (device-width"
When I go to "/more-css/site.css"
Then I should see "1" lines
When I go to "/stylesheets/report.css"
Then I should see "p{border:1px solid #ff6600}"
Scenario: Rendering external css with passthrough compressor
Given a fixture app "passthrough-app"
And a file named "config.rb" with:
"""
module ::PassThrough
def self.compress(data)
data
end
end
activate :minify_css, compressor: ::PassThrough
"""
And the Server is running at "passthrough-app"
When I go to "/stylesheets/site.css"
Then I should see "5" lines
Scenario: Rendering inline css with the feature disabled
2012-04-26 22:54:38 +02:00
Given a fixture app "minify-css-app"
And a file named "config.rb" with:
"""
"""
And the Server is running at "minify-css-app"
When I go to "/inline-css.html"
Then I should see:
"""
<style>
body {
test: style;
good: deal;
}
</style>
"""
Scenario: Rendering inline css with a passthrough minifier
Given a fixture app "passthrough-app"
And a file named "config.rb" with:
"""
module ::PassThrough
def self.compress(data)
data
end
end
activate :minify_css, inline: true, compressor: ::PassThrough
page "/inline-css.html", layout: false
"""
And the Server is running at "passthrough-app"
When I go to "/inline-css.html"
Then I should see:
"""
<style>
body {
test: style;
good: deal; }
</style>
"""
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_css, inline: true, compressor: ::HelloCompressor
page "/inline-css.html", layout: false
"""
And the Server is running at "passthrough-app"
When I go to "/inline-css.html"
Then I should see:
"""
<style>
Hello
</style>
"""
Scenario: Rendering inline css with the feature enabled
2012-04-26 22:54:38 +02:00
Given a fixture app "minify-css-app"
And a file named "config.rb" with:
"""
activate :minify_css, inline: true
2012-04-26 22:54:38 +02:00
"""
And the Server is running at "minify-css-app"
When I go to "/inline-css.html"
Then I should see:
"""
<style>
body{test:style;good:deal}
</style>
"""