ok metacode spec done
This commit is contained in:
parent
6d0dcec1ba
commit
7f50db1ae9
3 changed files with 33 additions and 43 deletions
|
@ -1,5 +1,4 @@
|
||||||
class Metacode < ActiveRecord::Base
|
class Metacode < ActiveRecord::Base
|
||||||
|
|
||||||
has_many :in_metacode_sets
|
has_many :in_metacode_sets
|
||||||
has_many :metacode_sets, :through => :in_metacode_sets
|
has_many :metacode_sets, :through => :in_metacode_sets
|
||||||
has_many :topics
|
has_many :topics
|
||||||
|
|
|
@ -2,22 +2,22 @@ require 'rails_helper'
|
||||||
|
|
||||||
RSpec.describe MetacodesController, type: :controller do
|
RSpec.describe MetacodesController, type: :controller do
|
||||||
let(:metacode) { create(:metacode) }
|
let(:metacode) { create(:metacode) }
|
||||||
let(:valid_attributes) { metacode.attributes.except(:id) }
|
let(:valid_attributes) { metacode.attributes.except('id') }
|
||||||
let(:invalid_attributes) { { permission: :commons } }
|
|
||||||
before :each do
|
before :each do
|
||||||
sign_in
|
sign_in create(:user, admin: true)
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'GET #index' do
|
describe 'GET #index' do
|
||||||
it 'assigns all metacodes as @metacodes' do
|
it 'assigns all metacodes as @metacodes' do
|
||||||
|
metacode.reload # ensure it's created
|
||||||
get :index, {}
|
get :index, {}
|
||||||
expect(assigns(:metacodes).to_a).to eq([metacode])
|
expect(Metacode.all.to_a).to eq([metacode])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'GET #new' do
|
describe 'GET #new' do
|
||||||
it 'assigns a new metacode as @metacode' do
|
it 'assigns a new metacode as @metacode' do
|
||||||
get :new, {}
|
get :new, { format: :json }
|
||||||
expect(assigns(:metacode)).to be_a_new(Metacode)
|
expect(assigns(:metacode)).to be_a_new(Metacode)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -32,32 +32,22 @@ RSpec.describe MetacodesController, type: :controller do
|
||||||
describe 'POST #create' do
|
describe 'POST #create' do
|
||||||
context 'with valid params' do
|
context 'with valid params' do
|
||||||
it 'creates a new Metacode' do
|
it 'creates a new Metacode' do
|
||||||
|
metacode.reload # ensure it's present to start
|
||||||
expect do
|
expect do
|
||||||
post :create, { metacode: valid_attributes }
|
post :create, { metacode: valid_attributes }
|
||||||
end.to change(Metacode, :count).by(1)
|
end.to change(Metacode, :count).by(1)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'assigns a newly created metacode as @metacode' do
|
it 'has the correct attributes' do
|
||||||
post :create, { metacode: valid_attributes }
|
post :create, { metacode: valid_attributes }
|
||||||
|
# expect(Metacode.last.attributes.expect(:id)).to eq(metacode.attributes.except(:id))
|
||||||
expect(assigns(:metacode)).to be_a(Metacode)
|
expect(assigns(:metacode)).to be_a(Metacode)
|
||||||
expect(assigns(:metacode)).to be_persisted
|
expect(assigns(:metacode)).to be_persisted
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'redirects to the created metacode' do
|
it 'redirects to the metacode index' do
|
||||||
post :create, { metacode: valid_attributes }
|
post :create, { metacode: valid_attributes }
|
||||||
expect(response).to redirect_to(Metacode.last)
|
expect(response).to redirect_to(metacodes_url)
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'with invalid params' do
|
|
||||||
it 'assigns a newly created but unsaved metacode as @metacode' do
|
|
||||||
post :create, { metacode: invalid_attributes }
|
|
||||||
expect(assigns(:metacode)).to be_a_new(Metacode)
|
|
||||||
end
|
|
||||||
|
|
||||||
it "re-renders the 'new' template" do
|
|
||||||
post :create, { metacode: invalid_attributes }
|
|
||||||
expect(response).to render_template('new')
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -65,35 +55,33 @@ RSpec.describe MetacodesController, type: :controller do
|
||||||
describe 'PUT #update' do
|
describe 'PUT #update' do
|
||||||
context 'with valid params' do
|
context 'with valid params' do
|
||||||
let(:new_attributes) do
|
let(:new_attributes) do
|
||||||
skip('Add a hash of attributes valid for your model')
|
{ icon: 'https://newimages.ca/cool-image.jpg',
|
||||||
|
color: '#ffffff',
|
||||||
|
name: 'Cognition' }
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'updates the requested metacode' do
|
it 'updates the requested metacode' do
|
||||||
put :update,
|
put :update,
|
||||||
{ id: metacode.to_param, metacode: new_attributes }
|
{ id: metacode.to_param, metacode: new_attributes }
|
||||||
metacode.reload
|
metacode.reload
|
||||||
skip('Add assertions for updated state')
|
expect(metacode.icon).to eq 'https://newimages.ca/cool-image.jpg'
|
||||||
end
|
expect(metacode.color).to eq '#ffffff'
|
||||||
|
expect(metacode.name).to eq 'Cognition'
|
||||||
it 'assigns the requested metacode as @metacode' do
|
|
||||||
put :update,
|
|
||||||
{ id: metacode.to_param, metacode: valid_attributes }
|
|
||||||
expect(assigns(:metacode)).to eq(metacode)
|
|
||||||
end
|
|
||||||
|
|
||||||
it 'redirects to the metacode' do
|
|
||||||
put :update,
|
|
||||||
{ id: metacode.to_param, metacode: valid_attributes }
|
|
||||||
expect(response).to redirect_to(metacode)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
context 'with invalid params' do
|
|
||||||
it 'redirects to edit template' do
|
|
||||||
put :update,
|
|
||||||
{ id: metacode.to_param, metacode: invalid_attributes }
|
|
||||||
expect(response.status).to eq 302
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context 'not admin' do
|
||||||
|
it 'denies access to create' do
|
||||||
|
sign_in create(:user, admin: false)
|
||||||
|
post :create, { metacode: valid_attributes }
|
||||||
|
expect(response).to redirect_to root_url
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'denies access to update' do
|
||||||
|
sign_in create(:user, admin: false)
|
||||||
|
post :update, { id: metacode.to_param, metacode: valid_attributes }
|
||||||
|
expect(response).to redirect_to root_url
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,4 +1,7 @@
|
||||||
FactoryGirl.define do
|
FactoryGirl.define do
|
||||||
factory :metacode do
|
factory :metacode do
|
||||||
|
sequence(:name) { |n| "Cool Metacode ##{n}" }
|
||||||
|
icon 'https://images.com/image.png'
|
||||||
|
color '#cccccc'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue