diff options
| author | kaniini <nenolod@gmail.com> | 2019-03-03 16:00:49 +0000 | 
|---|---|---|
| committer | kaniini <nenolod@gmail.com> | 2019-03-03 16:00:49 +0000 | 
| commit | ace4231628ad1af08c8696fb7fe6983549f62631 (patch) | |
| tree | c310e7065122b6c3a6e5a07d0f3eeaad1f2ef546 /test | |
| parent | 6c6a2dbfdd7ae4043633c3201693c5c49538ef84 (diff) | |
| parent | f2452d5700afc48284638ae2cd1bff4886571d8c (diff) | |
| download | pleroma-ace4231628ad1af08c8696fb7fe6983549f62631.tar.gz pleroma-ace4231628ad1af08c8696fb7fe6983549f62631.zip | |
Merge branch 'features/bio_rel_me' into 'develop'
Add rel=me to the User bio
Closes #423
See merge request pleroma/pleroma!813
Diffstat (limited to 'test')
| -rw-r--r-- | test/fixtures/rel_me_anchor.html | 14 | ||||
| -rw-r--r-- | test/fixtures/rel_me_link.html | 14 | ||||
| -rw-r--r-- | test/fixtures/rel_me_null.html | 13 | ||||
| -rw-r--r-- | test/user_test.exs | 16 | ||||
| -rw-r--r-- | test/web/rel_me_test.exs | 55 | 
5 files changed, 112 insertions, 0 deletions
| diff --git a/test/fixtures/rel_me_anchor.html b/test/fixtures/rel_me_anchor.html new file mode 100644 index 000000000..5abcce129 --- /dev/null +++ b/test/fixtures/rel_me_anchor.html @@ -0,0 +1,14 @@ +<!DOCTYPE html> +<html> +	<head> +		<meta charset="utf-8"/> +		<title>Blog</title> +	</head> +	<body> +	<article> +		<h1>Lorem ipsum</h1> +		<p>Lorem ipsum dolor sit ameph, …</p> +		<a rel="me" href="https://social.example.org/users/lain">lain’s account</a> +	</article> +	</body> +</html> diff --git a/test/fixtures/rel_me_link.html b/test/fixtures/rel_me_link.html new file mode 100644 index 000000000..b9ff18f6e --- /dev/null +++ b/test/fixtures/rel_me_link.html @@ -0,0 +1,14 @@ +<!DOCTYPE html> +<html> +	<head> +		<meta charset="utf-8"/> +		<title>Blog</title> +		<link rel="me" href="https://social.example.org/users/lain"/> +	</head> +	<body> +	<article> +		<h1>Lorem ipsum</h1> +		<p>Lorem ipsum dolor sit ameph, …</p> +	</article> +	</body> +</html> diff --git a/test/fixtures/rel_me_null.html b/test/fixtures/rel_me_null.html new file mode 100644 index 000000000..57d424b80 --- /dev/null +++ b/test/fixtures/rel_me_null.html @@ -0,0 +1,13 @@ +<!DOCTYPE html> +<html> +	<head> +		<meta charset="utf-8"/> +		<title>Blog</title> +	</head> +	<body> +	<article> +		<h1>Lorem ipsum</h1> +		<p>Lorem ipsum dolor sit ameph, …</p> +	</article> +	</body> +</html> diff --git a/test/user_test.exs b/test/user_test.exs index 390e3ef13..3a5f3c240 100644 --- a/test/user_test.exs +++ b/test/user_test.exs @@ -1054,6 +1054,22 @@ defmodule Pleroma.UserTest do        assert expected_text == User.parse_bio(bio, user)      end + +    test "Adds rel=me on linkbacked urls" do +      user = insert(:user, ap_id: "http://social.example.org/users/lain") + +      bio = "http://example.org/rel_me/null" +      expected_text = "<a href=\"#{bio}\">#{bio}</a>" +      assert expected_text == User.parse_bio(bio, user) + +      bio = "http://example.org/rel_me/link" +      expected_text = "<a href=\"#{bio}\">#{bio}</a>" +      assert expected_text == User.parse_bio(bio, user) + +      bio = "http://example.org/rel_me/anchor" +      expected_text = "<a href=\"#{bio}\">#{bio}</a>" +      assert expected_text == User.parse_bio(bio, user) +    end    end    test "bookmarks" do diff --git a/test/web/rel_me_test.exs b/test/web/rel_me_test.exs new file mode 100644 index 000000000..ba8038e69 --- /dev/null +++ b/test/web/rel_me_test.exs @@ -0,0 +1,55 @@ +defmodule Pleroma.Web.RelMeTest do +  use ExUnit.Case, async: true + +  setup do +    Tesla.Mock.mock(fn +      %{ +        method: :get, +        url: "http://example.com/rel_me/anchor" +      } -> +        %Tesla.Env{status: 200, body: File.read!("test/fixtures/rel_me_anchor.html")} + +      %{ +        method: :get, +        url: "http://example.com/rel_me/link" +      } -> +        %Tesla.Env{status: 200, body: File.read!("test/fixtures/rel_me_link.html")} + +      %{ +        method: :get, +        url: "http://example.com/rel_me/null" +      } -> +        %Tesla.Env{status: 200, body: File.read!("test/fixtures/rel_me_null.html")} +    end) + +    :ok +  end + +  test "parse/1" do +    hrefs = ["https://social.example.org/users/lain"] + +    assert Pleroma.Web.RelMe.parse("http://example.com/rel_me/null") == {:ok, []} +    assert {:error, _} = Pleroma.Web.RelMe.parse("http://example.com/rel_me/error") + +    assert Pleroma.Web.RelMe.parse("http://example.com/rel_me/link") == {:ok, hrefs} +    assert Pleroma.Web.RelMe.parse("http://example.com/rel_me/anchor") == {:ok, hrefs} +  end + +  test "maybe_put_rel_me/2" do +    profile_urls = ["https://social.example.org/users/lain"] +    attr = "me" +    fallback = nil + +    assert Pleroma.Web.RelMe.maybe_put_rel_me("http://example.com/rel_me/null", profile_urls) == +             fallback + +    assert Pleroma.Web.RelMe.maybe_put_rel_me("http://example.com/rel_me/error", profile_urls) == +             fallback + +    assert Pleroma.Web.RelMe.maybe_put_rel_me("http://example.com/rel_me/anchor", profile_urls) == +             attr + +    assert Pleroma.Web.RelMe.maybe_put_rel_me("http://example.com/rel_me/link", profile_urls) == +             attr +  end +end | 
