OSDN Git Service

t#31291:add stories index
[pettanr/pettanr.git] / spec / models / provider_status_spec.rb
index 466bef7..7887d43 100644 (file)
@@ -200,6 +200,7 @@ describe ProviderStatus do
       end
     end
   end
+  
   describe '待機中一覧取得に於いて' do
     before do
       @ps = FactoryGirl.create :provider_status
@@ -276,6 +277,84 @@ describe ProviderStatus do
       end
     end
   end
+  
+  describe '承認済リスト一覧取得に於いて' do
+    before do
+      @ps = FactoryGirl.create :provider_status, :token => 'aaaaa'
+      @pd = FactoryGirl.create :provider, :provider_status_id => @ps.id, :name => "6"
+    end
+    context 'つつがなく終わるとき' do
+      it '一覧取得オプションを利用している' do
+        ProviderStatus.stub(:list_opt).with(any_args).and_return({:include => {:provider => {}} })
+        ProviderStatus.should_receive(:list_opt).with(any_args).exactly(1)
+        r = ProviderStatus.approve_list
+      end
+    end
+    it 'リストを返す' do
+      r = ProviderStatus.approve_list
+      r.should eq [@ps]
+    end
+    it '管理名で並んでいる' do
+      @ps2 = FactoryGirl.create :provider_status, :token => 'aaaaa'
+      v = FactoryGirl.create :provider, :name => "0", :provider_status_id => @ps2.id
+      r = ProviderStatus.approve_list
+      r.should eq [@ps2, @ps]
+    end
+    it '借受状況のトークンが設定されている借受状況に限る' do
+      @ps2 = FactoryGirl.create :provider_status, :token => nil
+      v = FactoryGirl.create :provider, :name => "0", :provider_status_id => @ps2.id
+      r = ProviderStatus.approve_list
+      r.should eq [@ps]
+    end
+    context 'DBに5件あって1ページの件数を2件に変えたとして' do
+      before do
+        @ps2 = FactoryGirl.create :provider_status, :token => 'aaaaa'
+        @pd2 = FactoryGirl.create :provider, :provider_status_id => @ps2.id, :name => "5"
+        @ps3 = FactoryGirl.create :provider_status, :token => 'aaaaa'
+        @pd3 = FactoryGirl.create :provider, :provider_status_id => @ps3.id, :name => "4"
+        @ps4 = FactoryGirl.create :provider_status, :token => 'aaaaa'
+        @pd4 = FactoryGirl.create :provider, :provider_status_id => @ps4.id, :name => "3"
+        @ps5 = FactoryGirl.create :provider_status, :token => 'aaaaa'
+        @pd5 = FactoryGirl.create :provider, :provider_status_id => @ps5.id, :name => "2"
+        ProviderStatus.stub(:default_page_size).and_return(2)
+      end
+      it '通常は2件を返す' do
+        r = ProviderStatus.approve_list
+        r.should have(2).items 
+      end
+      it 'page=1なら末尾2件を返す' do
+        #管理名で並んでいる
+        r = ProviderStatus.approve_list(1)
+        r.should eq [@ps5, @ps4]
+      end
+      it 'page=2なら中間2件を返す' do
+        r = ProviderStatus.approve_list(2)
+        r.should eq [@ps3, @ps2]
+      end
+      it 'page=3なら先頭1件を返す' do
+        r = ProviderStatus.approve_list(3)
+        r.should eq [@ps]
+      end
+    end
+    context 'DBに5件あって1ページの件数を2件に変えたとして' do
+      before do
+        @ps2 = FactoryGirl.create :provider_status, :token => 'aaaaa'
+        @pd2 = FactoryGirl.create :provider, :provider_status_id => @ps2.id, :name => "5"
+        @ps3 = FactoryGirl.create :provider_status, :token => 'aaaaa'
+        @pd3 = FactoryGirl.create :provider, :provider_status_id => @ps3.id, :name => "4"
+        @ps4 = FactoryGirl.create :provider_status, :token => 'aaaaa'
+        @pd4 = FactoryGirl.create :provider, :provider_status_id => @ps4.id, :name => "3"
+        @ps5 = FactoryGirl.create :provider_status, :token => 'aaaaa'
+        @pd5 = FactoryGirl.create :provider, :provider_status_id => @ps5.id, :name => "2"
+        ProviderStatus.stub(:default_page_size).and_return(2)
+      end
+      it '件数0は全件(5件)を返す' do
+        r = ProviderStatus.approve_list 5, 0
+        r.should have(5).items 
+      end
+    end
+  end
+  
   describe '一覧取得オプションに於いて' do
     it 'includeキーを含んでいる' do
       r = ProviderStatus.list_opt
