require File.dirname(__FILE__) + '/spec_helper' describe Russian, "VERSION" do it "should be defined" do %w(MAJOR MINOR TINY STRING).each do |v| Russian::VERSION.const_defined?(v).should == true end end end describe Russian do describe "with locale" do it "should define :'ru-RU' LOCALE" do Russian::LOCALE.should == :'ru-RU' end it "should provide ::locale proxy" do Russian.locale.should == Russian::LOCALE end end describe "with custom backend class" do it "should define i18n_backend_class" do Russian.i18n_backend_class.should == I18n::Backend::Advanced end end describe "during i18n initialization" do it "should set I18n backend to an instance of a custom backend" do Russian.init_i18n I18n.backend.class.should == Russian.i18n_backend_class end it "should set default locale to Russian locale" do Russian.init_i18n I18n.default_locale.should == Russian.locale end describe "loading locales" do before(:all) do Russian.init_i18n end it "should load datetime translations" do lookup(:"date.formats.default").should_not be_nil lookup(:"time.formats.default").should_not be_nil end it "should load pluralization rules" do lookup(:"pluralize").should_not be_nil lookup(:"pluralize").is_a?(Proc).should be_true end it "should load actionview translations" do lookup(:"number.currency.format.format").should_not be_nil lookup(:"datetime.distance_in_words.half_a_minute").should_not be_nil lookup(:"activerecord.errors.template.header").should_not be_nil end it "should load activerecord translations" do lookup(:"activerecord.errors.messages.invalid").should_not be_nil lookup(:"activerecord.errors.messages.greater_than_or_equal_to").should_not be_nil end it "should load activesupport translations" do lookup(:"support.array.sentence_connector").should_not be_nil end def lookup(*args) I18n.backend.send(:lookup, Russian.locale, *args) end end end describe "with localize proxy" do before(:all) do @time = mock(:time) @options = { :format => "%d %B %Y" } end %w(l localize).each do |method| it "#{method} should call I18n backend localize" do I18n.should_receive(:localize).with(@time, @options.merge({ :locale => Russian.locale })) Russian.send(method, @time, @options) end end end describe "with translate proxy" do before(:all) do @object = :bar @options = { :scope => :foo } end %w(t translate).each do |method| it "#{method} should call I18n backend translate" do I18n.should_receive(:translate).with(@object, @options.merge({ :locale => Russian.locale })) Russian.send(method, @object, @options) end end end describe "strftime" do before(:all) do @time = mock(:time) end it "should call localize with object and format" do format = "%d %B %Y" Russian.should_receive(:localize).with(@time, { :format => format }) Russian.strftime(@time, format) end it "should call localize with object and default format when format is not specified" do Russian.should_receive(:localize).with(@time, { :format => :default }) Russian.strftime(@time) end end describe "pluralize" do it "should pluralize with variants given" do variants = %w(вещь вещи вещей) Russian.pluralize(1, *variants).should == "вещь" Russian.pluralize(2, *variants).should == 'вещи' Russian.pluralize(3, *variants).should == 'вещи' Russian.pluralize(5, *variants).should == 'вещей' Russian.pluralize(10, *variants).should == 'вещей' Russian.pluralize(21, *variants).should == 'вещь' Russian.pluralize(29, *variants).should == 'вещей' Russian.pluralize(129, *variants).should == 'вещей' Russian.pluralize(131, *variants).should == 'вещь' end it "should raise an exception when there are not enough variants" do lambda { Russian.pluralize(1) }.should raise_error(ArgumentError) lambda { Russian.pluralize(1, "вещь") }.should raise_error(ArgumentError) lambda { Russian.pluralize(1, "вещь", "вещи") }.should raise_error(ArgumentError) end end end