logo

mastofe

My custom branche(s) on git.pleroma.social/pleroma/mastofe
commit: e70e721a0d90e7b9b8b9bbf45b92fec2eb7be26b
parent: 83ccdeb87a6d9cd9b506707be8814cc7a0f242d2
Author: Eugen Rochko <eugen@zeonfederated.com>
Date:   Sun, 29 Jan 2017 12:35:55 +0100

Add tests for new API

Diffstat:

Aspec/controllers/api/v1/devices_controller_spec.rb38++++++++++++++++++++++++++++++++++++++
1 file changed, 38 insertions(+), 0 deletions(-)

diff --git a/spec/controllers/api/v1/devices_controller_spec.rb 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