user upgrades: add upgrade code system.

Add a system for upgrading accounts using upgrade codes. Users purchase
an upgrade code off-site then redeem it on-site to upgrade their account
to Gold. Upgrade codes are randomly pre-generated and are one time use
only. Codes have enough randomness that guessing a code is infeasible.
This commit is contained in:
evazion
2022-05-25 17:28:39 -05:00
parent 7786fbaca6
commit 173e43b192
22 changed files with 461 additions and 22 deletions

View File

@@ -0,0 +1,87 @@
require 'test_helper'
class UserUpgradesControllerTest < ActionDispatch::IntegrationTest
context "The upgrade codes controller" do
context "index action" do
should "render for the owner" do
create(:upgrade_code)
@user = create(:owner_user)
get_auth upgrade_codes_path, @user
assert_response :success
end
should "not render for non-privileged users" do
create(:upgrade_code)
@user = create(:admin_user)
get_auth upgrade_codes_path, @user
assert_response 403
end
end
context "redeem action" do
should "render for an anonymous user" do
get redeem_upgrade_codes_path
assert_response :success
end
should "render for a member user" do
get_auth redeem_upgrade_codes_path, create(:user)
assert_response :success
end
should "render for a Gold user" do
get_auth redeem_upgrade_codes_path, create(:gold_user)
assert_response :success
end
end
context "upgrade action" do
should "return an error for an invalid code" do
code = create(:upgrade_code)
user = create(:user)
post_auth upgrade_upgrade_codes_path, user, params: { upgrade_code: { code: "abcd" }}, xhr: true
assert_response 422
assert_equal(false, user.reload.is_gold?)
assert_equal(false, code.reload.redeemed?)
assert_nil(code.redeemer)
end
should "return an error for an already redeemed code" do
code = create(:upgrade_code, status: :redeemed)
user = create(:user)
post_auth upgrade_upgrade_codes_path, user, params: { upgrade_code: { code: code.code }}, xhr: true
assert_response 422
assert_equal(false, user.reload.is_gold?)
end
should "return an error for an already upgraded user" do
code = create(:upgrade_code)
user = create(:builder_user)
post_auth upgrade_upgrade_codes_path, user, params: { upgrade_code: { code: code.code }}, xhr: true
assert_response 422
assert_equal(true, user.reload.is_builder?)
assert_equal(false, code.reload.redeemed?)
assert_nil(code.redeemer)
end
should "upgrade the user for a unredeemed code" do
code = create(:upgrade_code)
user = create(:user)
post_auth upgrade_upgrade_codes_path, user, params: { upgrade_code: { code: code.code }}, xhr: true
assert_response 200
assert_equal(true, user.reload.is_gold?)
assert_equal(true, code.reload.redeemed?)
assert_equal(user, code.redeemer)
end
end
end
end