Skip to content

Commit

Permalink
Add tests for the repo and migration-dir options in schema generator
Browse files Browse the repository at this point in the history
The `repo` and `migration-dir` options change the location of the
migrations directory, either to the specified directory or one that
matches the repo name (underscored).

The default is explicitly set to "repo" if neither option is set, to
ensure backwards compatability even if the repo has a different name
than the typical `MyApp.Repo`.
  • Loading branch information
Gazler committed Oct 4, 2023
1 parent ce07beb commit 661cf51
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 12 deletions.
32 changes: 20 additions & 12 deletions lib/mix/tasks/phx.gen.schema.ex
Original file line number Diff line number Diff line change
Expand Up @@ -89,14 +89,14 @@ defmodule Mix.Tasks.Phx.Gen.Schema do
## repo
Generated migration can use `repo` to set the migration repository
folder with option `--repo`.
folder with option `--repo`:
$ mix phx.gen.schema Blog.Post posts --repo MyApp.Repo.Auth
## migration_dir
Generated migrations can be added to a specific `migration-dir` which sets the
migration folder path
Generated migrations can be added to a specific `--migration-dir` which sets
the migration folder path:
$ mix phx.gen.schema Blog.Post posts --migration-dir /path/to/directory
Expand Down Expand Up @@ -145,8 +145,8 @@ defmodule Mix.Tasks.Phx.Gen.Schema do

alias Mix.Phoenix.Schema

@switches [migration: :boolean, binary_id: :boolean, table: :string,
web: :string, context_app: :string, prefix: :string, repo: :string, migration_dir: :string]
@switches [migration: :boolean, binary_id: :boolean, table: :string, web: :string,
context_app: :string, prefix: :string, repo: :string, migration_dir: :string]

@doc false
def run(args) do
Expand Down Expand Up @@ -178,13 +178,10 @@ defmodule Mix.Tasks.Phx.Gen.Schema do
opts =
parent_opts
|> Keyword.merge(schema_opts)
|> Keyword.put(:migration_dir, schema_opts[:migration_dir])
|> put_context_app(schema_opts[:context_app])
|> maybe_update_repo_module
|> maybe_update_repo_module()

schema = Schema.new(schema_name, plural, attrs, opts)

schema
Schema.new(schema_name, plural, attrs, opts)
end

defp maybe_update_repo_module(opts) do
Expand All @@ -211,8 +208,19 @@ defmodule Mix.Tasks.Phx.Gen.Schema do
Mix.Phoenix.copy_from(paths, "priv/templates/phx.gen.schema", binding, files)

if schema.migration? do
repo_name = repo |> Module.split |> List.last |> Macro.underscore
migration_dir = opts[:migration_dir] || Mix.Phoenix.context_app_path(ctx_app, "priv/#{repo_name}/migrations/")
migration_dir =
case Map.new(opts) do
%{migration_dir: migration_dir} ->
migration_dir

%{repo: _} ->
repo_name = repo |> Module.split() |> List.last() |> Macro.underscore()
Mix.Phoenix.context_app_path(ctx_app, "priv/#{repo_name}/migrations/")

_ ->
Mix.Phoenix.context_app_path(ctx_app, "priv/repo/migrations/")
end

migration_path = Path.join(migration_dir, "#{timestamp()}_create_#{schema.table}.exs")

Mix.Phoenix.copy_from paths, "priv/templates/phx.gen.schema", binding, [
Expand Down
34 changes: 34 additions & 0 deletions test/mix/tasks/phx.gen.schema_test.exs
Original file line number Diff line number Diff line change
Expand Up @@ -113,6 +113,40 @@ defmodule Mix.Tasks.Phx.Gen.SchemaTest do
end
end

test "allows a custom repo", config do
in_tmp_project config.test, fn ->
Gen.Schema.run(~w(Blog.Post blog_posts title:string --repo MyApp.CustomRepo))

assert [migration] = Path.wildcard("priv/custom_repo/migrations/*_create_blog_posts.exs")
assert_file migration, fn file ->
assert file =~ "defmodule MyApp.CustomRepo.Migrations.CreateBlogPosts do"
end
end
end

test "allows a custom migration dir", config do
in_tmp_project config.test, fn ->
Gen.Schema.run(~w(Blog.Post blog_posts title:string --migration-dir priv/custom_dir))

assert [migration] = Path.wildcard("priv/custom_dir/*_create_blog_posts.exs")
assert_file migration, fn file ->
assert file =~ "defmodule Phoenix.Repo.Migrations.CreateBlogPosts do"
end
end
end

test "custom migration_dir takes precedence over custom repo name", config do
in_tmp_project config.test, fn ->
Gen.Schema.run(~w(Blog.Post blog_posts title:string \
--repo MyApp.CustomRepo --migration-dir priv/custom_dir))

assert [migration] = Path.wildcard("priv/custom_dir/*_create_blog_posts.exs")
assert_file migration, fn file ->
assert file =~ "defmodule MyApp.CustomRepo.Migrations.CreateBlogPosts do"
end
end
end

test "does not add maps to the required list", config do
in_tmp_project config.test, fn ->
Gen.Schema.run(~w(Blog.Post blog_posts title:string tags:map published_at:naive_datetime))
Expand Down

0 comments on commit 661cf51

Please sign in to comment.