sprite base spec

This commit is contained in:
Scott Davis 2011-03-23 00:56:49 -04:00
parent a5e27952f8
commit 03b0ee2660
5 changed files with 46 additions and 16 deletions

View File

@ -7,7 +7,7 @@ GIT
PATH PATH
remote: . remote: .
specs: specs:
compass (0.11.beta.3.6e1daf6) compass (0.11.beta.3.a5e2795)
chunky_png (~> 1.1.0) chunky_png (~> 1.1.0)
sass (>= 3.1.0.alpha.249) sass (>= 3.1.0.alpha.249)

View File

@ -143,7 +143,10 @@ module Compass
# Checks whether this sprite is outdated # Checks whether this sprite is outdated
def outdated? def outdated?
@images.map(&:mtime).any? { |mtime| mtime > self.mtime } if File.exists?(filename)
return @images.map(&:mtime).any? { |mtime| mtime > self.mtime }
end
true
end end
def mtime def mtime

View File

@ -3,27 +3,50 @@ describe Compass::SassExtensions::Sprites::Base do
before :each do before :each do
@images_src_path = File.join(File.dirname(__FILE__), '..', '..', '..', 'test_project', 'public', 'images') @images_src_path = File.join(File.dirname(__FILE__), '..', '..', '..', 'test_project', 'public', 'images')
@images_tmp_path = File.join(File.dirname(__FILE__), '..', '..', '..', 'test_project', 'public', 'selectors-images-tmp') @images_tmp_path = File.join(File.dirname(__FILE__), '..', '..', '..', 'test_project', 'public', 'images-tmp')
#FileUtils.mkdir_p @images_src_path
#FileUtils.mkdir_p @images_tmp_path
FileUtils.cp_r @images_src_path, @images_tmp_path FileUtils.cp_r @images_src_path, @images_tmp_path
file = StringIO.new("images_path = #{@images_tmp_path.inspect}\n") config = Compass::Configuration::Data.new('config')
Compass.add_configuration(file, "sprite_config") config.images_path = @images_tmp_path
Compass.add_configuration(config)
Compass.configure_sass_plugin! Compass.configure_sass_plugin!
rels = Dir["#{@images_src_path}/selectors/*.png"].sort.map { |f| f.split('/')[-2..-1].join('/') } #fix this eww
Compass::SassExtensions::Sprites::Base.new(rels, @images_src_path, 'selectors', self, options) options = Compass.sass_engine_options.extend Compass::SassExtensions::Functions::Sprites::VariableReader
@map = Compass::SpriteMap.new("selectors/*.png", options)
@base = Compass::SassExtensions::Sprites::Base.new(@map.sprite_names.map{|n| "selectors/#{n}.png"}, @map.path, 'selectors', @map.sass_engine, @map.options)
end end
after :each do after :each do
FileUtils.rm_r @images_tmp_path FileUtils.rm_r @images_tmp_path
end end
it "should" do subject { @base }
"foo"
its(:size) { should == [10,40] }
its(:sprite_names) { should == @map.sprite_names }
its(:image_filenames) { should == Dir["#{@images_tmp_path}/selectors/*.png"].sort }
its(:generation_required?) { should be_true }
its(:uniqueness_hash) { should == 'ef52c5c63a'}
its(:outdated?) { should be_true }
its(:filename) { should == File.join(@images_tmp_path, "#{@base.path}-#{@base.uniqueness_hash}.png")}
it "should return the 'ten-by-ten' image" do
subject.image_for('ten-by-ten').name.should == 'ten-by-ten'
subject.image_for('ten-by-ten').should be_a Compass::SassExtensions::Sprites::Image
end end
%w(target hover active).each do |selector|
it "should have a #{selector}" do
subject.send(:"has_#{selector}?", 'ten-by-ten').should be_true
end
end
context "#generate" do
before { @base.generate }
it "should generate sprite" do
File.exists?(@base.filename).should be_true
end
its(:generation_required?) { should be_false }
its(:outdated?) { should be_false }
end
end end

View File

@ -7,7 +7,6 @@ describe Compass::SassExtensions::Sprites::Image do
let(:sprite_name) { File.basename(sprite_filename, '.png') } let(:sprite_name) { File.basename(sprite_filename, '.png') }
let(:image) { self.class.describes.new(nil, File.join(sprite_filename), options)} let(:image) { self.class.describes.new(nil, File.join(sprite_filename), options)}
let(:digest) { Digest::MD5.file(sprite_path).hexdigest } let(:digest) { Digest::MD5.file(sprite_path).hexdigest }
subject { image } subject { image }
before { before {
@ -37,6 +36,7 @@ describe Compass::SassExtensions::Sprites::Image do
} }
describe '#repeat' do describe '#repeat' do
let(:type) { nil }
let(:get_var_return) { OpenStruct.new(:value => type) } let(:get_var_return) { OpenStruct.new(:value => type) }
context 'specific image' do context 'specific image' do
@ -61,6 +61,7 @@ describe Compass::SassExtensions::Sprites::Image do
end end
describe '#position' do describe '#position' do
let(:type) { nil }
let(:get_var_return) { type } let(:get_var_return) { type }
context 'specific image' do context 'specific image' do
@ -85,6 +86,7 @@ describe Compass::SassExtensions::Sprites::Image do
end end
describe '#spacing' do describe '#spacing' do
let(:type) { nil }
let(:get_var_return) { OpenStruct.new(:value => type) } let(:get_var_return) { OpenStruct.new(:value => type) }
context 'specific image' do context 'specific image' do

View File

@ -45,6 +45,8 @@ describe Compass::SpriteMap do
its(:mtime) { should == mtime } its(:mtime) { should == mtime }
it "should have a test for the sass engine" it "should have a test for the sass engine" do
pending 'sass'
end
end end
end end