forked from bofh/fetsite
additional neuigkeit test
This commit is contained in:
@@ -2,54 +2,126 @@
|
||||
require 'spec_helper'
|
||||
|
||||
RSpec.describe NeuigkeitenController, :type => :controller do
|
||||
let(:rubrik) {FactoryGirl.create(:rubrik, public:true)}
|
||||
let(:intern_rubrik) {FactoryGirl.create(:rubrik, public:false, name: "InternRubrik")}
|
||||
let(:user) {FactoryGirl.create(:user)}
|
||||
let(:fet_user) do
|
||||
user=FactoryGirl.create(:user)
|
||||
user.add_role(:fetadmin)
|
||||
end
|
||||
|
||||
let(:neuigkeit) {(FactoryGirl.create(:neuigkeit, :with_rubrik))}
|
||||
let(:intern_neuigkeit) {(FactoryGirl.create(:neuigkeit,:with_intern_rubrik))}
|
||||
|
||||
let(:neuigkeit) {(FactoryGirl.create(:neuigkeit, rubrik_id: rubrik.id, author_id: user.id, datum: 4.hours.ago))}
|
||||
let(:intern_neuigkeit) {(FactoryGirl.create(:neuigkeit, rubrik_id: intern_rubrik.id, author_id: user.id, datum: 4.hours.ago))}
|
||||
let(:valid_session) { {current_user: fet_user} }
|
||||
let(:public_session){{}}
|
||||
let(:valid_session) {{}}
|
||||
|
||||
# setting up shared examples
|
||||
let(:object_class) {Neuigkeit}
|
||||
let(:object_variable) {:neuigkeit}
|
||||
let(:assigned_object_variable){neuigkeit}
|
||||
|
||||
#let(:allow_fet_user) {allow(@controller).to receive(:current_user).and_return(fet_user)}
|
||||
|
||||
|
||||
describe "GET #show" do
|
||||
it "render show template" do
|
||||
get :show, {id: neuigkeit.id}, public_session
|
||||
expect(response).to have_http_status(200)
|
||||
expect(response).to render_template(:show)
|
||||
let(:action) { get :show, {id: neuigkeit.id, rubrik_id: neuigkeit.rubrik.id}}
|
||||
|
||||
it_behaves_like "it is success"
|
||||
it_behaves_like "it assigns object"
|
||||
|
||||
context "with internal news" do
|
||||
let(:action) { get :show, {id: intern_neuigkeit.id, rubrik_id: intern_neuigkeit.rubrik.id}}
|
||||
it_behaves_like "it is restricted"
|
||||
|
||||
context "with fet user" do
|
||||
with_fet_user
|
||||
it_behaves_like "it is success"
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
it "denys access to unpublished news" do
|
||||
neuigkeit.datum=5.hours.from_now
|
||||
neuigkeit.save!
|
||||
get :show, {id: neuigkeit.id}, public_session
|
||||
neuigkeit=FactoryGirl.create(:neuigkeit, :unpublished)
|
||||
get :show, {id: neuigkeit.id}, valid_session
|
||||
expect(response).to have_http_status(302)
|
||||
end
|
||||
|
||||
it "denys access to intern news" do
|
||||
get :show, {id: intern_neuigkeit.id}, public_session
|
||||
expect(response).to have_http_status(302)
|
||||
end
|
||||
|
||||
it "assignes neuigkeit" do
|
||||
|
||||
get :show, {id: neuigkeit.id }, public_session
|
||||
expect(assigns(:neuigkeit)).to eq(neuigkeit)
|
||||
end
|
||||
describe "GET #show view contents" do
|
||||
|
||||
|
||||
context "with rendered views" do
|
||||
render_views
|
||||
it "renders the name of the neuigkeit" do
|
||||
get :show, {id: neuigkeit.id} , public_session
|
||||
before do
|
||||
neuigkeit.rubrik
|
||||
intern_neuigkeit
|
||||
end
|
||||
|
||||
it "shows the name" do
|
||||
action
|
||||
expect(response.body).to match neuigkeit.name
|
||||
end
|
||||
it "has linkes to external rubrik" do
|
||||
it "has only links to external rubrik" do
|
||||
get :show, {id: neuigkeit.id}, public_session
|
||||
expect(response.body).to match rubrik.name
|
||||
expect(response.body).not_to match intern_rubrik.name
|
||||
end
|
||||
|
||||
context "and fet user" do
|
||||
with_fet_user
|
||||
it "has all links to internal and external rubriken" do
|
||||
action
|
||||
expect(response.body).to match intern_rubrik.name
|
||||
expect(response.body).to match rubrik.name
|
||||
end
|
||||
end
|
||||
it "shows datum in response" do
|
||||
action
|
||||
expect(response.body).to match I18n.l(neuigkeit.datum.to_date)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
describe "GET #edit" do
|
||||
let(:action) { get :edit, {id: neuigkeit.id, rubrik_id: neuigkeit.rubrik.id}}
|
||||
include_examples "it is restricted"
|
||||
it_behaves_like "it assigns object"
|
||||
it_behaves_like "it assigns persisted object"
|
||||
context "with fet user" do
|
||||
with_fet_user
|
||||
it_behaves_like "it is success"
|
||||
end
|
||||
end
|
||||
describe "GET #new" do
|
||||
let(:action) { get :new, {rubrik_id: neuigkeit.rubrik.id}}
|
||||
include_examples "it assigns new object"
|
||||
include_examples "it is restricted"
|
||||
context "with fet user" do
|
||||
with_fet_user
|
||||
it_behaves_like "it is success"
|
||||
end
|
||||
end
|
||||
|
||||
describe "GET add_calentry" do
|
||||
let(:action) { get :add_calentry, {id: neuigkeit.id, rubrik_id: neuigkeit.rubrik.id}}
|
||||
|
||||
it_behaves_like "it is restricted"
|
||||
context "with fet user" do
|
||||
with_fet_user
|
||||
it_behaves_like "it is success"
|
||||
it "renders edit template" do
|
||||
expect(action).to render_template(:edit)
|
||||
end
|
||||
|
||||
it "adds calentry to neuigkeit" do
|
||||
action
|
||||
expect(assigns(:neuigkeit).calentries).not_to be_empty
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe "GET unpublish" do
|
||||
let(:action) {get :unpublish, {id: neuigkeit.id, rubrik_id: neuigkeit.rubrik.id}}
|
||||
it_behaves_like "it is restricted"
|
||||
context "with fet user" do
|
||||
with_fet_user
|
||||
it "redirects to neuigkeit" do
|
||||
expect(action).to redirect_to(rubrik_neuigkeit_url(rubrik,neuigkeit))
|
||||
end
|
||||
it "assignes unpublished neuigkeit" do
|
||||
action
|
||||
expect(assigns(:neuigkeit)).not_to be_published
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user