|
|
@ -6,8 +6,11 @@ describe Admin::AdminUsersController, type: :controller do |
|
|
|
let(:page) { Capybara::Node::Simple.new(response.body) } |
|
|
|
let(:page) { Capybara::Node::Simple.new(response.body) } |
|
|
|
let(:resource_title) { "Admin Users" } |
|
|
|
let(:resource_title) { "Admin Users" } |
|
|
|
let(:valid_session) { {} } |
|
|
|
let(:valid_session) { {} } |
|
|
|
|
|
|
|
let(:signed_in_admin_user) { FactoryBot.create(:admin_user) } |
|
|
|
|
|
|
|
|
|
|
|
login_admin_user |
|
|
|
before do |
|
|
|
|
|
|
|
sign_in signed_in_admin_user |
|
|
|
|
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
describe "Get admin users" do |
|
|
|
describe "Get admin users" do |
|
|
|
before do |
|
|
|
before do |
|
|
@ -27,22 +30,30 @@ describe Admin::AdminUsersController, type: :controller do |
|
|
|
it "creates a new admin user" do |
|
|
|
it "creates a new admin user" do |
|
|
|
expect { post :create, session: valid_session, params: params }.to change(AdminUser, :count).by(1) |
|
|
|
expect { post :create, session: valid_session, params: params }.to change(AdminUser, :count).by(1) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
it "tracks who created the record" do |
|
|
|
|
|
|
|
post :create, session: valid_session, params: params |
|
|
|
|
|
|
|
created_id = response.location.match(/[0-9]+/)[0] |
|
|
|
|
|
|
|
whodunnit_actor = AdminUser.find_by(id: created_id).versions.last.actor |
|
|
|
|
|
|
|
expect(whodunnit_actor).to be_a(AdminUser) |
|
|
|
|
|
|
|
expect(whodunnit_actor.id).to eq(signed_in_admin_user.id) |
|
|
|
|
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
describe "Update admin users" do |
|
|
|
describe "Update admin users" do |
|
|
|
context "when editing the form" do |
|
|
|
context "when viewing the form" do |
|
|
|
before do |
|
|
|
before do |
|
|
|
get :edit, session: valid_session, params: { id: AdminUser.first.id } |
|
|
|
get :edit, session: valid_session, params: { id: AdminUser.first.id } |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
it "shows an edit form" do |
|
|
|
it "shows the correct fields" do |
|
|
|
expect(page).to have_field("admin_user_email") |
|
|
|
expect(page).to have_field("admin_user_email") |
|
|
|
expect(page).to have_field("admin_user_password") |
|
|
|
expect(page).to have_field("admin_user_password") |
|
|
|
expect(page).to have_field("admin_user_password_confirmation") |
|
|
|
expect(page).to have_field("admin_user_password_confirmation") |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
context "when updating the form" do |
|
|
|
context "when updating an admin user" do |
|
|
|
let(:admin_user) { FactoryBot.create(:admin_user) } |
|
|
|
let(:admin_user) { FactoryBot.create(:admin_user) } |
|
|
|
let(:email) { "new_email@example.com" } |
|
|
|
let(:email) { "new_email@example.com" } |
|
|
|
let(:params) { { id: admin_user.id, admin_user: { email: email } } } |
|
|
|
let(:params) { { id: admin_user.id, admin_user: { email: email } } } |
|
|
@ -55,6 +66,13 @@ describe Admin::AdminUsersController, type: :controller do |
|
|
|
admin_user.reload |
|
|
|
admin_user.reload |
|
|
|
expect(admin_user.email).to eq(email) |
|
|
|
expect(admin_user.email).to eq(email) |
|
|
|
end |
|
|
|
end |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
it "tracks who updated the record" do |
|
|
|
|
|
|
|
admin_user.reload |
|
|
|
|
|
|
|
whodunnit_actor = admin_user.versions.last.actor |
|
|
|
|
|
|
|
expect(whodunnit_actor).to be_a(AdminUser) |
|
|
|
|
|
|
|
expect(whodunnit_actor.id).to eq(signed_in_admin_user.id) |
|
|
|
|
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|
end |
|
|
|