Files
growstuff/spec/models/photo_spec.rb
Daniel O'Connor ee45b518ce Rubocop fixes (Stacked PR) (#3454)
* Fix todo

* Rubcop

* Rubocop

* Rubocop

* Rename harvests_routing_spec.rb to harvests_controller_routing_spec.rb

Making codeclimate happier

* Rename for CodeFactor: updates_routing_spec.rb to posts_controller_updates_routing_spec.rb

For codefactor

* Rename for CodeFactor: follows_routing_spec.rb to follows_controller_routing_spec.rb

* Rename for CodeFactor: forums_routing_spec.rb to forums_controller_routing_spec.rb

* Rename spec/routing/roles_routing_spec.rb to spec/routing/admin/roles_controller_routing_spec.rb

* Rename authentications_routing_spec.rb to authentications_controller_routing_spec.rb

* Rename for CodeFactor: plantings_routing_spec.rb to plantings_controller_routing_spec.rb

* Rename for CodeFactor: scientific_names_routing_spec.rb to scientific_names_controller_routing_spec.rb

* Rename for CodeFactor: seeds_routing_spec.rb to seeds_controller_routing_spec.rb

* Rename for CodeFactor: comments_routing_spec.rb to comments_controller_routing_spec.rb

* Rename for CodeFactor: garden_types_routing_spec.rb to garden_types_controller_routing_spec.rb

* Rename for CodeFactor: admin_routing_spec.rb to admin_controller_routing_spec.rb

* Rename for CodeFactor: gardens_routing_spec.rb to gardens_controller_routing_spec.rb

* Rename for CodeFactor: photos_routing_spec.rb to photos_controller_routing_spec.rb

* Rename for CodeFactor: plant_parts_routing_spec.rb to plant_parts_controller_routing_spec.rb

* Rename for CodeFactor: crops_routing_spec.rb to crops_controller_routing_spec.rb

* [CodeFactor] Apply fixes

* Rename

* Code factor bot

---------

Co-authored-by: Cesy <cesy.avon@gmail.com>
Co-authored-by: codefactor-io <support@codefactor.io>
2024-01-07 21:05:59 +10:30

273 lines
8.9 KiB
Ruby

