1
0
Fork 0

Do not create same Telegram user twice

This commit is contained in:
Alex Kotov 2018-11-29 22:34:28 +05:00
parent 79128fa5da
commit 98071229a1
No known key found for this signature in database
GPG Key ID: 4E831250F47DE154
2 changed files with 61 additions and 8 deletions

View File

@ -28,13 +28,15 @@ private
end
def handle_user(user)
TelegramUser.create!(
remote_telegram_id: user[:id],
is_bot: user[:is_bot],
first_name: user[:first_name],
last_name: user[:last_name],
username: user[:username],
language_code: user[:language_code],
)
telegram_user =
TelegramUser.find_or_initialize_by remote_telegram_id: user[:id]
telegram_user.is_bot = user[:is_bot]
telegram_user.first_name = user[:first_name]
telegram_user.last_name = user[:last_name]
telegram_user.username = user[:username]
telegram_user.language_code = user[:language_code]
telegram_user.save!
end
end

View File

@ -86,4 +86,55 @@ RSpec.describe 'POST /telegram_bot_updates' do
end
end
end
context 'when message "from" attribute is set and ' \
'Telegram user already exist' do
let! :telegram_user do
create :telegram_user, remote_telegram_id: remote_telegram_id
end
def make_request
post '/telegram_bot_updates',
params: { telegram_bot_id: telegram_bot.id,
secret: telegram_bot.secret,
message: { from: telegram_user_attributes } }
end
let :telegram_user_attributes do
{
id: remote_telegram_id,
is_bot: is_bot,
first_name: first_name,
last_name: last_name,
username: username,
language_code: language_code,
}
end
let(:remote_telegram_id) { rand 1..1_000_000 }
let(:is_bot) { [false, true].sample }
let(:first_name) { Faker::Name.first_name }
let(:last_name) { Faker::Name.last_name }
let(:username) { Faker::Internet.username }
let(:language_code) { I18n.available_locales.sample.to_s }
specify do
expect { make_request }.not_to change(TelegramUser, :count).from(1)
end
context 'after request' do
before { make_request }
specify do
expect(TelegramUser.last).to have_attributes(
remote_telegram_id: remote_telegram_id,
is_bot: is_bot,
first_name: first_name,
last_name: last_name,
username: username,
language_code: language_code,
)
end
end
end
end