analytics/test/plausible_web/controllers/api/external_controller_test.exs

364 lines
11 KiB
Elixir
Raw Normal View History

2019-09-02 14:29:19 +03:00
defmodule PlausibleWeb.Api.ExternalControllerTest do
use PlausibleWeb.ConnCase
use Plausible.Repo
defp get_event(domain) do
Plausible.Event.WriteBuffer.flush()
events = Plausible.Clickhouse.all(
from e in Plausible.ClickhouseEvent,
where: e.domain ==^domain,
order_by: [desc: e.timestamp],
limit: 1
)
List.first(events)
2019-12-03 12:42:17 +03:00
end
2019-09-02 14:29:19 +03:00
@user_agent "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_4) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.110 Safari/537.36"
@country_code "EE"
2019-10-31 06:49:46 +03:00
describe "POST /api/event" do
test "records the event", %{conn: conn} do
2019-09-02 14:29:19 +03:00
params = %{
domain: "external-controller-test-1.com",
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://gigride.live/",
referrer: "http://m.facebook.com/",
2020-03-31 15:01:27 +03:00
screen_width: 1440
2019-09-02 14:29:19 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2020-04-02 13:43:06 +03:00
|> put_req_header("x-country", @country_code)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-1.com")
2019-09-02 14:29:19 +03:00
assert response(conn, 202) == ""
assert pageview["hostname"] == "gigride.live"
assert pageview["domain"] == "external-controller-test-1.com"
assert pageview["pathname"] == "/"
assert pageview["country_code"] == @country_code
end
2020-02-05 14:51:44 +03:00
test "www. is stripped from domain", %{conn: conn} do
params = %{
name: "custom event",
url: "http://gigride.live/",
domain: "www.external-controller-test-2.com"
2020-02-05 14:51:44 +03:00
}
conn
|> put_req_header("content-type", "text/plain")
|> post("/api/event", Jason.encode!(params))
pageview = get_event("external-controller-test-2.com")
2020-02-05 14:51:44 +03:00
assert pageview["domain"] == "external-controller-test-2.com"
2020-02-05 14:51:44 +03:00
end
2019-09-02 14:29:19 +03:00
test "www. is stripped from hostname", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
url: "http://www.example.com/",
domain: "external-controller-test-3.com"
2019-09-02 14:29:19 +03:00
}
conn
|> put_req_header("content-type", "text/plain")
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-3.com")
2019-09-02 14:29:19 +03:00
assert pageview["hostname"] == "example.com"
2019-09-02 14:29:19 +03:00
end
2020-05-25 12:25:41 +03:00
test "empty path defaults to /", %{conn: conn} do
params = %{
name: "pageview",
url: "http://www.example.com",
domain: "external-controller-test-4.com"
2020-05-25 12:25:41 +03:00
}
conn
|> put_req_header("content-type", "text/plain")
|> post("/api/event", Jason.encode!(params))
pageview = get_event("external-controller-test-4.com")
2020-05-25 12:25:41 +03:00
assert pageview["pathname"] == "/"
2020-05-25 12:25:41 +03:00
end
2019-09-02 14:29:19 +03:00
test "bots and crawlers are ignored", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://www.example.com/",
domain: "external-controller-test-5.com"
2019-09-02 14:29:19 +03:00
}
conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", "generic crawler")
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
assert get_event("external-controller-test-5.com") == nil
2019-09-02 14:29:19 +03:00
end
test "parses user_agent", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://gigride.live/",
domain: "external-controller-test-6.com"
2019-09-02 14:29:19 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-6.com")
2019-09-02 14:29:19 +03:00
assert response(conn, 202) == ""
assert pageview["operating_system"] == "Mac"
assert pageview["browser"] == "Chrome"
2019-09-02 14:29:19 +03:00
end
test "parses referrer", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://gigride.live/",
referrer: "https://facebook.com",
domain: "external-controller-test-7.com"
2019-09-02 14:29:19 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-7.com")
2019-09-02 14:29:19 +03:00
assert response(conn, 202) == ""
assert pageview["referrer_source"] == "Facebook"
2019-09-02 14:29:19 +03:00
end
2020-01-08 11:53:08 +03:00
test "strips trailing slash from referrer", %{conn: conn} do
params = %{
name: "pageview",
url: "http://gigride.live/",
referrer: "https://facebook.com/page/",
domain: "external-controller-test-8.com"
2020-01-08 11:53:08 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
|> post("/api/event", Jason.encode!(params))
pageview = get_event("external-controller-test-8.com")
2020-01-08 11:53:08 +03:00
assert response(conn, 202) == ""
assert pageview["referrer"] == "facebook.com/page"
assert pageview["referrer_source"] == "Facebook"
2020-01-08 11:53:08 +03:00
end
2019-09-02 14:29:19 +03:00
test "ignores when referrer is internal", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://gigride.live/",
referrer: "https://gigride.live",
domain: "external-controller-test-9.com"
2019-09-02 14:29:19 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-9.com")
2019-09-02 14:29:19 +03:00
assert response(conn, 202) == ""
assert pageview["referrer_source"] == ""
2019-09-02 14:29:19 +03:00
end
test "ignores localhost referrer", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://gigride.live/",
referrer: "http://localhost:4000/",
domain: "external-controller-test-10.com"
2019-09-02 14:29:19 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-10.com")
2019-09-02 14:29:19 +03:00
assert response(conn, 202) == ""
assert pageview["referrer_source"] == ""
2019-09-02 14:29:19 +03:00
end
test "parses subdomain referrer", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://gigride.live/",
referrer: "https://blog.gigride.live",
domain: "external-controller-test-11.com"
2019-09-02 14:29:19 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-11.com")
2019-09-02 14:29:19 +03:00
assert response(conn, 202) == ""
assert pageview["referrer_source"] == "blog.gigride.live"
2019-09-02 14:29:19 +03:00
end
test "referrer is cleaned", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://www.example.com/",
referrer: "https://www.indiehackers.com/page?query=param#hash",
domain: "external-controller-test-12.com"
2019-09-02 14:29:19 +03:00
}
conn
|> put_req_header("content-type", "text/plain")
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-12.com")
2019-09-02 14:29:19 +03:00
assert pageview["referrer"] == "indiehackers.com/page"
2019-09-02 14:29:19 +03:00
end
test "source param controls the referrer source", %{conn: conn} do
2019-09-02 14:29:19 +03:00
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
url: "http://www.example.com/",
referrer: "https://betalist.com/my-produxct",
source: "betalist",
domain: "external-controller-test-13.com"
2019-09-02 14:29:19 +03:00
}
conn
|> put_req_header("content-type", "text/plain")
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-13.com")
2019-09-02 14:29:19 +03:00
assert pageview["referrer_source"] == "betalist"
2019-09-02 14:29:19 +03:00
end
test "if it's an :unknown referrer, just the domain is used", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://gigride.live/",
referrer: "https://www.indiehackers.com/landing-page-feedback",
domain: "external-controller-test-14.com"
2019-09-02 14:29:19 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-14.com")
2019-09-02 14:29:19 +03:00
assert response(conn, 202) == ""
assert pageview["referrer_source"] == "indiehackers.com"
2019-09-02 14:29:19 +03:00
end
test "if the referrer is not http or https, it is ignored", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://gigride.live/",
referrer: "android-app://com.google.android.gm",
domain: "external-controller-test-15.com"
2019-09-02 14:29:19 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-15.com")
2019-09-02 14:29:19 +03:00
assert response(conn, 202) == ""
assert pageview["referrer_source"] == ""
2019-09-02 14:29:19 +03:00
end
end
test "screen size is calculated from screen_width", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-02 14:29:19 +03:00
url: "http://gigride.live/",
screen_width: 480,
domain: "external-controller-test-16.com"
2019-09-02 14:29:19 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-02 14:29:19 +03:00
pageview = get_event("external-controller-test-16.com")
2019-09-02 14:29:19 +03:00
assert response(conn, 202) == ""
assert pageview["screen_size"] == "Mobile"
2019-09-02 14:29:19 +03:00
end
2019-09-04 12:50:56 +03:00
test "screen size is nil if screen_width is missing", %{conn: conn} do
params = %{
2019-10-31 06:49:46 +03:00
name: "pageview",
2019-09-04 12:50:56 +03:00
url: "http://gigride.live/",
domain: "external-controller-test-17.com"
2019-09-04 12:50:56 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
2019-10-31 06:49:46 +03:00
|> post("/api/event", Jason.encode!(params))
2019-09-04 12:50:56 +03:00
pageview = get_event("external-controller-test-17.com")
2019-09-04 12:50:56 +03:00
assert response(conn, 202) == ""
assert pageview["screen_size"] == ""
2019-09-04 12:50:56 +03:00
end
2019-10-31 06:49:46 +03:00
test "can trigger a custom event", %{conn: conn} do
params = %{
name: "custom event",
url: "http://gigride.live/",
domain: "external-controller-test-18.com"
2019-10-31 06:49:46 +03:00
}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
|> post("/api/event", Jason.encode!(params))
event = get_event("external-controller-test-18.com")
2019-10-31 06:49:46 +03:00
assert response(conn, 202) == ""
assert event["name"] == "custom event"
2019-10-31 06:49:46 +03:00
end
test "responds 400 when required fields are missing", %{conn: conn} do
2020-03-31 15:01:27 +03:00
params = %{}
conn = conn
|> put_req_header("content-type", "text/plain")
|> put_req_header("user-agent", @user_agent)
|> post("/api/event", Jason.encode!(params))
assert response(conn, 400) == ""
end
2019-09-02 14:29:19 +03:00
end