OSDN Git Service

t#32046:
[pettanr/pettanr.git] / spec / models / original_picture_spec.rb
index 8991830..ede81d9 100644 (file)
@@ -4,6 +4,7 @@ require 'spec_helper'
 
 describe OriginalPicture do
   before do
+    SpeechBalloonTemplate.delete_all
     @admin = FactoryGirl.create :admin
     @user = FactoryGirl.create( :user_yas)
     @author = FactoryGirl.create :author, :user_id => @user.id
@@ -146,6 +147,11 @@ describe OriginalPicture do
   end
   
   describe '上書き補充に於いて' do
+    it '投稿日時が設定されている' do
+      @op = FactoryGirl.build :original_picture, :uploaded_at => nil
+      @op.overwrite @artist
+      @op.uploaded_at.should_not be_nil
+    end
     it '絵師idが設定されている' do
       @op = FactoryGirl.build :original_picture, :artist_id => nil
       @op.overwrite @artist
@@ -153,29 +159,36 @@ describe OriginalPicture do
     end
   end
   
-  describe '作者判定に於いて' do
+  describe '所持判定に於いて' do
     before do
       @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
     end
-    context 'パラメータが作家のとき' do
-      it '自作の原画ならyes' do
-        @op.own?(@author).should == true
-      end
-      it '他人のならno' do
-        @op.own?(@other_author).should == false
+    context '事前チェックする' do
+      it '自身にロールリストからの絵師取得を依頼している' do
+        OriginalPicture.should_receive(:get_artist_from_roles).with(any_args).exactly(1)
+        r = @op.own?([@artist])
       end
     end
-    context 'パラメータが絵師のとき' do
-      it '自作の原画ならyes' do
-        @op.own?(@artist).should == true
+    context 'ロール内絵師が取得できるとき' do
+      before do
+      end
+      it 'ロール内絵師のidが自身の絵師idと一致するなら許可する' do
+        OriginalPicture.stub(:get_artist_from_roles).with(any_args).and_return(@artist)
+        r = @op.own?([@artist])
+        r.should be_true
       end
-      it '他人のならno' do
-        @op.own?(@other_artist).should == false
+      it 'ロール内絵師のidが自身の絵師idと一致しないならno' do
+        OriginalPicture.stub(:get_artist_from_roles).with(any_args).and_return(@other_artist)
+        @op.own?(@other_artist).should be_false
       end
     end
-    context 'それ以外のとき' do
-      it 'no' do
-        @op.own?(nil).should == false
+    context 'ロール内絵師が取得できないとき' do
+      before do
+        OriginalPicture.stub(:get_artist_from_roles).with(any_args).and_return(nil)
+      end
+      it 'Falseを返す' do
+        r = @op.own?([@artist])
+        r.should be_false
       end
     end
   end
@@ -184,20 +197,30 @@ describe OriginalPicture do
     before do
       @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
     end
-    it '検査対象が管理者のとき、許可を返す' do
-      OriginalPicture.any_instance.stub(:own?).and_return(false)
-      r = @op.visible?(@admin)
-      r.should == true
-    end
-    it '所持判定を問い合わせ、自分の原画なら許可する' do
-      OriginalPicture.any_instance.stub(:own?).and_return(true)
-      r = @op.visible?(@artist)
-      r.should == true
+    context '事前チェックする' do
+      before do
+        MagicNumber['run_mode'] = 1
+      end
+      it '自身の原画に所持判定を問い合わせしている' do
+        OriginalPicture.any_instance.stub(:own?).and_return(true)
+        OriginalPicture.any_instance.should_receive(:own?).with(any_args).exactly(1)
+        r = @op.visible?([@artist])
+      end
     end
-    it '他人の原画なら許可しない' do
-      OriginalPicture.any_instance.stub(:own?).and_return(false)
-      r = @op.visible?(@artist)
-      r.should == false
+    context 'つつがなく終わるとき' do
+      before do
+        MagicNumber['run_mode'] = 1
+      end
+      it '自分の原画なら許可する' do
+        OriginalPicture.any_instance.stub(:own?).and_return(true)
+        r = @op.visible?([@artist])
+        r.should be_true
+      end
+      it '他人の原画なら許可しない' do
+        OriginalPicture.any_instance.stub(:own?).and_return(false)
+        r = @op.visible?([@artist])
+        r.should be_false
+      end
     end
   end
   
@@ -297,15 +320,20 @@ describe OriginalPicture do
     before do
       @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
     end
-    context 'å®\9fç´ æ\9d\90ã\81\8cã\82¼ã\83­のとき' do
+    context 'å\85¬é\96\8bæ\97¥æ\99\82ã\81¨å\81\9cæ­¢æ\97¥æ\99\82ã\81\8cã\81¨ã\82\82ã\81«ç©ºのとき' do
       it 'Trueを返す' do
         r = @op.unpublished?
         r.should be_true
       end
     end
-    context '実素材がゼロではないとき' do
+    context '公開日時と停止日時がともに空ではないとき' do
+      it 'Falseを返す' do
+        @op.stopped_at =Time.now
+        r = @op.unpublished?
+        r.should be_false
+      end
       it 'Falseを返す' do
-        @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id 
+        @op.published_at =Time.now
         r = @op.unpublished?
         r.should be_false
       end
@@ -316,23 +344,16 @@ describe OriginalPicture do
     before do
       @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
     end
-    context '未公開ではないが、素材がないとき' do
+    context '停止日時が空でないとき' do
       it 'Trueを返す' do
-        @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id 
+        @op.stopped_at =Time.now
         r = @op.stopped?
         r.should be_true
       end
     end
-    context '未公開のとき' do
+    context '停止日時が空のとき' do
       it 'Falseを返す' do
-        r = @op.stopped?
-        r.should be_false
-      end
-    end
-    context '未公開ではなく、素材もあるとき' do
-      it 'falseを返す' do
-        @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id 
-        @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :picture_id => @p.id
+        @op.stopped_at = nil
         r = @op.stopped?
         r.should be_false
       end
@@ -343,31 +364,36 @@ describe OriginalPicture do
     before do
       @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
     end
-    context '未公開ではなく、素材もあるが、原画の更新日時が実素材のheadのそれより後のとき' do
+    context '公開日時と停止日時のうち、空でない方を取得して、投稿日時がそれより後のとき' do
       it 'Trueを返す' do
-        @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :updated_at => Time.now - 1000
-        @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :picture_id => @p.id
+        @op.uploaded_at = Time.now
+        @op.stopped_at = Time.now - 400
+        r = @op.unlicensed?
+        r.should be_true
+      end
+      it 'Trueを返す' do
+        @op.uploaded_at = Time.now
+        @op.published_at =Time.now - 400
         r = @op.unlicensed?
         r.should be_true
       end
     end
-    context '未公開のとき' do
+    context '公開日時と停止日時のうち、空でない方を取得して、投稿日時がそれより後ではないとき' do
       it 'Falseを返す' do
+        @op.published_at = nil
+        @op.stopped_at = nil
         r = @op.unlicensed?
         r.should be_false
       end
-    end
-    context '未公開ではないが、素材がないとき' do
       it 'Falseを返す' do
-        @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id 
+        @op.uploaded_at = Time.now
+        @op.published_at =Time.now + 400
         r = @op.unlicensed?
         r.should be_false
       end
-    end
-    context '未公開ではなく、素材もあり、実素材のheadの更新日時が原画のそれより後のとき' do
       it 'Falseを返す' do
-        @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :updated_at => Time.now + 1000
-        @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :picture_id => @p.id
+        @op.uploaded_at = Time.now
+        @op.stopped_at =Time.now + 400
         r = @op.unlicensed?
         r.should be_false
       end
@@ -378,31 +404,16 @@ describe OriginalPicture do
     before do
       @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
     end
-    context '未公開ではなく、素材もあり、実素材のheadの更新日時が原画のそれより後のとき' do
+    context '公開日時が空ではないとき' do
       it 'Trueを返す' do
-        @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :updated_at => Time.now + 1000
-        @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :picture_id => @p.id
+        @op.published_at =Time.now
         r = @op.published?
         r.should be_true
       end
     end
-    context '未公開のとき' do
+    context '公開日時が空のとき' do
       it 'Falseを返す' do
-        r = @op.published?
-        r.should be_false
-      end
-    end
-    context '未公開ではないが、素材がないとき' do
-      it 'falseを返す' do
-        @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id 
-        r = @op.published?
-        r.should be_false
-      end
-    end
-    context '未公開ではなく、素材もあるが、原画の更新日時が実素材のheadのそれより後のとき' do
-      it 'falseを返す' do
-        @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :updated_at => Time.now - 1000
-        @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :picture_id => @p.id
+        @op.published_at = nil
         r = @op.published?
         r.should be_false
       end
@@ -439,47 +450,6 @@ describe OriginalPicture do
       end
     end
   end
-  describe '一覧取得オプションに於いて' do
-    it 'includeキーを含んでいる' do
-      r = OriginalPicture.list_opt
-      r.has_key?(:include).should be_true
-    end
-    it '2つの項目を含んでいる' do
-      r = OriginalPicture.list_opt[:include]
-      r.should have(2).items
-    end
-    it '素材を含んでいる' do
-      r = OriginalPicture.list_opt[:include]
-      r.has_key?(:resource_picture).should be_true
-    end
-    it '実素材を含んでいる' do
-      r = OriginalPicture.list_opt[:include]
-      r.has_key?(:pictures).should be_true
-    end
-  end
-  describe 'json一覧出力オプションに於いて' do
-    before do
-      @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
-      @p = FactoryGirl.create :picture, :original_picture_id => @op.id, :license_id => @license.id, :artist_id => @artist.id
-      @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :license_id => @license.id, :original_picture_id => @op.id, :picture_id => @p.id
-      @sbt = FactoryGirl.create :speech_balloon_template
-      @comic = FactoryGirl.create :comic, :author_id => @author.id, :visible => 1
-      @panel = FactoryGirl.create :panel, :author_id => @author.id, :publish => 1
-      @story = FactoryGirl.create :story, :author_id => @author.id, :comic_id => @comic.id, :panel_id => @panel.id
-    end
-    it '素材を含んでいる' do
-      r = OriginalPicture.mylist(@artist).to_json OriginalPicture.list_json_opt
-      j = JSON.parse r
-      i = j.first
-      i.has_key?('resource_picture').should be_true
-    end
-    it '実素材を含んでいる' do
-      r = OriginalPicture.mylist(@artist).to_json OriginalPicture.list_json_opt
-      j = JSON.parse r
-      i = j.first
-      i.has_key?('pictures').should be_true
-    end
-  end
   
   describe '自分の原画一覧取得に於いて' do
     before do
@@ -531,18 +501,63 @@ describe OriginalPicture do
         r.should eq [@op]
       end
     end
-    context 'DBに5件あって1ページの件数を0件に変えたとして' do
-      before do
-        @op2 = FactoryGirl.create :original_picture, :artist_id => @artist.id, :updated_at => Time.now + 100
-        @op3 = FactoryGirl.create :original_picture, :artist_id => @artist.id, :updated_at => Time.now + 200
-        @op4 = FactoryGirl.create :original_picture, :artist_id => @artist.id, :updated_at => Time.now + 300
-        @op5 = FactoryGirl.create :original_picture, :artist_id => @artist.id, :updated_at => Time.now + 400
-        OriginalPicture.stub(:default_page_size).and_return(2)
-      end
-      it '通常は全件(5件)を返す' do
-        r = OriginalPicture.mylist @artist, 5, 0
-        r.should have(5).items 
-      end
+  end
+  
+  describe '自分の原画一覧ページ制御に於いて' do
+    before do
+      OriginalPicture.stub(:count).with(any_args).and_return(100)
+    end
+    it 'ページ制御を返す' do
+      r = OriginalPicture.mylist_paginate @author
+      r.is_a?(Kaminari::PaginatableArray).should be_true
+    end
+    it '自分の原画一覧の取得条件を利用している' do
+      OriginalPicture.stub(:mylist_where).with(any_args).and_return('')
+      OriginalPicture.should_receive(:mylist_where).with(any_args).exactly(1)
+      r = OriginalPicture.mylist_paginate @author
+    end
+    it 'ページ件数10のとき、3ページ目のオフセットは20から始まる' do
+      r = OriginalPicture.mylist_paginate @author, 3, 10
+      r.limit_value.should eq 10
+      r.offset_value.should eq 20
+    end
+  end
+  
+  describe '一覧取得オプションに於いて' do
+    it '2つの項目を含んでいる' do
+      r = OriginalPicture.list_opt
+      r.should have(2).items
+    end
+    it '素材を含んでいる' do
+      r = OriginalPicture.list_opt
+      r.has_key?(:resource_picture).should be_true
+    end
+    it '実素材を含んでいる' do
+      r = OriginalPicture.list_opt
+      r.has_key?(:pictures).should be_true
+    end
+  end
+  describe 'json一覧出力オプションに於いて' do
+    before do
+      @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
+      @p = FactoryGirl.create :picture, :original_picture_id => @op.id, :license_id => @license.id, :artist_id => @artist.id
+      @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :license_id => @license.id, :original_picture_id => @op.id, :picture_id => @p.id
+      @sbt = FactoryGirl.create :speech_balloon_template
+      @scroll = FactoryGirl.create :scroll, :author_id => @author.id, :visible => 1
+      @panel = FactoryGirl.create :panel, :author_id => @author.id, :publish => 1
+      @scroll_panel = FactoryGirl.create :scroll_panel, :author_id => @author.id, :scroll_id => @scroll.id, :panel_id => @panel.id
+    end
+    it '素材を含んでいる' do
+      r = OriginalPicture.mylist(@artist).to_json OriginalPicture.list_json_opt
+      j = JSON.parse r
+      i = j.first
+      i.has_key?('resource_picture').should be_true
+    end
+    it '実素材を含んでいる' do
+      r = OriginalPicture.mylist(@artist).to_json OriginalPicture.list_json_opt
+      j = JSON.parse r
+      i = j.first
+      i.has_key?('pictures').should be_true
     end
   end
   
@@ -667,9 +682,9 @@ describe OriginalPicture do
       @p = FactoryGirl.create :picture, :original_picture_id => @op.id, :license_id => @license.id, :artist_id => @artist.id
       @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :license_id => @license.id, :original_picture_id => @op.id, :picture_id => @p.id
       @sbt = FactoryGirl.create :speech_balloon_template
-      @comic = FactoryGirl.create :comic, :author_id => @author.id, :visible => 1
+      @scroll = FactoryGirl.create :scroll, :author_id => @author.id, :visible => 1
       @panel = FactoryGirl.create :panel, :author_id => @author.id, :publish => 1
-      @story = FactoryGirl.create :story, :author_id => @author.id, :comic_id => @comic.id, :panel_id => @panel.id
+      @scroll_panel = FactoryGirl.create :scroll_panel, :author_id => @author.id, :scroll_id => @scroll.id, :panel_id => @panel.id
     end
     it '素材を含んでいる' do
       r = OriginalPicture.show(@op.id, @artist).to_json OriginalPicture.show_json_opt
@@ -865,6 +880,7 @@ describe OriginalPicture do
     end
     context '画像の削除に失敗したとき' do
       before do
+        PictureIO.original_picture_io.stub(:exist?).with(@op.filename).and_return(true)
         PictureIO.original_picture_io.stub(:delete).with(@op.filename).and_raise(PictureIO::Error)
       end
       it 'Falseを返す' do
@@ -917,126 +933,78 @@ describe OriginalPicture do
     end
   end
   
-=begin
   describe 'エクスポートに於いて' do
     before do
       @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
       @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :revision => 0
       @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :picture_id => @p.id
-      #他人の原画排除
+      #開始日時以前の原画
+      @old_op = FactoryGirl.create :original_picture, :artist_id => @artist.id, :updated_at => Time.now - 1000
+      #素材がライセンスされていない原画
+      @stopped_op = FactoryGirl.create :original_picture, :artist_id => @artist.id
+      #他人の原画
       @other_op = FactoryGirl.create :original_picture, :artist_id => @other_artist.id
+      #貸手からの原画排除
+      @outer_artist = FactoryGirl.create :artist_yas, :author_id => nil
+      @outer_op = FactoryGirl.create :original_picture, :artist_id => @outer_artist.id
     end
     context 'つつがなく終わるとき' do
-      it 'ライセンスグループに依頼してリストを取得している' do
-        LicenseGroup.stub(:list).with(any_args).and_return([@lg])
-        LicenseGroup.should_receive(:list).with(any_args).exactly(1)
-        r = OriginalPicture.export(@artist)
-      end
-      it '原画に依頼してリストを取得している' do
-        OriginalPicture.stub(:list).with(any_args).and_return([@op])
-        OriginalPicture.should_receive(:list).with(any_args).exactly(1)
-        r = OriginalPicture.export(@artist)
+      it '開始日時が省略された場合はすべての内原画を返す' do
+        r = OriginalPicture.export 
+        r.should eq [@op, @old_op, @stopped_op, @other_op]
       end
-      it 'Hashを返す' do
-        r = OriginalPicture.export(@artist)
-        r.is_a?(Hash).should be_true
+      it '開始日時以降に更新された内原画を返す' do
+        r = OriginalPicture.export @op.updated_at - 100
+        r.should eq [@op, @stopped_op, @other_op]
       end
-      it 'Hashはライセンスグループを含んでいる' do
-        r = OriginalPicture.export(@artist)
-        r.include?(:license_groups).should be_true
-      end
-      it 'Hashは原画を含んでいる' do
-        r = OriginalPicture.export(@artist)
-        r.include?(:original_pictures).should be_true
+      it '素材を含んでいる' do
+        r = OriginalPicture.export 
+        r.first.resource_picture.should_not be_nil
       end
       #素材がライセンスされていないケースもある
-      it 'Hashの原画は素材を含んでいる' do
-        r = OriginalPicture.export(@artist)
-        r[:original_pictures].first.resource_picture.should_not be_nil
-      end
-      it 'Hashの原画は実素材を含んでいる' do
-        r = OriginalPicture.export(@artist)
-        r[:original_pictures].first.pictures.should be_nil
+      it '停止中の原画は素材を含んでいない' do
+        r = OriginalPicture.export
+        r[2].resource_picture.should be_nil
       end
     end
-    context '実データ単体のとき' do
-      it 'ライセンスは配列構造になっている' do
-        r = OriginalPicture.export(@artist)
-        r[:license_groups].is_a?(Array).should be_true
-      end
-      it 'ライセンスが全件出ている' do
-        r = OriginalPicture.export(@artist)
-        r[:license_groups].size.should eq 1
-        r[:license_groups].first.should eq @lg
-      end
-      it '原画は配列構造になっている' do
-        r = OriginalPicture.export(@artist)
-        r[:original_pictures].is_a?(Array).should be_true
-      end
-      it '原画が全件出ている' do
-        r = OriginalPicture.export(@artist)
-        r[:original_pictures].size.should eq 1
-        r[:original_pictures].first.should eq @op
+  end
+  
+  describe 'リストのjson化に於いて' do
+    before do
+      @op = FactoryGirl.create :original_picture, :artist_id => @artist.id
+      @p = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :revision => 0
+      @rp = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :original_picture_id => @op.id, :license_id => @license.id, :picture_id => @p.id
+      @other_op = FactoryGirl.create :original_picture, :artist_id => @other_artist.id
+      @other_p = FactoryGirl.create :picture, :artist_id => @other_artist.id, :original_picture_id => @other_op.id, :license_id => @license.id, :revision => 0, :updated_at => Time.now + 100
+      @other_rp = FactoryGirl.create :resource_picture, :artist_id => @other_artist.id, :original_picture_id => @other_op.id, :license_id => @license.id, :picture_id => @other_p.id
+      ResourcePicture.any_instance.stub(:restore).with(any_args).and_return('picture binary data')
+    end
+    context 'つつがなく終わるとき' do
+      it 'json文字列を返す' do
+        r = OriginalPicture.list_as_json_text OriginalPicture.all 
+        lambda {
+          j = JSON.parse r
+        }.should_not raise_error(JSON::ParserError)
       end
-      it 'å\8e\9fç\94»ã\81«ç´ æ\9d\90ã\81\8cé\96¢é\80£ä»\98ã\81\84ã\81¦ã\81\84ã\82\8b' do
-        r = OriginalPicture.export(@artist)
-        i = r[:original_pictures].first
-        i.resource_picture.should eq @rp
+      it 'å\8e\9fç\94»ã\83ªã\82¹ã\83\88ã\82\92è¿\94ã\81\99' do
+        r = OriginalPicture.list_as_json_text OriginalPicture.all 
+        j = JSON.parse r
+        j.size.should eq 2
       end
-      it '原画に実素材が関連付いている' do
-        r = OriginalPicture.export(@artist)
-        i = r[:original_pictures].first
-        i.picture.should eq @p
+      it '素材を含んでいる' do
+        r = OriginalPicture.list_as_json_text OriginalPicture.all 
+        j = JSON.parse r
+        j.first['resource_picture'].should_not be_nil
       end
-    end
-    context '実データ複数のとき' do
-      before do
-        @lg2 = FactoryGirl.create :license_group, :name => 'export test', :url => 'http://export.test/'
-        @license2 = FactoryGirl.create :license, :license_group_id => @lg2.id, :system_picture_id => @sp.id, :name => 'export test license', :url => 'http://export.test/license'
-        @op2 = FactoryGirl.create :original_picture, :artist_id => @artist.id
-        @p2 = FactoryGirl.create :picture, :artist_id => @artist.id, :original_picture_id => @op2.id, :license_id => @license2.id, :revision => 0
-        @rp2 = FactoryGirl.create :resource_picture, :artist_id => @artist.id, :original_picture_id => @op2.id, :license_id => @license2.id, :picture_id => @p2.id
-      end
-      it 'ライセンスは配列構造になっている' do
-        r = OriginalPicture.export(@artist)
-        r[:license_groups].is_a?(Array).should be_true
-      end
-      it 'ライセンスが全件出ている' do
-        r = OriginalPicture.export(@artist)
-        r[:license_groups].size.should eq 2
-        r[:license_groups].first.should eq @lg
-        r[:license_groups].last.should eq @lg2
-      end
-      it '原画は配列構造になっている' do
-        r = OriginalPicture.export(@artist)
-        r[:original_pictures].is_a?(Array).should be_true
-      end
-      it '原画が全件出ている' do
-        r = OriginalPicture.export(@artist)
-        r[:original_pictures].size.should eq 2
-        r[:original_pictures].first.should eq @op
-        r[:original_pictures].last.should eq @op2
-      end
-      it '原画に素材が関連付いている' do
-        r = OriginalPicture.export(@artist)
-        i = r[:original_pictures].first
-        i.resource_picture.should eq @rp
-        i2 = r[:original_pictures].last
-        i2.resource_picture.should eq @rp2
-      end
-      it '原画に実素材が関連付いている' do
-        r = OriginalPicture.export(@artist)
-        i = r[:original_pictures].first
-        i.picture.should eq @p
-        i2 = r[:original_pictures].last
-        i2.picture.should eq @p2
+      it '各素材に画像データを添えて返す' do
+        r = OriginalPicture.list_as_json_text OriginalPicture.all 
+        j = JSON.parse r
+        j.first['resource_picture']['picture_data'].should_not be_nil
+        j.last['resource_picture']['picture_data'].should_not be_nil
       end
     end
   end
   
-  describe 'エクスポートオプションに於いて' do
-  end
-  
   describe 'インポートに於いて' do
     before do
       @imports = {:licenses => {}, :artist_id => @artist.id}
@@ -1045,5 +1013,4 @@ describe OriginalPicture do
     end
   end
   
-=end
 end