mirror of
https://github.com/Freika/dawarich.git
synced 2026-01-13 10:41:38 -05:00
Add test for photos integration not being configured
This commit is contained in:
parent
7bcdff5868
commit
955f8946ad
4 changed files with 77 additions and 42 deletions
|
|
@ -1,6 +1,9 @@
|
|||
# frozen_string_literal: true
|
||||
|
||||
class Api::V1::PhotosController < ApiController
|
||||
before_action :check_integration_configured, only: %i[index thumbnail]
|
||||
before_action :check_source, only: %i[thumbnail]
|
||||
|
||||
def index
|
||||
@photos = Rails.cache.fetch("photos_#{params[:start_date]}_#{params[:end_date]}", expires_in: 1.day) do
|
||||
Photos::Request.new(current_api_user, start_date: params[:start_date], end_date: params[:end_date]).call
|
||||
|
|
@ -10,8 +13,6 @@ class Api::V1::PhotosController < ApiController
|
|||
end
|
||||
|
||||
def thumbnail
|
||||
return unauthorized_integration unless integration_configured?
|
||||
|
||||
response = fetch_cached_thumbnail(params[:source])
|
||||
handle_thumbnail_response(response)
|
||||
end
|
||||
|
|
@ -33,8 +34,15 @@ class Api::V1::PhotosController < ApiController
|
|||
end
|
||||
|
||||
def integration_configured?
|
||||
(params[:source] == 'immich' && current_api_user.immich_integration_configured?) ||
|
||||
(params[:source] == 'photoprism' && current_api_user.photoprism_integration_configured?)
|
||||
current_api_user.immich_integration_configured? || current_api_user.photoprism_integration_configured?
|
||||
end
|
||||
|
||||
def check_integration_configured
|
||||
unauthorized_integration unless integration_configured?
|
||||
end
|
||||
|
||||
def check_source
|
||||
unauthorized_integration unless params[:source] == 'immich' || params[:source] == 'photoprism'
|
||||
end
|
||||
|
||||
def unauthorized_integration
|
||||
|
|
|
|||
|
|
@ -23,7 +23,7 @@ FactoryBot.define do
|
|||
admin { true }
|
||||
end
|
||||
|
||||
trait :with_immich_credentials do
|
||||
trait :with_immich_integration do
|
||||
settings do
|
||||
{
|
||||
immich_url: 'https://immich.example.com',
|
||||
|
|
@ -31,5 +31,14 @@ FactoryBot.define do
|
|||
}
|
||||
end
|
||||
end
|
||||
|
||||
trait :with_photoprism_integration do
|
||||
settings do
|
||||
{
|
||||
photoprism_url: 'https://photoprism.example.com',
|
||||
photoprism_api_key: '1234567890'
|
||||
}
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
|||
|
|
@ -4,50 +4,68 @@ require 'rails_helper'
|
|||
|
||||
RSpec.describe 'Api::V1::Photos', type: :request do
|
||||
describe 'GET /index' do
|
||||
let(:user) { create(:user) }
|
||||
context 'when the integration is configured' do
|
||||
let(:user) { create(:user, :with_photoprism_integration) }
|
||||
|
||||
let(:photo_data) do
|
||||
[
|
||||
{
|
||||
'id' => 1,
|
||||
'latitude' => 35.6762,
|
||||
'longitude' => 139.6503,
|
||||
'localDateTime' => '2024-01-01T00:00:00.000Z',
|
||||
'originalFileName' => 'photo1.jpg',
|
||||
'city' => 'Tokyo',
|
||||
'state' => 'Tokyo',
|
||||
'country' => 'Japan',
|
||||
'type' => 'photo',
|
||||
'source' => 'photoprism'
|
||||
},
|
||||
{
|
||||
'id' => 2,
|
||||
'latitude' => 40.7128,
|
||||
'longitude' => -74.0060,
|
||||
'localDateTime' => '2024-01-02T00:00:00.000Z',
|
||||
'originalFileName' => 'photo2.jpg',
|
||||
'city' => 'New York',
|
||||
'state' => 'New York',
|
||||
'country' => 'USA',
|
||||
'type' => 'photo',
|
||||
'source' => 'immich'
|
||||
}
|
||||
]
|
||||
let(:photo_data) do
|
||||
[
|
||||
{
|
||||
'id' => 1,
|
||||
'latitude' => 35.6762,
|
||||
'longitude' => 139.6503,
|
||||
'localDateTime' => '2024-01-01T00:00:00.000Z',
|
||||
'originalFileName' => 'photo1.jpg',
|
||||
'city' => 'Tokyo',
|
||||
'state' => 'Tokyo',
|
||||
'country' => 'Japan',
|
||||
'type' => 'photo',
|
||||
'source' => 'photoprism'
|
||||
},
|
||||
{
|
||||
'id' => 2,
|
||||
'latitude' => 40.7128,
|
||||
'longitude' => -74.0060,
|
||||
'localDateTime' => '2024-01-02T00:00:00.000Z',
|
||||
'originalFileName' => 'photo2.jpg',
|
||||
'city' => 'New York',
|
||||
'state' => 'New York',
|
||||
'country' => 'USA',
|
||||
'type' => 'photo',
|
||||
'source' => 'immich'
|
||||
}
|
||||
]
|
||||
end
|
||||
|
||||
context 'when the request is successful' do
|
||||
before do
|
||||
allow_any_instance_of(Photos::Request).to receive(:call).and_return(photo_data)
|
||||
|
||||
get '/api/v1/photos', params: { api_key: user.api_key }
|
||||
end
|
||||
|
||||
it 'returns http success' do
|
||||
expect(response).to have_http_status(:success)
|
||||
end
|
||||
|
||||
it 'returns photos data as JSON' do
|
||||
expect(JSON.parse(response.body)).to eq(photo_data)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context 'when the request is successful' do
|
||||
context 'when the integration is not configured' do
|
||||
let(:user) { create(:user) }
|
||||
|
||||
before do
|
||||
allow_any_instance_of(Photos::Request).to receive(:call).and_return(photo_data)
|
||||
|
||||
get '/api/v1/photos', params: { api_key: user.api_key }
|
||||
get '/api/v1/photos', params: { api_key: user.api_key, source: 'immich' }
|
||||
end
|
||||
|
||||
it 'returns http success' do
|
||||
expect(response).to have_http_status(:success)
|
||||
it 'returns http unauthorized' do
|
||||
expect(response).to have_http_status(:unauthorized)
|
||||
end
|
||||
|
||||
it 'returns photos data as JSON' do
|
||||
expect(JSON.parse(response.body)).to eq(photo_data)
|
||||
it 'returns an error message' do
|
||||
expect(JSON.parse(response.body)).to eq({ 'error' => 'Immich integration not configured' })
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
|
|||
|
|
@ -3,7 +3,7 @@
|
|||
require 'swagger_helper'
|
||||
|
||||
RSpec.describe 'Api::V1::PhotosController', type: :request do
|
||||
let(:user) { create(:user, :with_immich_credentials) }
|
||||
let(:user) { create(:user, :with_immich_integration) }
|
||||
let(:api_key) { user.api_key }
|
||||
let(:start_date) { '2024-01-01' }
|
||||
let(:end_date) { '2024-01-02' }
|
||||
|
|
|
|||
Loading…
Reference in a new issue