From a76418c5de3bcb1c73c01ab804af20bf1562246d Mon Sep 17 00:00:00 2001 From: SimonLab Date: Mon, 4 Feb 2019 12:26:34 +0000 Subject: [PATCH 1/8] keep inserted_at value to the original value, #30 --- lib/alog.ex | 21 +++++++++++++++++++++ test/all_test.exs | 3 ++- 2 files changed, 23 insertions(+), 1 deletion(-) diff --git a/lib/alog.ex b/lib/alog.ex index b730d18..b3c4f2f 100644 --- a/lib/alog.ex +++ b/lib/alog.ex @@ -248,6 +248,19 @@ defmodule Alog do User.all() """ def all do + # get the oldest items + sub = + from(m in __MODULE__, + distinct: m.entry_id, + order_by: [asc: :inserted_at], + select: m + ) + + query = from(m in subquery(sub), where: not m.deleted, select: m) + + oldest_items = @repo.all(query) + + # get the most recent inserted items, ie desc: :inserted_at sub = from(m in __MODULE__, distinct: m.entry_id, @@ -258,6 +271,14 @@ defmodule Alog do query = from(m in subquery(sub), where: not m.deleted, select: m) @repo.all(query) + |> Enum.map(fn(newest_item) -> + oldest_item = Enum.find(oldest_items, &(&1.entry_id == newest_item.entry_id)) + if oldest_item do + %{newest_item | inserted_at: oldest_item.inserted_at} + else + newest_item + end + end) end @doc """ diff --git a/test/all_test.exs b/test/all_test.exs index 6b89cdf..791e3bb 100644 --- a/test/all_test.exs +++ b/test/all_test.exs @@ -14,9 +14,10 @@ defmodule AlogTest.AllTest do test "does not include old items" do {:ok, user} = %User{} |> User.changeset(Helpers.user_1_params()) |> User.insert() {:ok, _} = %User{} |> User.changeset(Helpers.user_2_params()) |> User.insert() - {:ok, _} = user |> User.changeset(%{postcode: "W2 3EC"}) |> User.update() + {:ok, user_updated} = user |> User.changeset(%{postcode: "W2 3EC"}) |> User.update() assert length(User.all()) == 2 + assert user.inserted_at == user_updated.inserted_at end end end From 6bc2aca19412aeb4de3a7603cd9631ad747b83ed Mon Sep 17 00:00:00 2001 From: SimonLab Date: Mon, 4 Feb 2019 12:36:30 +0000 Subject: [PATCH 2/8] add travis.yml config --- .travis.yml | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 .travis.yml diff --git a/.travis.yml b/.travis.yml new file mode 100644 index 0000000..6c340f4 --- /dev/null +++ b/.travis.yml @@ -0,0 +1,20 @@ +language: elixir +elixir: + - 1.7 +otp_release: + - 20.2.4 +env: + - MIX_ENV=test +cache: + directories: + - _build + - deps +services: + - postgresql +env: + global: + - MIX_ENV=test +before_script: + - mix do ecto.create +script: + - mix test From 400fef02ec339029ca09623d9ca39d76b49b7336 Mon Sep 17 00:00:00 2001 From: SimonLab Date: Mon, 4 Feb 2019 12:46:37 +0000 Subject: [PATCH 3/8] migrate data before running test on travis, https://github.com/dwyl/alog/pull/36/commits/f705607508e4818fe6d3b7353cc036cacd74c932 --- .travis.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.travis.yml b/.travis.yml index 6c340f4..ddcb594 100644 --- a/.travis.yml +++ b/.travis.yml @@ -15,6 +15,6 @@ env: global: - MIX_ENV=test before_script: - - mix do ecto.create + - mix do ecto.create, ecto.migrate script: - mix test From 530f7e04da93d233b9fa5573da6f5aab61fa9278 Mon Sep 17 00:00:00 2001 From: SimonLab Date: Mon, 4 Feb 2019 12:57:39 +0000 Subject: [PATCH 4/8] update tests, #30 --- test/all_test.exs | 12 ++++++++++-- test/get_by_test.exs | 4 ++-- test/support/helpers.ex | 2 ++ 3 files changed, 14 insertions(+), 4 deletions(-) diff --git a/test/all_test.exs b/test/all_test.exs index 791e3bb..64b834a 100644 --- a/test/all_test.exs +++ b/test/all_test.exs @@ -14,10 +14,18 @@ defmodule AlogTest.AllTest do test "does not include old items" do {:ok, user} = %User{} |> User.changeset(Helpers.user_1_params()) |> User.insert() {:ok, _} = %User{} |> User.changeset(Helpers.user_2_params()) |> User.insert() - {:ok, user_updated} = user |> User.changeset(%{postcode: "W2 3EC"}) |> User.update() + {:ok, _} = user |> User.changeset(%{postcode: "W2 3EC"}) |> User.update() assert length(User.all()) == 2 - assert user.inserted_at == user_updated.inserted_at + end + + test "all return inserted_at original value" do + {:ok, user} = %User{} |> User.changeset(Helpers.user_3_params()) |> User.insert() + {:ok, user_updated} = user |> User.changeset(%{postcode: "W2 3EC"}) |> User.update() + + [user_all] = User.all() + assert user_all.inserted_at == user.inserted_at + assert user_all.postcode == user_updated.postcode end end end diff --git a/test/get_by_test.exs b/test/get_by_test.exs index 7bf938a..34fb9ee 100644 --- a/test/get_by_test.exs +++ b/test/get_by_test.exs @@ -38,7 +38,7 @@ defmodule AlogTest.GetByTest do test "does not retrieve outdated results" do {:ok, user} = %User{} |> User.changeset(Helpers.user_1_params()) |> User.insert() - {:ok, updated_user} = user |> User.changeset(%{postcode: "EC3 RST"}) |> User.update() + {:ok, _updated_user} = user |> User.changeset(%{postcode: "EC3 RST"}) |> User.update() assert User.get_by(postcode: "E2 0SY") == nil end @@ -58,7 +58,7 @@ defmodule AlogTest.GetByTest do |> User.changeset(Map.put(Helpers.user_2_params(), :postcode, "E2 0SY")) |> User.insert() - {:ok, updated_user_2} = user_2 |> User.changeset(%{postcode: "EC3 RST"}) |> User.update() + {:ok, _} = user_2 |> User.changeset(%{postcode: "EC3 RST"}) |> User.update() assert User.get_by(postcode: "E2 0SY") == user end diff --git a/test/support/helpers.ex b/test/support/helpers.ex index 2f6e5b5..2374956 100644 --- a/test/support/helpers.ex +++ b/test/support/helpers.ex @@ -6,6 +6,8 @@ defmodule Alog.TestApp.Helpers do def user_2_params(), do: %{name: "Loki", username: "mschfmkr", postcode: "E1 6DR"} + def user_3_params(), do: %{name: "Bob", username: "bobuser", postcode: "E1 7DR"} + def seed_data() do {:ok, item_type} = %ItemType{} |> ItemType.changeset(%{type: "Weapon"}) |> ItemType.insert() From 7d46a3a66372c808a526122a29445baa268a09b2 Mon Sep 17 00:00:00 2001 From: SimonLab Date: Tue, 5 Feb 2019 10:22:14 +0000 Subject: [PATCH 5/8] keeps inserted_at value on update, #30 --- lib/alog.ex | 22 ---------------------- mix.exs | 2 +- 2 files changed, 1 insertion(+), 23 deletions(-) diff --git a/lib/alog.ex b/lib/alog.ex index b3c4f2f..8a2a0a9 100644 --- a/lib/alog.ex +++ b/lib/alog.ex @@ -209,7 +209,6 @@ defmodule Alog do |> Map.get(:data) |> @repo.preload(__MODULE__.__schema__(:associations)) |> Map.put(:id, nil) - |> Map.put(:inserted_at, nil) |> Map.put(:updated_at, nil) changeset @@ -248,19 +247,6 @@ defmodule Alog do User.all() """ def all do - # get the oldest items - sub = - from(m in __MODULE__, - distinct: m.entry_id, - order_by: [asc: :inserted_at], - select: m - ) - - query = from(m in subquery(sub), where: not m.deleted, select: m) - - oldest_items = @repo.all(query) - - # get the most recent inserted items, ie desc: :inserted_at sub = from(m in __MODULE__, distinct: m.entry_id, @@ -271,14 +257,6 @@ defmodule Alog do query = from(m in subquery(sub), where: not m.deleted, select: m) @repo.all(query) - |> Enum.map(fn(newest_item) -> - oldest_item = Enum.find(oldest_items, &(&1.entry_id == newest_item.entry_id)) - if oldest_item do - %{newest_item | inserted_at: oldest_item.inserted_at} - else - newest_item - end - end) end @doc """ diff --git a/mix.exs b/mix.exs index b7e96a5..06d677b 100644 --- a/mix.exs +++ b/mix.exs @@ -4,7 +4,7 @@ defmodule Alog.MixProject do def project do [ app: :alog, - version: "0.4.2", + version: "0.4.3", elixir: "~> 1.7", elixirc_paths: elixirc_paths(Mix.env()), start_permanent: Mix.env() == :prod, From 34c76da6fea34338d4d785039eed1a4a4bc92739 Mon Sep 17 00:00:00 2001 From: SimonLab Date: Tue, 5 Feb 2019 10:43:33 +0000 Subject: [PATCH 6/8] sort on updated_at value, #30 --- lib/alog.ex | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/lib/alog.ex b/lib/alog.ex index 8a2a0a9..c967446 100644 --- a/lib/alog.ex +++ b/lib/alog.ex @@ -129,7 +129,7 @@ defmodule Alog do from( m in __MODULE__, where: m.entry_id == ^entry_id, - order_by: [desc: :inserted_at], + order_by: [desc: :updated_at], limit: 1, select: m ) @@ -179,7 +179,7 @@ defmodule Alog do end end) end).() - |> order_by([m], desc: m.inserted_at) + |> order_by([m], desc: m.updated_at) |> distinct([m], m.entry_id) |> select([m], m) @@ -250,7 +250,7 @@ defmodule Alog do sub = from(m in __MODULE__, distinct: m.entry_id, - order_by: [desc: :inserted_at], + order_by: [desc: :updated_at], select: m ) @@ -345,7 +345,7 @@ defmodule Alog do sub = from(mod in Map.get(module.__schema__(:association, assoc), :queryable), distinct: mod.entry_id, - order_by: [desc: :inserted_at], + order_by: [desc: :updated_at], select: mod ) From e5b93539048a63dd736533b4edc9ef1ed7c5e621 Mon Sep 17 00:00:00 2001 From: Simon Date: Tue, 5 Feb 2019 13:17:37 +0000 Subject: [PATCH 7/8] Update mix.exs bump version to 0.5.0 --- mix.exs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/mix.exs b/mix.exs index 06d677b..a6e7b9e 100644 --- a/mix.exs +++ b/mix.exs @@ -4,7 +4,7 @@ defmodule Alog.MixProject do def project do [ app: :alog, - version: "0.4.3", + version: "0.5.0", elixir: "~> 1.7", elixirc_paths: elixirc_paths(Mix.env()), start_permanent: Mix.env() == :prod, From c2b495ed17e20720cdf46d4c1c05452710c8811e Mon Sep 17 00:00:00 2001 From: Simon Date: Tue, 5 Feb 2019 14:10:54 +0000 Subject: [PATCH 8/8] Update .travis.yml remove duplicate env value in travis.yml file --- .travis.yml | 2 -- 1 file changed, 2 deletions(-) diff --git a/.travis.yml b/.travis.yml index ddcb594..64aef49 100644 --- a/.travis.yml +++ b/.travis.yml @@ -3,8 +3,6 @@ elixir: - 1.7 otp_release: - 20.2.4 -env: - - MIX_ENV=test cache: directories: - _build