@@ -557,7 +636,7 @@ describe ProviderStatus do
     context '事前チェックしておく' do
       before do
         ProviderStatus.any_instance.stub(:export_by).with(any_args).and_return([@license.attributes])
-        ProviderLicense.stub(:import).with(any_args).and_return([])
+        ProviderLicense.stub(:import).with(any_args).and_return(LicenseImportResult.new([]))
       end
       it '貸手からのエクスポートを依頼している' do
         ProviderStatus.any_instance.should_receive(:export_by).exactly(1)
@@ -571,20 +650,20 @@ describe ProviderStatus do
     context 'つつがなく終わるとき' do
       before do
         ProviderStatus.any_instance.stub(:export_by).with(any_args).and_return([@license.attributes])
-        ProviderLicense.stub(:import).with(any_args).and_return([])
+        ProviderLicense.stub(:import).with(any_args).and_return(LicenseImportResult.new([]))
       end
       it 'ライセンスインポート結果を返す' do
         r = @ps.licenses_import '20111010'
-        r.should eq []
+        r.should be_response
       end
     end
     context 'エクスポートに失敗したとき' do
       before do
         ProviderStatus.any_instance.stub(:export_by).with(any_args).and_return(nil)
       end
-      it 'nilを返す' do
+      it '受信に失敗したImportResultを返す' do
         r = @ps.licenses_import '20111010'
-        r.should be_nil
+        r.should_not be_response
       end
     end
   end
@@ -597,7 +676,7 @@ describe ProviderStatus do
     context '事前チェックしておく' do
       before do
         ProviderStatus.any_instance.stub(:export_by).with(any_args).and_return([])
-        ProviderArtist.stub(:import).with(any_args).and_return([])
+        ProviderArtist.stub(:import).with(any_args).and_return(ArtistImportResult.new([]))
       end
       it '貸手からのエクスポートを依頼している' do
         ProviderStatus.any_instance.should_receive(:export_by).exactly(1)
@@ -611,20 +690,20 @@ describe ProviderStatus do
     context 'つつがなく終わるとき' do
       before do
         ProviderStatus.any_instance.stub(:export_by).with(any_args).and_return([])
-        ProviderArtist.stub(:import).with(any_args).and_return([])
+        ProviderArtist.stub(:import).with(any_args).and_return(ArtistImportResult.new([]))
       end
       it '絵師インポート結果を返す' do
         r = @ps.artists_import '20111010'
-        r.should eq []
+        r.should be_response
       end
     end
     context 'エクスポートに失敗したとき' do
       before do
         ProviderStatus.any_instance.stub(:export_by).with(any_args).and_return(nil)
       end
-      it 'nilを返す' do
-        r = @ps.artists_import '20111010'
-        r.should be_nil
+      it '受信に失敗したImportResultを返す' do
+        r = @ps.licenses_import '20111010'
+        r.should_not be_response
       end
     end
   end
@@ -637,7 +716,7 @@ describe ProviderStatus do
     context '事前チェックしておく' do
       before do
         ProviderStatus.any_instance.stub(:export_by).with(any_args).and_return([])
-        ProviderOriginalPicture.stub(:import).with(any_args).and_return({:original_pictures => [], :pictures => [], :resource_pictures => []})
+        ProviderOriginalPicture.stub(:import).with(any_args).and_return(OriginalPictureImportResult.new([]))
       end
       it '貸手からのエクスポートを依頼している' do
         ProviderStatus.any_instance.should_receive(:export_by).exactly(2)
@@ -651,26 +730,20 @@ describe ProviderStatus do
     context 'つつがなく終わるとき' do
       before do
         ProviderStatus.any_instance.stub(:export_by).with(any_args).and_return([])
-        ProviderOriginalPicture.stub(:import).with(any_args).and_return({:original_pictures => [], :pictures => [], :resource_pictures => []})
+        ProviderOriginalPicture.stub(:import).with(any_args).and_return(OriginalPictureImportResult.new([]))
       end
       it '原画インポート結果を返す' do
         r = @ps.original_pictures_import '20111010'
-        r.is_a?(Hash).should be_true
-      end
-      it 'インポート失敗リストを取得している' do
-        r = @ps.original_pictures_import '20111010'
-        r[:original_pictures].should be_empty
-        r[:pictures].should be_empty
-        r[:resource_pictures].should be_empty
+        r.should be_response
       end
     end
     context 'エクスポートに失敗したとき' do
       before do
         ProviderStatus.any_instance.stub(:export_by).with(any_args).and_return(nil)
       end
-      it 'nilを返す' do
-        r = @ps.original_pictures_import '20111010'
-        r.should be_nil
+      it '受信に失敗したImportResultを返す' do
+        r = @ps.licenses_import '20111010'
+        r.should_not be_response
       end
     end
   end