diff options
| author | Dawid Rycerz <dawid@rycerz.xyz> | 2025-03-23 17:11:39 +0100 |
|---|---|---|
| committer | Dawid Rycerz <dawid@rycerz.xyz> | 2025-04-05 21:16:51 +0200 |
| commit | 0ab2e5ba2b0631b28b5b1405559237b3913c878f (patch) | |
| tree | 791cea788b0a62bc483d0041fbd0c655d2ad49e8 /test/silmataivas_web/controllers/location_json_test.exs | |
feat: initialize Phoenix application for weather alerts
This commit sets up the initial Silmataivas project structure, including: Phoenix web framework configuration, database models for users and locations, weather polling service, notification system, Docker and deployment configurations, CI/CD pipeline setup
Diffstat (limited to 'test/silmataivas_web/controllers/location_json_test.exs')
| -rw-r--r-- | test/silmataivas_web/controllers/location_json_test.exs | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/test/silmataivas_web/controllers/location_json_test.exs b/test/silmataivas_web/controllers/location_json_test.exs new file mode 100644 index 0000000..f74b943 --- /dev/null +++ b/test/silmataivas_web/controllers/location_json_test.exs @@ -0,0 +1,48 @@ +defmodule SilmataivasWeb.LocationJSONTest do + use SilmataivasWeb.ConnCase, async: true + + import Silmataivas.LocationsFixtures + import Silmataivas.UsersFixtures + + alias SilmataivasWeb.LocationJSON + + describe "location_json" do + test "index/1 renders a list of locations" do + user = user_fixture() + location1 = location_fixture(%{user_id: user.id, latitude: 10.0, longitude: 20.0}) + location2 = location_fixture(%{user_id: user.id, latitude: 30.0, longitude: 40.0}) + + json = LocationJSON.index(%{locations: [location1, location2]}) + + assert json == %{ + data: [ + %{ + id: location1.id, + latitude: location1.latitude, + longitude: location1.longitude + }, + %{ + id: location2.id, + latitude: location2.latitude, + longitude: location2.longitude + } + ] + } + end + + test "show/1 renders a single location with data wrapper" do + user = user_fixture() + location = location_fixture(%{user_id: user.id}) + + json = LocationJSON.show(%{location: location}) + + assert json == %{ + data: %{ + id: location.id, + latitude: location.latitude, + longitude: location.longitude + } + } + end + end +end |
