2017-08-30 00:49:07 +08:00
|
|
|
require 'rails_helper'
|
|
|
|
|
|
|
|
describe Api::ApiController, type: :controller do
|
2018-08-17 22:13:21 +08:00
|
|
|
describe 'GET #health' do
|
|
|
|
before do
|
|
|
|
get :health
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'Returns HTTP success and with correct text' do
|
|
|
|
expect(response).to be_success
|
|
|
|
expect(response).to have_http_status(200)
|
|
|
|
expect(response.body).to match('RUNNING')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-08-30 00:49:07 +08:00
|
|
|
describe 'GET #status' do
|
|
|
|
before do
|
|
|
|
get :status
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'Returns HTTP success' do
|
|
|
|
expect(response).to be_success
|
|
|
|
expect(response).to have_http_status(200)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'Response with correct JSON status structure' do
|
|
|
|
hash_body = nil
|
|
|
|
expect { hash_body = json }.not_to raise_exception
|
|
|
|
expect(hash_body).to match(
|
|
|
|
'message' => I18n.t('api.core.status_ok'),
|
|
|
|
'versions' => [{ 'version' => '20170715',
|
2018-08-17 22:13:21 +08:00
|
|
|
'baseUrl' => '/api/20170715/' },
|
|
|
|
{ 'version' => 'v1',
|
|
|
|
'baseUrl' => '/api/v1/' }]
|
2017-08-30 00:49:07 +08:00
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'Post #authenticate' do
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
|
|
|
context 'When valid request' do
|
|
|
|
before do
|
2018-01-23 21:54:15 +08:00
|
|
|
post :authenticate, params: { email: user.email,
|
|
|
|
password: user.password,
|
|
|
|
grant_type: 'password' }
|
2017-08-30 00:49:07 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'Returns HTTP success' do
|
|
|
|
expect(response).to have_http_status(200)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'Returns valid JWT token' do
|
|
|
|
token = nil
|
|
|
|
expect { token = json['access_token'] }.not_to raise_exception
|
|
|
|
user_id = nil
|
|
|
|
expect { user_id = decode_token(token) }.not_to raise_exception
|
|
|
|
expect(user_id).to eq(user.id)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'When invalid password in request' do
|
|
|
|
it 'Returns HTTP error' do
|
2018-01-23 21:54:15 +08:00
|
|
|
post :authenticate, params: { email: user.email,
|
|
|
|
password: 'wrong_password',
|
|
|
|
grant_type: 'password' }
|
2017-08-30 00:49:07 +08:00
|
|
|
expect(response).to have_http_status(400)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'When no grant_type in request' do
|
|
|
|
it 'Returns HTTP error' do
|
2018-01-23 21:54:15 +08:00
|
|
|
post :authenticate, params: { email: user.email,
|
|
|
|
password: user.password }
|
2017-08-30 00:49:07 +08:00
|
|
|
expect(response).to have_http_status(400)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|