mirror of https://github.com/captn3m0/dotfiles.git
81 lines
2.9 KiB
Ruby
81 lines
2.9 KiB
Ruby
# Copyright 2010-2011 Wincent Colaiuta. All rights reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are met:
|
|
#
|
|
# 1. Redistributions of source code must retain the above copyright notice,
|
|
# this list of conditions and the following disclaimer.
|
|
# 2. Redistributions in binary form must reproduce the above copyright notice,
|
|
# this list of conditions and the following disclaimer in the documentation
|
|
# and/or other materials provided with the distribution.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE
|
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
require 'spec_helper'
|
|
require 'command-t/finder/file_finder'
|
|
|
|
module VIM; end
|
|
|
|
describe CommandT::FileFinder do
|
|
before :all do
|
|
@finder = CommandT::FileFinder.new File.join(File.dirname(__FILE__), '..',
|
|
'..', '..', 'fixtures')
|
|
@all_fixtures = %w(
|
|
bar/abc
|
|
bar/xyz
|
|
baz
|
|
bing
|
|
foo/alpha/t1
|
|
foo/alpha/t2
|
|
foo/beta
|
|
)
|
|
end
|
|
|
|
before do
|
|
# scanner will call VIM's expand() function for exclusion filtering
|
|
stub(::VIM).evaluate(/expand\(.+\)/) { '0' }
|
|
end
|
|
|
|
describe 'sorted_matches_for method' do
|
|
it 'returns an empty array when no matches' do
|
|
@finder.sorted_matches_for('kung foo fighting').should == []
|
|
end
|
|
|
|
it 'returns all files when query string is empty' do
|
|
@finder.sorted_matches_for('').should == @all_fixtures
|
|
end
|
|
|
|
it 'returns files in alphabetical order when query string is empty' do
|
|
results = @finder.sorted_matches_for('')
|
|
results.should == results.sort
|
|
end
|
|
|
|
it 'returns matching files in score order' do
|
|
@finder.sorted_matches_for('ba').
|
|
should == %w(baz bar/abc bar/xyz foo/beta)
|
|
@finder.sorted_matches_for('a').
|
|
should == %w(baz bar/abc bar/xyz foo/alpha/t1 foo/alpha/t2 foo/beta)
|
|
end
|
|
|
|
it 'obeys the :limit option for empty search strings' do
|
|
@finder.sorted_matches_for('', :limit => 2).
|
|
should == %w(bar/abc bar/xyz)
|
|
end
|
|
|
|
it 'obeys the :limit option for non-empty search strings' do
|
|
@finder.sorted_matches_for('a', :limit => 3).
|
|
should == %w(baz bar/abc bar/xyz)
|
|
end
|
|
end
|
|
end
|