diff options
author | Steven Blowers <shdblowers@gmail.com> | 2016-11-22 19:39:45 +0000 |
---|---|---|
committer | Steven Blowers <shdblowers@gmail.com> | 2016-11-22 19:39:45 +0000 |
commit | 1bfac92a35eb752c4ed6cc4a510d11786d1a01c8 (patch) | |
tree | bac33bb3466887ff60102e40e39f1f3f03d3fa30 /test | |
parent | b8e4872ab277e8e889d852a2bc6aa19ec7972b9d (diff) | |
download | zendex-1bfac92a35eb752c4ed6cc4a510d11786d1a01c8.tar.gz zendex-1bfac92a35eb752c4ed6cc4a510d11786d1a01c8.tar.xz |
finishing off using meck. had to delete doctests, as they don't work with meck
Diffstat (limited to 'test')
-rw-r--r-- | test/zendex/search_test.exs | 2 | ||||
-rw-r--r-- | test/zendex/user_test.exs | 49 |
2 files changed, 47 insertions, 4 deletions
diff --git a/test/zendex/search_test.exs b/test/zendex/search_test.exs index d1e2851..a5b6405 100644 --- a/test/zendex/search_test.exs +++ b/test/zendex/search_test.exs @@ -1,5 +1,5 @@ defmodule Zendex.SearchTest do - use ExUnit.Case, async: true + use ExUnit.Case, async: false setup do %{conn: Zendex.Connection.setup("http://test.zendesk.com", "User", "Passw")} diff --git a/test/zendex/user_test.exs b/test/zendex/user_test.exs index f61ef13..5d07c73 100644 --- a/test/zendex/user_test.exs +++ b/test/zendex/user_test.exs @@ -1,14 +1,26 @@ defmodule Zendex.UserTest do - use ExUnit.Case, async: true + use ExUnit.Case, async: false - doctest Zendex.User + @base_url "http://test.zendesk.com" setup do - [conn: Zendex.Connection.setup("http://test.zendesk.com", "User1", "pass")] + [conn: Zendex.Connection.setup(@base_url, "User1", "pass")] + end + + setup_all do + :meck.new(HTTPoison) + on_exit fn -> :meck.unload end + :ok end test "list users", context do expected = "users" + + stub = fn("#{@base_url}/api/v2/users.json", _) -> + %HTTPoison.Response{body: Poison.encode!(expected)} + end + :meck.expect(HTTPoison, :get!, stub) + actual = Zendex.User.list(context[:conn]) assert expected == actual @@ -49,6 +61,12 @@ defmodule Zendex.UserTest do "user_fields" => %{"customer_complaint" => nil}, "tags" => [], "updated_at" => "2016-10-28T21:08:23Z"}} + + stub = fn("#{@base_url}/api/v2/users/295204.json", _) -> + %HTTPoison.Response{body: Poison.encode!(expected)} + end + :meck.expect(HTTPoison, :get!, stub) + actual = Zendex.User.show(context[:conn], 295204) assert expected == actual @@ -57,6 +75,12 @@ defmodule Zendex.UserTest do test "showing many users", context do expected = %{"users" => [%{"id" => 6, "name" => "Kiki Segal"}, %{"id" => 67, "name" => "Sarpedon Baumgartner"}]} + + stub = fn("#{@base_url}/api/v2/users/show_many.json?ids=6,67", _) -> + %HTTPoison.Response{body: Poison.encode!(expected)} + end + :meck.expect(HTTPoison, :get!, stub) + actual = Zendex.User.show_many(context[:conn], [6,67]) assert expected == actual @@ -73,6 +97,12 @@ defmodule Zendex.UserTest do "topic_comments" => 116, "topics" => 5, "votes" => 2001}} + + stub = fn("#{@base_url}/api/v2/users/649267/related.json", _) -> + %HTTPoison.Response{body: Poison.encode!(expected)} + end + :meck.expect(HTTPoison, :get!, stub) + actual = Zendex.User.related_information(context[:conn], 649267) assert expected == actual @@ -80,6 +110,13 @@ defmodule Zendex.UserTest do test "creating a user", context do expected = %{"user" => %{"id" => 1234, "name" => "Roger", "email" => "roger@dodger.com"}} + + stub = fn("#{@base_url}/api/v2/users.json", _, _) -> + %HTTPoison.Response{body: Poison.encode!(expected)} + end + :meck.expect(HTTPoison, :post!, stub) + + actual = Zendex.User.create(context[:conn], %{user: %{name: "Roger", email: "roger@dodger.com"}}) assert expected == actual @@ -120,6 +157,12 @@ defmodule Zendex.UserTest do "user_fields" => %{"customer_complaint" => nil}, "tags" => [], "updated_at" => "2016-10-28T21:08:23Z"}} + + stub = fn("#{@base_url}/api/v2/users/49043.json", _) -> + %HTTPoison.Response{body: Poison.encode!(expected)} + end + :meck.expect(HTTPoison, :delete!, stub) + actual = Zendex.User.delete(context[:conn], 49043) assert expected == actual |