dawarich/spec/factories/places.rb
Evgenii Burmakin b1393ee674
0.36.0 (#1952)
* Implement OmniAuth GitHub authentication

* Fix omniauth GitHub scope to include user email access

* Remove margin-bottom

* Implement Google OAuth2 authentication

* Implement OIDC authentication for Dawarich using omniauth_openid_connect gem.

* Add patreon account linking and patron checking service

* Update docker-compose.yml to use boolean values instead of strings

* Add support for KML files

* Add tests

* Update changelog

* Remove patreon OAuth integration

* Move omniauthable to a concern

* Update an icon in integrations

* Update changelog

* Update app version

* Fix family location sharing toggle

* Move family location sharing to its own controller

* Update changelog

* Implement basic tagging functionality for places, allowing users to categorize and label places with custom tags.

* Add places management API and tags feature

* Add some changes related to places management feature

* Fix some tests

* Fix sometests

* Add places layer

* Update places layer to use Leaflet.Control.Layers.Tree for hierarchical layer control

* Rework tag form

* Add hashtag

* Add privacy zones to tags

* Add notes to places and manage place tags

* Update changelog

* Update e2e tests

* Extract tag serializer to its own file

* Fix some tests

* Fix tags request specs

* Fix some tests

* Fix rest of the tests

* Revert some changes

* Add missing specs

* Revert changes in place export/import code

* Fix some specs

* Fix PlaceFinder to only consider global places when finding existing places

* Fix few more specs

* Fix visits creator spec

* Fix last tests

* Update place creating modal

* Add home location based on "Home" tagged place

* Save enabled tag layers

* Some fixes

* Fix bug where enabling place tag layers would trigger saving enabled layers, overwriting with incomplete data

* Update migration to use disable_ddl_transaction! and add up/down methods

* Fix tag layers restoration and filtering logic

* Update OIDC auto-registration and email/password registration settings

* Fix potential xss
2025-11-24 19:45:09 +01:00

73 lines
2.1 KiB
Ruby

# frozen_string_literal: true
FactoryBot.define do
factory :place do
sequence(:name) { |n| "Place #{n}" }
latitude { 54.2905245 }
longitude { 13.0948638 }
# lonlat is auto-generated by before_validation callback in Place model
# association :user
trait :with_geodata do
geodata do
{
"geometry": {
"coordinates": [
13.0948638,
54.2905245
],
"type": 'Point'
},
"type": 'Feature',
"properties": {
"osm_id": 5_762_449_774,
"country": 'Germany',
"city": 'Stralsund',
"countrycode": 'DE',
"postcode": '18439',
"locality": 'Frankensiedlung',
"county": 'Vorpommern-Rügen',
"type": 'house',
"osm_type": 'N',
"osm_key": 'amenity',
"housenumber": '84-85',
"street": 'Greifswalder Chaussee',
"district": 'Franken',
"osm_value": 'restaurant',
"name": 'Braugasthaus Zum Alten Fritz',
"state": 'Mecklenburg-Vorpommern'
}
}
end
end
# Trait for setting coordinates from lonlat geometry
# This is forward-compatible for when latitude/longitude are deprecated
trait :from_lonlat do
transient do
lonlat_wkt { nil }
end
after(:build) do |place, evaluator|
if evaluator.lonlat_wkt
# Parse WKT to extract coordinates
# Format: "POINT(longitude latitude)" or "SRID=4326;POINT(longitude latitude)"
coords = evaluator.lonlat_wkt.match(/POINT\(([^ ]+) ([^ ]+)\)/)
if coords
place.longitude = coords[1].to_f
place.latitude = coords[2].to_f
end
end
end
end
# Special trait for testing with nil lonlat
trait :without_lonlat do
# Skip validation to create an invalid record for testing
to_create { |instance| instance.save(validate: false) }
after(:build) do |place|
place.lonlat = nil
end
end
end
end