Add tests for poll view
This commit is contained in:
parent
e3c460353d
commit
c47da0e65d
|
@ -342,4 +342,106 @@ test "a rich media card with all relevant data renders correctly" do
|
||||||
StatusView.render("card.json", %{page_url: page_url, rich_media: card})
|
StatusView.render("card.json", %{page_url: page_url, rich_media: card})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe "poll view" do
|
||||||
|
test "renders a poll" do
|
||||||
|
user = insert(:user)
|
||||||
|
|
||||||
|
{:ok, activity} =
|
||||||
|
CommonAPI.post(user, %{
|
||||||
|
"status" => "Is Tenshi eating a corndog cute?",
|
||||||
|
"poll" => %{
|
||||||
|
"options" => ["absolutely!", "sure", "yes", "why are you even asking?"],
|
||||||
|
"expires_in" => 20
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
object = Object.normalize(activity)
|
||||||
|
|
||||||
|
expected = %{
|
||||||
|
emojis: [],
|
||||||
|
expired: false,
|
||||||
|
id: object.id,
|
||||||
|
multiple: false,
|
||||||
|
options: [
|
||||||
|
%{title: "absolutely!", votes_count: 0},
|
||||||
|
%{title: "sure", votes_count: 0},
|
||||||
|
%{title: "yes", votes_count: 0},
|
||||||
|
%{title: "why are you even asking?", votes_count: 0}
|
||||||
|
],
|
||||||
|
voted: false,
|
||||||
|
votes_count: 0
|
||||||
|
}
|
||||||
|
|
||||||
|
result = StatusView.render("poll.json", %{object: object})
|
||||||
|
expires_at = result.expires_at
|
||||||
|
result = Map.delete(result, :expires_at)
|
||||||
|
|
||||||
|
assert result == expected
|
||||||
|
|
||||||
|
expires_at = NaiveDateTime.from_iso8601!(expires_at)
|
||||||
|
assert NaiveDateTime.diff(expires_at, NaiveDateTime.utc_now()) in 15..20
|
||||||
|
end
|
||||||
|
|
||||||
|
test "detects if it is multiple choice" do
|
||||||
|
user = insert(:user)
|
||||||
|
|
||||||
|
{:ok, activity} =
|
||||||
|
CommonAPI.post(user, %{
|
||||||
|
"status" => "Which Mastodon developer is your favourite?",
|
||||||
|
"poll" => %{
|
||||||
|
"options" => ["Gargron", "Eugen"],
|
||||||
|
"expires_in" => 20,
|
||||||
|
"multiple" => true
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
object = Object.normalize(activity)
|
||||||
|
|
||||||
|
assert %{multiple: true} = StatusView.render("poll.json", %{object: object})
|
||||||
|
end
|
||||||
|
|
||||||
|
test "detects emoji" do
|
||||||
|
user = insert(:user)
|
||||||
|
|
||||||
|
{:ok, activity} =
|
||||||
|
CommonAPI.post(user, %{
|
||||||
|
"status" => "What's with the smug face?",
|
||||||
|
"poll" => %{
|
||||||
|
"options" => [":blank: sip", ":blank::blank: sip", ":blank::blank::blank: sip"],
|
||||||
|
"expires_in" => 20
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
object = Object.normalize(activity)
|
||||||
|
|
||||||
|
assert %{emojis: [%{shortcode: "blank"}]} =
|
||||||
|
StatusView.render("poll.json", %{object: object})
|
||||||
|
end
|
||||||
|
|
||||||
|
test "detects vote status" do
|
||||||
|
user = insert(:user)
|
||||||
|
other_user = insert(:user)
|
||||||
|
|
||||||
|
{:ok, activity} =
|
||||||
|
CommonAPI.post(user, %{
|
||||||
|
"status" => "Which input devices do you use?",
|
||||||
|
"poll" => %{
|
||||||
|
"options" => ["mouse", "trackball", "trackpoint"],
|
||||||
|
"multiple" => true,
|
||||||
|
"expires_in" => 20
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
object = Object.normalize(activity)
|
||||||
|
|
||||||
|
{:ok, _, object} = CommonAPI.vote(other_user, object, [1, 2])
|
||||||
|
|
||||||
|
result = StatusView.render("poll.json", %{object: object, for: other_user})
|
||||||
|
|
||||||
|
assert result[:voted] == true
|
||||||
|
assert Enum.at(result[:options], 1)[:votes_count] == 1
|
||||||
|
assert Enum.at(result[:options], 2)[:votes_count] == 1
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue