1 # -*- encoding: utf-8 -*-
5 describe ProviderStatusesController do
7 @admin = FactoryGirl.create :admin
8 @sp = FactoryGirl.create :system_picture
9 @lg = FactoryGirl.create :license_group
10 @license = FactoryGirl.create :license, :license_group_id => @lg.id, :system_picture_id => @sp.id
11 @user = FactoryGirl.create :user_yas
12 @author = @user.author #ユーザ作成時に連動して作成される
15 describe '一覧表示に於いて' do
17 @ps = FactoryGirl.create :provider_status
18 @provider = FactoryGirl.create :provider, :provider_status_id => @ps.id
19 ProviderStatus.stub(:list).and_return([@ps, @ps, @ps])
20 ProviderStatus.stub(:available_list).and_return([@ps, @ps])
24 it '与えられたpageがセットされている' do
25 get :index, :page => 5
26 assigns(:page).should eq 5
28 it '省略されると@pageに1値が入る' do
30 assigns(:page).should eq 1
32 it '与えられたpage_sizeがセットされている' do
33 get :index, :page_size => 15
34 assigns(:page_size).should eq 15
36 it '省略されると@page_sizeにデフォルト値が入る' do
38 assigns(:page_size).should eq ProviderStatus.default_page_size
40 it '最大を超えると@page_sizeにデフォルト最大値が入る' do
41 get :index, :page_size => 1500
42 assigns(:page_size).should eq ProviderStatus.max_page_size
44 it '不正な値が入ると@page_sizeにデフォルト最大値が入る' do
45 get :index, :page_size => 0
46 assigns(:page_size).should eq ProviderStatus.default_page_size
49 context 'つつがなく終わるとき' do
50 it 'ステータスコード200 OKを返す' do
52 response.should be_success
56 assigns(:hide).should be_blank
58 it '借受状況モデルに全一覧取得を問い合わせている' do
59 ProviderStatus.should_receive(:list).exactly(1)
62 it '@provider_statusesにリストを取得している' do
64 assigns(:provider_statuses).should have_at_least(3).items
67 it 'indexテンプレートを描画する' do
69 response.should render_template("index")
74 get :index, :format => :json
75 lambda{JSON.parse(response.body)}.should_not raise_error(JSON::ParserError)
77 it '借受状況モデルにjson一覧出力オプションを問い合わせている' do
78 ProviderStatus.should_receive(:list_json_opt).exactly(1)
79 get :index, :format => :json
81 it 'データがリスト構造になっている' do
82 get :index, :format => :json
83 json = JSON.parse response.body
84 json.should have_at_least(3).items
86 it 'リストの先頭くらいは借受状況っぽいものであって欲しい' do
87 get :index, :format => :json
88 json = JSON.parse response.body
89 json.first.has_key?("token").should be_true
90 json.first.has_key?("receive_hour1").should be_true
91 json.first.has_key?("receive_hour2").should be_true
92 json.first.has_key?("received_at").should be_true
96 context '除外フラグが除外のとき' do
98 get :index, :hide => 1
99 assigns(:hide).should_not be_blank
101 it '借受状況モデルに待機中一覧取得を問い合わせている' do
102 ProviderStatus.should_receive(:available_list).exactly(1)
103 get :index, :hide => 1
105 it '@provider_statusesにリストを取得している' do
106 get :index, :hide => 1
107 assigns(:provider_statuses).should have_at_least(2).items
110 context '管理者権限がないとき' do
115 it 'ステータスコード302 Foundを返す' do
117 response.status.should eq 302
119 it 'サインインページへ遷移する' do
121 response.should redirect_to '/admins/sign_in'
125 it 'ステータスコード401 Unauthorizedを返す' do
126 get :index, :format => :json
127 response.status.should eq 401
129 it '応答メッセージにUnauthorizedを返す' do
130 get :index, :format => :json
131 response.message.should match(/Unauthorized/)
137 describe '単体表示に於いて' do
139 @ps = FactoryGirl.create :provider_status
140 @provider = FactoryGirl.create :provider, :provider_status_id => @ps.id
141 ProviderStatus.stub(:show).and_return(@ps)
144 context 'つつがなく終わるとき' do
145 it 'ステータスコード200 OKを返す' do
146 get :show, :id => @ps.id
147 response.should be_success
149 it '借受状況モデルに単体取得を問い合わせている' do
150 ProviderStatus.should_receive(:show).exactly(1)
153 it '@provider_statusにアレを取得している' do
154 get :show, :id => @ps.id
155 assigns(:provider_status).should eq(@ps)
158 it 'showテンプレートを描画する' do
159 get :show, :id => @ps.id
160 response.should render_template("show")
165 get :show, :id => @ps.id, :format => :json
166 lambda{JSON.parse(response.body)}.should_not raise_error(JSON::ParserError)
168 it '借受状況モデルにjson単体出力オプションを問い合わせている' do
169 ProviderStatus.should_receive(:show_json_opt).exactly(1)
170 get :show, :id => @ps.id, :format => :json
173 get :show, :id => @ps.id, :format => :json
174 json = JSON.parse response.body
175 json.has_key?("token").should be_true
176 json.has_key?("receive_hour1").should be_true
177 json.has_key?("receive_hour2").should be_true
178 json.has_key?("received_at").should be_true
182 context '管理者権限がないとき' do
187 it 'ステータスコード302 Foundを返す' do
188 get :show, :id => @ps.id
189 response.status.should eq 302
191 it 'サインインページへ遷移する' do
192 get :show, :id => @ps.id
193 response.body.should redirect_to '/admins/sign_in'
197 it 'ステータスコード401 Unauthorizedを返す' do
198 get :show, :id => @ps.id, :format => :json
199 response.status.should eq 401
201 it '応答メッセージにUnauthorizedを返す' do
202 get :show, :id => @ps.id, :format => :json
203 response.message.should match(/Unauthorized/)
209 describe '編集フォーム表示に於いて' do
211 @ps = FactoryGirl.create :provider_status
212 @provider = FactoryGirl.create :provider, :provider_status_id => @ps.id
214 ProviderStatus.stub(:edit).with(@ps.id.to_s, @admin).and_return(@ps)
216 context 'つつがなく終わるとき' do
217 it 'ステータスコード200 OKを返す' do
218 get :edit, :id => @ps.id
219 response.should be_success
221 it '借受状況モデルに編集取得を問い合わせている' do
222 ProviderStatus.should_receive(:edit).exactly(1)
223 get :edit, :id => @ps.id
225 it '@provider_statusにデータを用意している' do
226 get :edit, :id => @ps.id
227 assigns(:provider_status).should eq @ps
230 it 'editテンプレートを描画する' do
231 get :edit, :id => @ps.id
232 response.should render_template("edit")
236 context '管理者権限がないとき' do
241 it 'ステータスコード302 Foundを返す' do
242 get :edit, :id => @ps.id
243 response.status.should eq 302
245 it 'サインインページへ遷移する' do
246 get :edit, :id => @ps.id
247 response.body.should redirect_to '/admins/sign_in'
255 @ps = FactoryGirl.create :provider_status
256 @attr = FactoryGirl.attributes_for(:provider_status, :receive_hour1 => 22)
259 context '事前チェックしておく' do
260 it '借受状況モデルに編集取得を問い合わせている' do
261 ProviderStatus.stub(:edit).with(any_args()).and_return @ps
262 ProviderStatus.should_receive(:edit).exactly(1)
263 put :update, :id => @ps.id, :provider_status => @attr
265 it '借受状況モデルにカラム値復元を依頼している' do
266 ProviderStatus.any_instance.should_receive(:attributes=).exactly(1)
267 put :update, :id => @ps.id, :provider_status => @attr
269 it '借受状況モデルに上書き補充を依頼している' do
270 ProviderStatus.any_instance.should_receive(:overwrite).exactly(1)
271 put :update, :id => @ps.id, :provider_status => @attr
274 ProviderStatus.any_instance.stub(:save).with(any_args).and_return true
275 ProviderStatus.any_instance.should_receive(:save).exactly(1)
276 put :update, :id => @ps.id, :provider_status => @attr
278 it '@provider_statusにアレを取得している' do
279 put :update, :id => @ps.id, :provider_status => @attr
280 assigns(:provider_status).id.should eq(@ps.id)
283 context 'つつがなく終わるとき' do
285 put :update, :id => @ps.id, :provider_status => @attr
286 ProviderStatus.find(@ps.id).receive_hour1.should eq 22
289 it 'ステータスコード302 Foundを返す' do
290 ProviderStatus.any_instance.stub(:save).with(any_args()).and_return(true)
291 put :update, :id => @ps.id, :provider_status => @attr
292 response.status.should eq 302
294 it '更新された借受状況の表示ページへ遷移する' do
295 put :update, :id => @ps.id, :provider_status => @attr
296 response.should redirect_to(@ps)
300 it 'ステータスコード200 OKを返す' do
301 ProviderStatus.any_instance.stub(:save).with(any_args()).and_return(true)
302 put :update, :id => @ps.id, :provider_status => @attr, :format => :json
303 response.should be_success
306 ProviderStatus.any_instance.stub(:save).with(any_args()).and_return(true)
307 put :update, :id => @ps.id, :provider_status => @attr, :format => :json
308 response.body.should match /./
312 context '管理者権限がないとき' do
316 it 'ステータスコード302 Foundを返す' do
317 put :update, :id => @ps.id, :provider_status => @attr
318 response.status.should eq 302
321 it 'サインインページへ遷移する' do
322 put :update, :id => @ps.id, :provider_status => @attr
323 response.body.should redirect_to '/admins/sign_in'
327 it '応答メッセージにUnauthorizedを返す' do
328 put :update, :id => @ps.id, :provider_status => @attr, :format => :json
329 response.message.should match(/Unauthorized/)
333 context '検証、保存に失敗したとき' do
335 ProviderStatus.any_instance.stub(:save).and_return(false)
338 it 'ステータスコード200 Okを返す' do
339 put :update, :id => @ps.id, :provider_status => @attr
340 response.status.should eq 200
343 put :update, :id => @ps.id, :provider_status => @attr
344 response.should render_template("edit")
348 it 'ステータスコード422 unprocessable_entity を返す' do
349 ProviderStatus.any_instance.stub(:save).and_return(false)
350 put :update, :id => @ps.id, :provider_status => @attr, :format => :json
351 response.status.should eq 422
353 it '応答メッセージUnprocessable Entityを返す' do
354 put :update, :id => @ps.id, :provider_status => @attr, :format => :json
355 response.message.should match(/Unprocessable/)
361 describe 'ライセンスインポートに於いて' do
363 @ps = FactoryGirl.create :provider_status, :token => 'aaaaaaaaaaaaaaaaa'
364 @provider = FactoryGirl.create :provider, :provider_status_id => @ps.id
365 ProviderStatus.stub(:show).and_return(@ps)
368 context '事前チェックしておく' do
370 ProviderStatus.any_instance.stub(:status).with(any_args).and_return(1)
371 ProviderStatusesController.any_instance.stub(:ymd_to_time).with(any_args).and_return(nil)
372 ProviderStatusesController.any_instance.stub(:export_url).with(any_args).and_return(@ps)
373 ProviderStatusesController.any_instance.stub(:export_from_provider).with(any_args).and_return([@license.attributes])
374 ProviderLicense.stub(:import).with(any_args).and_return([])
376 it '借受状況モデルに単体取得を問い合わせている' do
377 ProviderStatus.should_receive(:show).exactly(1)
378 get :licenses_import, :id => @ps.id
380 it '日付文字列変換を依頼している' do
381 ProviderStatusesController.any_instance.should_receive(:ymd_to_time).with('20111010').exactly(1)
382 get :licenses_import, :id => @ps.id, :date => '20111010'
384 it 'エクスポートurl取得を依頼している' do
385 ProviderStatusesController.any_instance.stub(:ymd_to_time).with('20111010').and_return(Time.parse('2011/10/10'))
386 ProviderStatusesController.any_instance.should_receive(:export_url).with(@provider.demander_url, @ps.token, Time.parse('2011/10/10')).exactly(1)
387 get :licenses_import, :id => @ps.id, :date => '20111010'
389 it '貸手からのエクスポートを依頼している' do
390 ProviderStatusesController.any_instance.should_receive(:export_from_provider).exactly(1)
391 get :licenses_import, :id => @ps.id
393 it 'ライセンス対照表モデルにインポートを依頼している' do
394 ProviderLicense.should_receive(:import).exactly(1)
395 get :licenses_import, :id => @ps.id
398 context 'つつがなく終わるとき' do
400 ProviderStatus.any_instance.stub(:status).with(any_args).and_return(1)
401 ProviderStatusesController.any_instance.stub(:ymd_to_time).with('20111010').and_return(Time.parse('2011/10/10'))
402 ProviderStatusesController.any_instance.stub(:ymd_to_time).with(any_args).and_return(nil)
403 ProviderStatusesController.any_instance.stub(:export_url).with(any_args).and_return(@ps)
404 ProviderStatusesController.any_instance.stub(:export_from_provider).with(any_args).and_return([@license.attributes])
405 ProviderLicense.stub(:import).with(any_args).and_return([])
407 it 'ステータスコード200 OKを返す' do
408 get :licenses_import, :id => @ps.id
409 response.should be_success
411 it '@provider_statusに借受状況を取得している' do
412 get :licenses_import, :id => @ps.id
413 assigns(:provider_status).should eq(@ps)
415 it '@failuresにインポート失敗リストを取得している' do
416 get :licenses_import, :id => @ps.id
417 assigns(:failures).should eq([])
420 it 'licenses_importテンプレートを描画する' do
421 get :licenses_import, :id => @ps.id
422 response.should render_template("licenses_import")
427 get :licenses_import, :id => @ps.id, :format => :json
428 lambda{JSON.parse(response.body)}.should_not raise_error(JSON::ParserError)
432 context '管理者権限がないとき' do
437 it 'ステータスコード302 Foundを返す' do
438 get :licenses_import, :id => @ps.id
439 response.status.should eq 302
441 it 'サインインページへ遷移する' do
442 get :licenses_import, :id => @ps.id
443 response.body.should redirect_to '/admins/sign_in'
447 it 'ステータスコード401 Unauthorizedを返す' do
448 get :licenses_import, :id => @ps.id, :format => :json
449 response.status.should eq 401
451 it '応答メッセージにUnauthorizedを返す' do
452 get :licenses_import, :id => @ps.id, :format => :json
453 response.message.should match(/Unauthorized/)
457 context '借受権限がないとき' do
459 ProviderStatus.any_instance.stub(:status).and_return(0)
462 it '例外403 forbiddenを返す' do
464 get :licenses_import, :id => @ps.id
465 }.should raise_error(ActiveRecord::Forbidden)
469 it '例外403 forbiddenを返す' do
471 get :licenses_import, :id => @ps.id, :format => :json
472 }.should raise_error(ActiveRecord::Forbidden)