#ste -*- encoding : utf-8 -*-
# -*- coding: UTF-8 -*-
require File.expand_path(File.dirname(__FILE__) + '/../spec_helper')
require 'marc'
def exportable_record
"
01828cjm a2200409 a 4500
a4768316
SIRSI
sd fungnnmmned
020117p20011990xxuzz h d
Music for horn
[sound recording] /
Brahms, Beethoven, von Krufft.
[United States] :
Harmonia Mundi USA,
p2001.
Greer, Lowell.
Lubin, Steven.
Chase, Stephanie,
1957-
Brahms, Johannes,
1833-1897.
Trios,
piano, violin, horn,
op. 40,
E? major.
Beethoven, Ludwig van,
1770-1827.
Sonatas,
horn, piano,
op. 17,
F major.
Krufft, Nikolaus von,
1779-1818.
Sonata,
horn, piano,
F major.
"
end
describe BlacklightHelper do
include ERB::Util
include BlacklightHelper
def blacklight_config
@config ||= Blacklight::Configuration.new.configure do |config|
config.show.html_title = "title_display"
config.show.heading = "title_display"
config.show.display_type = 'format'
config.index.show_link = 'title_display'
config.index.record_display_type = 'format'
end
#CatalogController.blacklight_config
#@config ||= {:show => {:html_title => 'title_display', :heading => 'title_display', :display_type => 'format'}, :index => { :show_link => 'title_display', :record_display_type => 'format' } }
end
describe "#application_name", :test => true do
it "should use the Rails application config application_name if available" do
Rails.application.config.stub(:application_name => 'asdf')
Rails.application.config.should_receive(:respond_to?).with(:application_name).and_return(true)
application_name.should == 'asdf'
end
it "should default to 'Blacklight'" do
application_name.should == "Blacklight"
end
end
describe "link_back_to_catalog" do
before(:all) do
@query_params = {:q => "query", :f => "facets", :per_page => "10", :page => "2", :controller=>'catalog'}
end
it "should build a link tag to catalog using session[:search] for query params" do
session[:search] = @query_params
tag = link_back_to_catalog
tag.should =~ /q=query/
tag.should =~ /f=facets/
tag.should =~ /per_page=10/
tag.should =~ /page=2/
end
end
describe "link_to_query" do
it "should build a link tag to catalog using query string (no other params)" do
query = "brilliant"
self.should_receive(:params).and_return({})
tag = link_to_query(query)
tag.should =~ /q=#{query}/
tag.should =~ />#{query}<\/a>/
end
it "should build a link tag to catalog using query string and other existing params" do
query = "wonderful"
self.should_receive(:params).and_return({:qt => "title_search", :per_page => "50"})
tag = link_to_query(query)
tag.should =~ /qt=title_search/
tag.should =~ /per_page=50/
end
it "should ignore existing :page param" do
query = "yes"
self.should_receive(:params).and_return({:page => "2", :qt => "author_search"})
tag = link_to_query(query)
tag.should =~ /qt=author_search/
tag.should_not =~ /page/
end
it "should be html_safe" do
query = "brilliant"
self.should_receive(:params).and_return({:page => "2", :qt => "author_search"})
tag = link_to_query(query)
tag.html_safe?.should == true
end
end
describe "search_as_hidden_fields", :asdf => true do
def params
{:q => "query", :sort => "sort", :per_page => "20", :search_field => "search_field", :page => 100, :arbitrary_key => "arbitrary_value", :f => {"field" => ["value1", "value2"], "other_field" => ['asdf']}, :controller => "catalog", :action => "index", :commit => "search"}
end
describe "for default arguments" do
it "should default to omitting :page" do
search_as_hidden_fields.should have_selector("input[type='hidden']", :count =>8)
search_as_hidden_fields.should_not have_selector("input[name='page']")
end
it "should not return blacklisted elements" do
search_as_hidden_fields.should_not have_selector("input[name='action']")
search_as_hidden_fields.should_not have_selector("input[name='controller']")
search_as_hidden_fields.should_not have_selector("input[name='commit']")
end
describe "for omit_keys parameter" do
it "should not include those keys" do
generated = search_as_hidden_fields(:omit_keys => [:per_page, :sort])
generated.should_not have_selector("input[name=sort]")
generated.should_not have_selector("input[name=per_page]")
generated.should have_selector("input[name=page]")
end
it "should support hash-based deleting" do
generated = search_as_hidden_fields(:omit_keys => [{:f => 'field' }])
generated.should have_selector("input[name='f[other_field][]']")
generated.should_not have_selector("input[name='f[field][]']")
end
end
end
end
describe "render body class" do
it "should include a serialization of the current controller name" do
@controller = mock("controller")
@controller.should_receive(:controller_name).any_number_of_times.and_return("123456")
@controller.should_receive(:action_name).any_number_of_times.and_return("abcdef")
render_body_class.split(' ').should include('blacklight-123456')
end
it "should include a serialization of the current action name" do
@controller = mock("controller")
@controller.should_receive(:controller_name).any_number_of_times.and_return("123456")
@controller.should_receive(:action_name).any_number_of_times.and_return("abcdef")
render_body_class.split(' ').should include('blacklight-123456-abcdef')
end
end
describe "document_heading" do
it "should consist of the show heading field when available" do
@document = SolrDocument.new('title_display' => "A Fake Document")
document_heading.should == "A Fake Document"
end
it "should fallback on the document id if no title is available" do
@document = SolrDocument.new(:id => '123456')
document_heading.should == '123456'
end
end
describe "render_document_heading" do
it "should consist of #document_heading wrapped in a