From a32a2b08a7c42e82724e49bebdfa48001e460d6a Mon Sep 17 00:00:00 2001 From: Rasmus Kjellberg <2277443+kjellberg@users.noreply.github.com> Date: Thu, 4 Apr 2024 23:01:04 +0200 Subject: [PATCH] chore: replace role column with owner boolean --- app/controllers/accounts_controller.rb | 2 +- app/controllers/users/cancellations_controller.rb | 2 +- app/controllers/users/registrations_controller.rb | 2 +- app/models/account_user.rb | 11 +++++------ app/views/accounts/members/index.html.erb | 2 -- config/locales/kiqr.en.yml | 5 ----- ...205037_replace_role_with_owner_on_account_users.rb | 6 ++++++ db/schema.rb | 4 ++-- test/controllers/accounts/members_controller_test.rb | 10 +++++----- test/controllers/accounts_controller_test.rb | 2 +- .../controllers/users/cancellation_controller_test.rb | 2 +- test/helpers/current_helper_test.rb | 2 +- test/kiqr_test.rb | 2 ++ test/models/account_user_test.rb | 10 ++++++++-- test/system/accounts/accounts_test.rb | 4 ++-- test/system/signin_test.rb | 2 +- test/system/users/cancellation_test.rb | 2 +- 17 files changed, 38 insertions(+), 32 deletions(-) create mode 100644 db/migrate/20240404205037_replace_role_with_owner_on_account_users.rb diff --git a/app/controllers/accounts_controller.rb b/app/controllers/accounts_controller.rb index 98da758..37d4c8e 100644 --- a/app/controllers/accounts_controller.rb +++ b/app/controllers/accounts_controller.rb @@ -7,7 +7,7 @@ def new def create @account = Account.new(account_permitted_parameters) - @account.account_users.new(user: current_user, role: "owner") + @account.account_users.new(user: current_user, owner: true) if @account.save redirect_to dashboard_path(account_id: @account), notice: I18n.t("accounts.create.success") diff --git a/app/controllers/users/cancellations_controller.rb b/app/controllers/users/cancellations_controller.rb index 76d932e..976c96d 100644 --- a/app/controllers/users/cancellations_controller.rb +++ b/app/controllers/users/cancellations_controller.rb @@ -1,6 +1,6 @@ class Users::CancellationsController < ApplicationController def show # Get a list of accounts where the current user is the owner. - @conflicting_account_users = current_user.account_users.where(role: "owner") + @conflicting_account_users = current_user.account_users.where(owner: true) end end diff --git a/app/controllers/users/registrations_controller.rb b/app/controllers/users/registrations_controller.rb index 4c4553a..38153c1 100644 --- a/app/controllers/users/registrations_controller.rb +++ b/app/controllers/users/registrations_controller.rb @@ -1,7 +1,7 @@ class Users::RegistrationsController < Devise::RegistrationsController def destroy # Don't let user cancel their accounts if they are an owner of a team. - if current_user.account_users.find_by(role: "owner") + if current_user.account_users.find_by(owner: true) flash[:alert] = I18n.t("users.registrations.destroy.owner_of_team") return redirect_to delete_user_registration_path end diff --git a/app/models/account_user.rb b/app/models/account_user.rb index b6d26dc..6e71c4a 100644 --- a/app/models/account_user.rb +++ b/app/models/account_user.rb @@ -5,16 +5,15 @@ class AccountUser < ApplicationRecord # This will generate a public_uid for the # Learn more: https://github.com/equivalent/public_uid include PublicUid::ModelConcern - # This is a list of roles that a user can have in an account. - # You can add more roles if you want, but you SHOULD NOT REMOVE - # the owner role, as it is required for the account to function. - ROLES = %w[owner admin readonly] - belongs_to :user belongs_to :account # The name of the account user. delegate :name, to: :user - validates :role, presence: true, inclusion: {in: self::ROLES} + # Prevent the deletion of account owners. + def destroy + return if owner? + super + end end diff --git a/app/views/accounts/members/index.html.erb b/app/views/accounts/members/index.html.erb index 663d15c..084ddbd 100644 --- a/app/views/accounts/members/index.html.erb +++ b/app/views/accounts/members/index.html.erb @@ -14,7 +14,6 @@ <%= t(".table.name") %> <%= t(".table.email") %> - <%= t(".table.role") %> <%= t(".table.actions") %> @@ -23,7 +22,6 @@ <%= member.user.name %> <%= member.user.email %> - <%= member.role %> <%= link_to t(".table.edit"), edit_member_path(id: member), class: "button xs" %> diff --git a/config/locales/kiqr.en.yml b/config/locales/kiqr.en.yml index dfb4961..e4b5f13 100644 --- a/config/locales/kiqr.en.yml +++ b/config/locales/kiqr.en.yml @@ -59,7 +59,6 @@ en: table: name: "Name" email: "Email" - role: "Role" actions: "Actions" edit: "Edit" edit: @@ -74,10 +73,6 @@ en: form: submit: "Save changes" account_users: - roles: - owner: "Owner" - admin: "Admin" - readonly: "Read-Only" destroy: success: "Member has successfully been removed from the team." failure: "Member could not be removed. Please contact support if this issue persists." diff --git a/db/migrate/20240404205037_replace_role_with_owner_on_account_users.rb b/db/migrate/20240404205037_replace_role_with_owner_on_account_users.rb new file mode 100644 index 0000000..b6900d9 --- /dev/null +++ b/db/migrate/20240404205037_replace_role_with_owner_on_account_users.rb @@ -0,0 +1,6 @@ +class ReplaceRoleWithOwnerOnAccountUsers < ActiveRecord::Migration[7.1] + def change + remove_column :account_users, :role, :string, default: "owner", null: false + add_column :account_users, :owner, :boolean, default: false, null: false + end +end diff --git a/db/schema.rb b/db/schema.rb index e091cc4..9d8fbcc 100644 --- a/db/schema.rb +++ b/db/schema.rb @@ -10,14 +10,14 @@ # # It's strongly recommended that you check this file into your version control system. -ActiveRecord::Schema[7.1].define(version: 2024_04_04_092246) do +ActiveRecord::Schema[7.1].define(version: 2024_04_04_205037) do create_table "account_users", force: :cascade do |t| t.integer "user_id", null: false t.integer "account_id", null: false - t.string "role", default: "owner", null: false t.datetime "created_at", null: false t.datetime "updated_at", null: false t.string "public_uid" + t.boolean "owner", default: false, null: false t.index ["account_id"], name: "index_account_users_on_account_id" t.index ["public_uid"], name: "index_account_users_on_public_uid", unique: true t.index ["user_id"], name: "index_account_users_on_user_id" diff --git a/test/controllers/accounts/members_controller_test.rb b/test/controllers/accounts/members_controller_test.rb index e76a6ed..d361820 100644 --- a/test/controllers/accounts/members_controller_test.rb +++ b/test/controllers/accounts/members_controller_test.rb @@ -14,8 +14,8 @@ class Accounts::MembersControllerTest < ActionDispatch::IntegrationTest some_user = create(:user) account = create(:account, name: "Team account") - account.account_users << AccountUser.create(user: user, role: "owner") - account.account_users << AccountUser.create(user: some_user, role: "admin") + account.account_users << AccountUser.create(user: user, owner: true) + account.account_users << AccountUser.create(user: some_user) sign_in user get edit_member_path(account_id: account, id: some_user.account_users.first) @@ -26,7 +26,7 @@ class Accounts::MembersControllerTest < ActionDispatch::IntegrationTest test "can show members as team account" do user = create(:user) account = create(:account, name: "Team account") - account.account_users << AccountUser.create(user:, role: "owner") + account.account_users << AccountUser.create(user:, owner: true) sign_in user get members_path(account_id: account) @@ -39,8 +39,8 @@ class Accounts::MembersControllerTest < ActionDispatch::IntegrationTest some_user = create(:user) account = create(:account, name: "Team account") - account.account_users << AccountUser.create(user: user, role: "owner") - account.account_users << AccountUser.create(user: some_user, role: "admin") + account.account_users << AccountUser.create(user: user, owner: true) + account.account_users << AccountUser.create(user: some_user) assert_includes account.reload.users, some_user diff --git a/test/controllers/accounts_controller_test.rb b/test/controllers/accounts_controller_test.rb index 813915d..b9c96f6 100644 --- a/test/controllers/accounts_controller_test.rb +++ b/test/controllers/accounts_controller_test.rb @@ -47,7 +47,7 @@ class AccountsControllerTest < ActionDispatch::IntegrationTest test "can update team accounts" do user = create(:user) account = create(:account, name: "Team account") - account.account_users << AccountUser.create(user:, role: "owner") + account.account_users << AccountUser.create(user:, owner: true) sign_in user patch account_path(account_id: account), params: {account: {name: "New company name"}} diff --git a/test/controllers/users/cancellation_controller_test.rb b/test/controllers/users/cancellation_controller_test.rb index 8121a76..86f8407 100644 --- a/test/controllers/users/cancellation_controller_test.rb +++ b/test/controllers/users/cancellation_controller_test.rb @@ -19,7 +19,7 @@ class Users::RegistrationControllerTest < ActionDispatch::IntegrationTest test "can't delete a user with owned teams" do user = create(:user) team_account = create(:account, name: "Team account") - team_account.account_users << AccountUser.create(user: user, role: "owner") + team_account.account_users << AccountUser.create(user: user, owner: true) sign_in user delete user_registration_path diff --git a/test/helpers/current_helper_test.rb b/test/helpers/current_helper_test.rb index d64e533..a7cb5d8 100644 --- a/test/helpers/current_helper_test.rb +++ b/test/helpers/current_helper_test.rb @@ -7,7 +7,7 @@ class CurrentHelperTest < ActionView::TestCase @current_user = create(:user) @team_account = create(:account, name: "Company 1") @alien_account = create(:account, name: "Someone else's account") - @current_user.account_users << AccountUser.new(account: @team_account, role: "owner") + @current_user.account_users << AccountUser.new(account: @team_account, owner: true) Current.user = @current_user end diff --git a/test/kiqr_test.rb b/test/kiqr_test.rb index 8a1c35d..087e102 100644 --- a/test/kiqr_test.rb +++ b/test/kiqr_test.rb @@ -1,3 +1,5 @@ +require "test_helper" + class KiqrTest < ActiveSupport::TestCase test "should set default_url_options to localhost:3000 in test environment" do assert_equal Kiqr.default_url_options, {host: "localhost", port: 3000, protocol: "http"} diff --git a/test/models/account_user_test.rb b/test/models/account_user_test.rb index 1abf13c..52d0257 100644 --- a/test/models/account_user_test.rb +++ b/test/models/account_user_test.rb @@ -1,7 +1,13 @@ require "test_helper" class AccountUserTest < ActiveSupport::TestCase - test "should have the owner role" do - assert_includes AccountUser::ROLES, "owner" + test "can't remove the team owner" do + user = create(:user) + account = create(:account, name: "Team account") + account.account_users << AccountUser.create(user: user, owner: true) + + assert_no_difference -> { AccountUser.count } do + account.account_users.first.destroy + end end end diff --git a/test/system/accounts/accounts_test.rb b/test/system/accounts/accounts_test.rb index 36620fc..a2e38ed 100644 --- a/test/system/accounts/accounts_test.rb +++ b/test/system/accounts/accounts_test.rb @@ -21,7 +21,7 @@ class EditAccountsTest < ApplicationSystemTestCase test "can edit team account" do user = create(:user) team_account = create(:account, name: "Team account") - team_account.account_users << AccountUser.create(user: user, role: "owner") + team_account.account_users << AccountUser.create(user: user, owner: true) sign_in(user) visit edit_account_path(account_id: team_account) @@ -51,7 +51,7 @@ class EditAccountsTest < ApplicationSystemTestCase account = user.reload.accounts.last assert_equal "New name", account.name - assert_equal "owner", account.account_users.find_by(user: user).role + assert account.account_users.find_by(user: user).owner? assert_current_path dashboard_path(account_id: account) end end diff --git a/test/system/signin_test.rb b/test/system/signin_test.rb index e6b4f03..d1b248c 100644 --- a/test/system/signin_test.rb +++ b/test/system/signin_test.rb @@ -15,7 +15,7 @@ class SigninTest < ApplicationSystemTestCase test "select account after sign in if user has teams" do user = create(:user) account = create(:account, name: "Team account") - account.account_users << AccountUser.create(user:, role: "owner") + account.account_users << AccountUser.create(user:, owner: true) visit new_user_session_path fill_in "user[email]", with: user.email diff --git a/test/system/users/cancellation_test.rb b/test/system/users/cancellation_test.rb index 8ec1b89..940d403 100644 --- a/test/system/users/cancellation_test.rb +++ b/test/system/users/cancellation_test.rb @@ -14,7 +14,7 @@ class EditAccountsTest < ApplicationSystemTestCase test "don't show delete button if user is an owner of a team" do user = create(:user) team_account = create(:account, name: "Team account") - team_account.account_users << AccountUser.create(user: user, role: "owner") + team_account.account_users << AccountUser.create(user: user, owner: true) sign_in(user) visit delete_user_registration_path