mirror of
https://github.com/mastodon/mastodon.git
synced 2025-01-09 19:56:20 +01:00
Refer to constant values from api/v1/apps
request spec (#33488)
This commit is contained in:
parent
7ad44e22ed
commit
b3243ef41c
@ -3,14 +3,18 @@
|
|||||||
module ApplicationExtension
|
module ApplicationExtension
|
||||||
extend ActiveSupport::Concern
|
extend ActiveSupport::Concern
|
||||||
|
|
||||||
|
APP_NAME_LIMIT = 60
|
||||||
|
APP_REDIRECT_URI_LIMIT = 2_000
|
||||||
|
APP_WEBSITE_LIMIT = 2_000
|
||||||
|
|
||||||
included do
|
included do
|
||||||
include Redisable
|
include Redisable
|
||||||
|
|
||||||
has_many :created_users, class_name: 'User', foreign_key: 'created_by_application_id', inverse_of: :created_by_application
|
has_many :created_users, class_name: 'User', foreign_key: 'created_by_application_id', inverse_of: :created_by_application
|
||||||
|
|
||||||
validates :name, length: { maximum: 60 }
|
validates :name, length: { maximum: APP_NAME_LIMIT }
|
||||||
validates :website, url: true, length: { maximum: 2_000 }, if: :website?
|
validates :redirect_uri, length: { maximum: APP_REDIRECT_URI_LIMIT }
|
||||||
validates :redirect_uri, length: { maximum: 2_000 }
|
validates :website, url: true, length: { maximum: APP_WEBSITE_LIMIT }, if: :website?
|
||||||
|
|
||||||
# The relationship used between Applications and AccessTokens is using
|
# The relationship used between Applications and AccessTokens is using
|
||||||
# dependent: delete_all, which means the ActiveRecord callback in
|
# dependent: delete_all, which means the ActiveRecord callback in
|
||||||
|
15
spec/models/doorkeeper/application_spec.rb
Normal file
15
spec/models/doorkeeper/application_spec.rb
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
require 'rails_helper'
|
||||||
|
|
||||||
|
RSpec.describe Doorkeeper::Application do
|
||||||
|
describe 'Associations' do
|
||||||
|
it { is_expected.to have_many(:created_users).class_name('User').inverse_of(:created_by_application).with_foreign_key(:created_by_application_id) }
|
||||||
|
end
|
||||||
|
|
||||||
|
describe 'Validations' do
|
||||||
|
it { is_expected.to validate_length_of(:name).is_at_most(described_class::APP_NAME_LIMIT) }
|
||||||
|
it { is_expected.to validate_length_of(:redirect_uri).is_at_most(described_class::APP_REDIRECT_URI_LIMIT) }
|
||||||
|
it { is_expected.to validate_length_of(:website).is_at_most(described_class::APP_WEBSITE_LIMIT) }
|
||||||
|
end
|
||||||
|
end
|
@ -122,7 +122,7 @@ RSpec.describe 'Apps' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
context 'with a too-long name' do
|
context 'with a too-long name' do
|
||||||
let(:client_name) { 'hoge' * 20 }
|
let(:client_name) { 'a' * Doorkeeper::Application::APP_NAME_LIMIT * 2 }
|
||||||
|
|
||||||
it 'returns http unprocessable entity' do
|
it 'returns http unprocessable entity' do
|
||||||
subject
|
subject
|
||||||
@ -134,7 +134,7 @@ RSpec.describe 'Apps' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
context 'with a too-long website' do
|
context 'with a too-long website' do
|
||||||
let(:website) { "https://foo.bar/#{'hoge' * 2_000}" }
|
let(:website) { "https://foo.bar/#{'a' * Doorkeeper::Application::APP_WEBSITE_LIMIT * 2}" }
|
||||||
|
|
||||||
it 'returns http unprocessable entity' do
|
it 'returns http unprocessable entity' do
|
||||||
subject
|
subject
|
||||||
@ -146,7 +146,7 @@ RSpec.describe 'Apps' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
context 'with a too-long redirect_uri' do
|
context 'with a too-long redirect_uri' do
|
||||||
let(:redirect_uris) { "https://app.example/#{'hoge' * 2_000}" }
|
let(:redirect_uris) { "https://app.example/#{'a' * Doorkeeper::Application::APP_REDIRECT_URI_LIMIT * 2}" }
|
||||||
|
|
||||||
it 'returns http unprocessable entity' do
|
it 'returns http unprocessable entity' do
|
||||||
subject
|
subject
|
||||||
|
Loading…
x
Reference in New Issue
Block a user