From e70e721a0d90e7b9b8b9bbf45b92fec2eb7be26b Mon Sep 17 00:00:00 2001 From: Eugen Rochko <eugen@zeonfederated.com> Date: Sun, 29 Jan 2017 12:35:55 +0100 Subject: [PATCH] Add tests for new API --- .../api/v1/devices_controller_spec.rb | 38 +++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 spec/controllers/api/v1/devices_controller_spec.rb diff --git a/spec/controllers/api/v1/devices_controller_spec.rb b/spec/controllers/api/v1/devices_controller_spec.rb new file mode 100644 index 00000000..745a462e --- /dev/null +++ b/spec/controllers/api/v1/devices_controller_spec.rb @@ -0,0 +1,38 @@ +require 'rails_helper' + +RSpec.describe Api::V1::DevicesController, type: :controller do + let(:user) { Fabricate(:user, account: Fabricate(:account, username: 'alice')) } + let(:token) { double acceptable?: true, resource_owner_id: user.id } + + before do + allow(controller).to receive(:doorkeeper_token) { token } + end + + describe 'POST #register' do + before do + post :register, params: { registration_id: 'foo123' } + end + + it 'returns http success' do + expect(response).to have_http_status(:success) + end + + it 'registers device' do + expect(Device.where(account: user.account, registration_id: 'foo123').first).to_not be_nil + end + end + + describe 'POST #unregister' do + before do + post :unregister, params: { registration_id: 'foo123' } + end + + it 'returns http success' do + expect(response).to have_http_status(:success) + end + + it 'removes device' do + expect(Device.where(account: user.account, registration_id: 'foo123').first).to be_nil + end + end +end