-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
119cd9c
commit fc494d0
Showing
3 changed files
with
108 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
defmodule WomenInTechVic.Content.Event do | ||
@moduledoc """ | ||
An scheduled event for the Women in Tech Vic meetup group. | ||
Can be either in-person or online | ||
""" | ||
|
||
use Ecto.Schema | ||
import Ecto.Changeset | ||
|
||
@type t :: %__MODULE__{ | ||
id: pos_integer() | nil, | ||
title: String.t(), | ||
scheduled_at: DateTime.t(), | ||
online: boolean(), | ||
address: String.t(), | ||
description: String.t(), | ||
updated_at: DateTime.t() | nil, | ||
inserted_at: DateTime.t() | nil | ||
} | ||
|
||
@required [:title, :scheduled_at, :online, :address, :description] | ||
@enforce_keys @required | ||
|
||
schema "events" do | ||
field :title, :string | ||
field :scheduled_at, :utc_datetime_usec | ||
field :online, :boolean | ||
field :address, :string | ||
field :description, :string | ||
|
||
timestamps(type: :utc_datetime_usec) | ||
end | ||
|
||
@doc false | ||
@spec create_changeset(map) :: Ecto.Changeset.t() | ||
def create_changeset(attrs) do | ||
@enforce_keys | ||
|> Map.new(&{&1, nil}) | ||
|> then(&struct!(__MODULE__, &1)) | ||
|> changeset(attrs) | ||
end | ||
|
||
@doc false | ||
@spec changeset(t(), map()) :: Ecto.Changeset.t(t) | ||
def changeset(%__MODULE__{} = event, params \\ %{}) do | ||
event | ||
|> cast(params, @required) | ||
|> validate_required(@required) | ||
|> maybe_validate_online_address() | ||
|> unique_constraint(:scheduled_at) | ||
end | ||
|
||
defp maybe_validate_online_address(%Ecto.Changeset{valid?: true} = changeset) do | ||
online = fetch_field!(changeset, :online) | ||
|
||
if online do | ||
validate_format( | ||
changeset, | ||
:address, | ||
~r|meet.google.com\/|, | ||
message: "Valid google meet link required for online meeting" | ||
) | ||
end | ||
end | ||
|
||
defp maybe_validate_online_address(changeset), do: changeset | ||
end |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
defmodule WomenInTechVic.Content.EventTest do | ||
use WomenInTechVic.DataCase, async: true | ||
|
||
alias WomenInTechVic.Content.Event | ||
|
||
describe "changeset/2" do | ||
test "validates required" do | ||
assert %Ecto.Changeset{errors: errors} = Event.create_changeset(%{}) | ||
|
||
assert [ | ||
title: {"can't be blank", [validation: :required]}, | ||
scheduled_at: {"can't be blank", [validation: :required]}, | ||
online: {"can't be blank", [validation: :required]}, | ||
address: {"can't be blank", [validation: :required]}, | ||
description: {"can't be blank", [validation: :required]} | ||
] = errors | ||
end | ||
|
||
test "validates google meet link for online meetings" do | ||
params = %{ | ||
title: "Online meeting", | ||
description: "Another online meeting", | ||
online: true, | ||
address: "meet.google.com/", | ||
scheduled_at: DateTime.utc_now() | ||
} | ||
|
||
assert %Ecto.Changeset{valid?: true} = Event.create_changeset(params) | ||
|
||
faulty_params = Map.put(params, :address, "not a valid google meet address") | ||
assert %Ecto.Changeset{errors: errors} = Event.create_changeset(faulty_params) | ||
|
||
assert [ | ||
address: | ||
{"Valid google meet link required for online meeting", [validation: :format]} | ||
] = errors | ||
end | ||
end | ||
end |