2020-02-11 02:12:57 -05:00
|
|
|
# Pleroma: A lightweight social networking server
|
2020-03-03 18:16:24 -05:00
|
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
2020-02-11 02:12:57 -05:00
|
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
defmodule Pleroma.HTTP.ConnectionTest do
|
|
|
|
use ExUnit.Case
|
|
|
|
use Pleroma.Tests.Helpers
|
|
|
|
import ExUnit.CaptureLog
|
|
|
|
alias Pleroma.Config
|
|
|
|
alias Pleroma.HTTP.Connection
|
|
|
|
|
|
|
|
setup_all do
|
2020-03-03 11:24:14 -05:00
|
|
|
{:ok, _} = Registry.start_link(keys: :unique, name: Pleroma.GunMock)
|
2020-02-11 02:12:57 -05:00
|
|
|
:ok
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "parse_host/1" do
|
|
|
|
test "as atom to charlist" do
|
|
|
|
assert Connection.parse_host(:localhost) == 'localhost'
|
|
|
|
end
|
|
|
|
|
|
|
|
test "as string to charlist" do
|
|
|
|
assert Connection.parse_host("localhost.com") == 'localhost.com'
|
|
|
|
end
|
|
|
|
|
|
|
|
test "as string ip to tuple" do
|
|
|
|
assert Connection.parse_host("127.0.0.1") == {127, 0, 0, 1}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "parse_proxy/1" do
|
|
|
|
test "ip with port" do
|
|
|
|
assert Connection.parse_proxy("127.0.0.1:8123") == {:ok, {127, 0, 0, 1}, 8123}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "host with port" do
|
|
|
|
assert Connection.parse_proxy("localhost:8123") == {:ok, 'localhost', 8123}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "as tuple" do
|
|
|
|
assert Connection.parse_proxy({:socks4, :localhost, 9050}) ==
|
|
|
|
{:ok, :socks4, 'localhost', 9050}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "as tuple with string host" do
|
|
|
|
assert Connection.parse_proxy({:socks5, "localhost", 9050}) ==
|
|
|
|
{:ok, :socks5, 'localhost', 9050}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "parse_proxy/1 errors" do
|
|
|
|
test "ip without port" do
|
|
|
|
capture_log(fn ->
|
2020-03-03 09:32:59 -05:00
|
|
|
assert Connection.parse_proxy("127.0.0.1") == {:error, :invalid_proxy}
|
2020-02-11 02:12:57 -05:00
|
|
|
end) =~ "parsing proxy fail \"127.0.0.1\""
|
|
|
|
end
|
|
|
|
|
|
|
|
test "host without port" do
|
|
|
|
capture_log(fn ->
|
2020-03-03 09:32:59 -05:00
|
|
|
assert Connection.parse_proxy("localhost") == {:error, :invalid_proxy}
|
2020-02-11 02:12:57 -05:00
|
|
|
end) =~ "parsing proxy fail \"localhost\""
|
|
|
|
end
|
|
|
|
|
|
|
|
test "host with bad port" do
|
|
|
|
capture_log(fn ->
|
2020-03-03 09:32:59 -05:00
|
|
|
assert Connection.parse_proxy("localhost:port") == {:error, :invalid_proxy_port}
|
2020-02-11 02:12:57 -05:00
|
|
|
end) =~ "parsing port in proxy fail \"localhost:port\""
|
|
|
|
end
|
|
|
|
|
|
|
|
test "ip with bad port" do
|
|
|
|
capture_log(fn ->
|
2020-03-03 09:32:59 -05:00
|
|
|
assert Connection.parse_proxy("127.0.0.1:15.9") == {:error, :invalid_proxy_port}
|
2020-02-11 02:12:57 -05:00
|
|
|
end) =~ "parsing port in proxy fail \"127.0.0.1:15.9\""
|
|
|
|
end
|
|
|
|
|
|
|
|
test "as tuple without port" do
|
|
|
|
capture_log(fn ->
|
2020-03-03 09:32:59 -05:00
|
|
|
assert Connection.parse_proxy({:socks5, :localhost}) == {:error, :invalid_proxy}
|
2020-02-11 02:12:57 -05:00
|
|
|
end) =~ "parsing proxy fail {:socks5, :localhost}"
|
|
|
|
end
|
|
|
|
|
|
|
|
test "with nil" do
|
|
|
|
assert Connection.parse_proxy(nil) == nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe "options/3" do
|
|
|
|
clear_config([:http, :proxy_url])
|
|
|
|
|
|
|
|
test "without proxy_url in config" do
|
|
|
|
Config.delete([:http, :proxy_url])
|
|
|
|
|
|
|
|
opts = Connection.options(%URI{})
|
|
|
|
refute Keyword.has_key?(opts, :proxy)
|
|
|
|
end
|
|
|
|
|
|
|
|
test "parses string proxy host & port" do
|
|
|
|
Config.put([:http, :proxy_url], "localhost:8123")
|
|
|
|
|
|
|
|
opts = Connection.options(%URI{})
|
|
|
|
assert opts[:proxy] == {'localhost', 8123}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "parses tuple proxy scheme host and port" do
|
|
|
|
Config.put([:http, :proxy_url], {:socks, 'localhost', 1234})
|
|
|
|
|
|
|
|
opts = Connection.options(%URI{})
|
|
|
|
assert opts[:proxy] == {:socks, 'localhost', 1234}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "passed opts have more weight than defaults" do
|
|
|
|
Config.put([:http, :proxy_url], {:socks5, 'localhost', 1234})
|
|
|
|
|
|
|
|
opts = Connection.options(%URI{}, proxy: {'example.com', 4321})
|
|
|
|
|
|
|
|
assert opts[:proxy] == {'example.com', 4321}
|
|
|
|
end
|
|
|
|
|
|
|
|
test "default ssl adapter opts with connection" do
|
|
|
|
adapter = Application.get_env(:tesla, :adapter)
|
|
|
|
Application.put_env(:tesla, :adapter, Tesla.Adapter.Gun)
|
|
|
|
on_exit(fn -> Application.put_env(:tesla, :adapter, adapter) end)
|
|
|
|
|
|
|
|
uri = URI.parse("https://some-domain.com")
|
|
|
|
|
|
|
|
pid = Process.whereis(:federation)
|
2020-02-24 11:56:27 -05:00
|
|
|
:ok = Pleroma.Gun.Conn.open(uri, :gun_connections, genserver_pid: pid)
|
2020-02-11 02:12:57 -05:00
|
|
|
|
|
|
|
opts = Connection.options(uri)
|
|
|
|
|
|
|
|
assert opts[:certificates_verification]
|
|
|
|
tls_opts = opts[:tls_opts]
|
|
|
|
assert tls_opts[:verify] == :verify_peer
|
|
|
|
assert tls_opts[:depth] == 20
|
|
|
|
assert tls_opts[:reuse_sessions] == false
|
|
|
|
|
|
|
|
assert opts[:original] == "some-domain.com:443"
|
|
|
|
assert opts[:close_conn] == false
|
|
|
|
assert is_pid(opts[:conn])
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|