# -*- encoding: utf-8 -*-
require 'rails_helper'
describe UserImportResultsController do
fixtures :all
describe "GET index" do
describe "When logged in as Administrator" do
login_fixture_admin
it "assigns all user_import_results as @user_import_results" do
get :index
assigns(:user_import_results).should eq(UserImportResult.page(1))
end
describe "With @user_import_file parameter" do
before(:each) do
@file = UserImportFile.create user_import: File.new("#{Rails.root}/../../examples/user_import_file_sample_long.tsv"), user: users(:admin)
@file.default_user_group = UserGroup.find(2)
@file.default_library = Library.find(3)
@file.save
@file.import_start
end
render_views
it "should assign all user_import_results for the user_import_file with a page parameter" do
get :index, user_import_file_id: @file.id
results = assigns(:user_import_results)
results.should_not be_empty
response.body.should match /
11<\/td>/
end
end
end
describe "When logged in as Librarian" do
login_fixture_librarian
it "assigns all user_import_results as @user_import_results" do
get :index
assigns(:user_import_results).should eq(UserImportResult.page(1))
end
end
describe "When logged in as User" do
login_fixture_user
it "assigns empty as @user_import_results" do
get :index
assigns(:user_import_results).should be_nil
response.should be_forbidden
end
end
describe "When not logged in" do
it "assigns empty as @user_import_results" do
get :index
assigns(:user_import_results).should be_nil
response.should redirect_to(new_user_session_url)
end
end
end
describe "GET show" do
describe "When logged in as Administrator" do
login_fixture_admin
it "assigns the requested user_import_result as @user_import_result" do
get :show, id: 1
assigns(:user_import_result).should eq(UserImportResult.find(1))
end
end
describe "When logged in as Librarian" do
login_fixture_librarian
it "assigns the requested user_import_result as @user_import_result" do
get :show, id: 1
assigns(:user_import_result).should eq(UserImportResult.find(1))
end
end
describe "When logged in as User" do
login_fixture_user
it "assigns the requested user_import_result as @user_import_result" do
get :show, id: 1
assigns(:user_import_result).should eq(UserImportResult.find(1))
end
end
describe "When not logged in" do
it "assigns the requested user_import_result as @user_import_result" do
get :show, id: 1
assigns(:user_import_result).should eq(UserImportResult.find(1))
response.should redirect_to(new_user_session_url)
end
end
end
describe "DELETE destroy" do
before(:each) do
@user_import_result = user_import_results(:one)
end
describe "When logged in as Administrator" do
login_fixture_admin
it "destroys the requested user_import_result" do
delete :destroy, id: @user_import_result.id
end
it "should be forbidden" do
delete :destroy, id: @user_import_result.id
response.should be_forbidden
end
end
describe "When logged in as Librarian" do
login_fixture_librarian
it "destroys the requested user_import_result" do
delete :destroy, id: @user_import_result.id
end
it "should be forbidden" do
delete :destroy, id: @user_import_result.id
response.should be_forbidden
end
end
describe "When logged in as User" do
login_fixture_user
it "destroys the requested user_import_result" do
delete :destroy, id: @user_import_result.id
end
it "should be forbidden" do
delete :destroy, id: @user_import_result.id
response.should be_forbidden
end
end
describe "When not logged in" do
it "destroys the requested user_import_result" do
delete :destroy, id: @user_import_result.id
end
it "should be forbidden" do
delete :destroy, id: @user_import_result.id
response.should redirect_to(new_user_session_url)
end
end
end
end
|