# frozen_string_literal: true
require 'rails_helper'
describe Photo do
let(:photo) { FactoryBot.create(:photo, :reindex, owner: member) }
let(:member) { FactoryBot.create(:member) }
it_behaves_like "it is likeable"
describe 'add/delete functionality' do
let(:planting) { FactoryBot.create(:planting, owner: member) }
let(:seed) { FactoryBot.create(:seed, owner: member) }
let(:harvest) { FactoryBot.create(:harvest, owner: member) }
let(:post) { FactoryBot.create(:post, author: member) }
let(:garden) { FactoryBot.create(:garden, owner: member) }
context "adds photos" do
describe 'to a planting' do
before { planting.photos << photo }
it { expect(planting.photos.count).to eq 1 }
it { expect(planting.photos.first).to eq photo }
# there's only one photo, so that's the default
it { expect(planting.default_photo).to eq photo }
it { expect(planting.crop.default_photo).to eq photo }
describe 'with a second older photo' do
let(:old_photo) { FactoryBot.create(:photo, owner: member, created_at: 1.year.ago, date_taken: 2.years.ago) }
# Add an old photo
before { planting.photos << old_photo }
it { expect(planting.default_photo).to eq photo }
it { expect(planting.crop.default_photo).to eq photo }
describe 'and someone likes the old photo' do
before { FactoryBot.create(:like, likeable: old_photo) }
it { expect(planting.default_photo).to eq old_photo }
it { expect(planting.crop.default_photo).to eq old_photo }
end
end
end
describe 'to a harvest' do
let(:crop) { harvest.crop }
before { harvest.photos << photo }
it { expect(harvest.photos).to eq [photo] }
it { expect(harvest.photo_associations.count).to eq 1 }
# Check the relationship from crop
it { expect(crop.photo_associations.count).to eq 1 }
it { expect(crop.photos.count).to eq 1 }
it { expect(crop.photos).to eq [photo] }
# Check the relationship from the photo
it { expect(photo.photo_associations.count).to eq 1 }
it { expect(photo.photo_associations.map(&:crop)).to eq [crop] }
it { expect(photo.crops.count).to eq 1 }
it { expect(photo.crops).to eq [crop] }
end
it 'to a seed' do
seed.photos << photo
expect(seed.photos).to eq [photo]
expect(photo.crops).to eq [seed.crop]
end
it 'to a planting' do
planting.photos << photo
expect(planting.photos).to eq [photo]
expect(photo.crops).to eq [planting.crop]
end
it 'to a garden' do
garden.photos << photo
expect(garden.photos).to eq [photo]
end
it 'to a post' do
post.photos << photo
expect(post.photos).to eq [photo]
end
end
context "removing photos" do
it 'from a planting' do
planting.photos << photo
photo.destroy
expect(planting.photos.count).to eq 0
end
it 'from a harvest' do
harvest.photos << photo
photo.destroy
expect(harvest.photos.count).to eq 0
end
it 'from a garden' do
garden.photos << photo
photo.destroy
expect(garden.photos.count).to eq 0
end
it "automatically if unused" do
photo.destroy_if_unused
expect { photo.reload }.to raise_error ActiveRecord::RecordNotFound
end
it 'they are used by plantings but not harvests' do
harvest.photos << photo
planting.photos << photo
harvest.destroy # photo is now used by harvest but not planting
photo.destroy_if_unused
expect { photo.reload }.not_to raise_error
end
it 'they are used by harvests but not plantings' do
harvest.photos << photo
planting.photos << photo
planting.destroy # photo is now used by harvest but not planting
photo.destroy_if_unused
expect { photo.reload }.not_to raise_error
end
it 'they are used by gardens but not plantings' do
garden.photos << photo
planting.photos << photo
planting.destroy # photo is now used by garden but not planting
photo.destroy_if_unused
expect { photo.reload }.not_to raise_error
end
it 'they are no longer used by anything' do
planting.photos << photo
harvest.photos << photo
garden.photos << photo
expect(photo.plantings.count).to eq 1
expect(photo.harvests.count).to eq 1
expect(photo.gardens.count).to eq 1
planting.destroy # photo is still used by harvest and garden
photo.reload
expect(photo.plantings.count).to eq 0
expect(photo.harvests.count).to eq 1
harvest.destroy
garden.destroy # photo is now no longer used by anything
photo.reload
expect(photo.plantings.count).to eq 0
expect(photo.harvests.count).to eq 0
expect(photo.gardens.count).to eq 0
photo.destroy_if_unused
expect { photo.reload }.to raise_error ActiveRecord::RecordNotFound
end
it 'does not occur when a photo is still in use' do
planting.photos << photo
harvest.photos << photo
planting.destroy # photo is still used by the harvest
expect(photo).to be_an_instance_of described_class
end
end # removing photos
end # add/delete functionality
describe 'flickr_metadata' do
# Any further tests led to us MOCKING ALL THE THINGS
# which was epistemologically unsatisfactory.
# So we're just going to test that the method exists.
it 'exists' do
photo = described_class.new(owner_id: 1)
photo.should.respond_to? :flickr_metadata
end
end
it 'excludes deleted members' do
expect(described_class.joins(:owner).all).to include(photo)
member.destroy
expect(described_class.joins(:owner).all).not_to include(photo)
end
describe 'assocations' do
let(:harvest_crop) { FactoryBot.create(:crop, name: 'harvest_crop') }
let!(:harvest) { FactoryBot.create(:harvest, owner: member, crop: harvest_crop) }
let!(:harvest_photo) { FactoryBot.create(:photo, owner: member) }
let(:planting_crop) { FactoryBot.create(:crop, name: 'planting_crop') }
let!(:planting) { FactoryBot.create(:planting, owner: member, crop: planting_crop) }
let!(:planting_photo) { FactoryBot.create(:photo, owner: member) }
let(:seed_crop) { FactoryBot.create(:crop, name: 'seed_crop') }
let!(:seed) { FactoryBot.create(:seed, owner: member, crop: seed_crop) }
let!(:seed_photo) { FactoryBot.create(:photo, owner: member) }
before do
harvest.photos << harvest_photo
planting.photos << planting_photo
seed.photos << seed_photo
# harvest_photo.reload
# harvest.reload
# # harvest.reindex
# planting_photo.reload
# planting.reload
# # planting.reindex
# seed_photo.reload
# seed.reload
# seed.reindex
end
describe 'relationships' do
it { expect(seed_photo.crops).to eq [seed_crop] }
it { expect(seed_crop.photos).to eq [seed_photo] }
it { expect(harvest_photo.crops).to eq [harvest_crop] }
it { expect(harvest_crop.photos).to eq [harvest_photo] }
it { expect(planting_photo.crops).to eq [planting_crop] }
it { expect(planting_crop.photos).to eq [planting_photo] }
end
describe 'scopes' do
it { expect(described_class.by_model(Harvest)).to eq([harvest_photo]) }
it { expect(described_class.by_model(Planting)).to eq([planting_photo]) }
it { expect(described_class.by_model(Seed)).to eq([seed_photo]) }
it { expect(described_class.by_crop(harvest_crop)).to eq([harvest_photo]) }
it { expect(described_class.by_crop(planting_crop)).to eq([planting_photo]) }
it { expect(described_class.by_crop(seed_crop)).to eq([seed_photo]) }
end
end
describe 'Elastic search indexing', :search do
let!(:planting) { FactoryBot.create(:planting, :reindex, owner: photo.owner) }
let!(:crop) { FactoryBot.create(:crop, :reindex) }
before do
planting.photos << photo
described_class.reindex
described_class.searchkick_index.refresh
end
describe "finds all photos in search index" do
it "finds just one" do
expect(described_class.search.count).to eq 1
end
it "finds the matching photo" do
expect(described_class.search).to include photo
end
it "retrieves crops from ES" do
expect(described_class.search(load: false).first.crops).to eq [planting.crop.id]
end
end
it "finds photos by owner in search index" do
expect(described_class.search(where: { owner_id: planting.owner_id })).to include photo
end
it "finds photos by crop in search index" do
expect(described_class.search(where: { crops: planting.crop.id })).to include photo
end
end
end