DEV: avoid double sign-in which can lead to flaky tests

We should not be signing in twice in tests, it is both wasteful and risky
This commit is contained in:
Sam Saffron 2019-06-03 10:15:49 +10:00
parent e302c0af8b
commit f415712269
1 changed files with 39 additions and 34 deletions

View File

@ -5,44 +5,49 @@ require 'rails_helper'
describe CategoryHashtagsController do describe CategoryHashtagsController do
describe "check" do describe "check" do
describe "logged in" do describe "logged in" do
before do
sign_in(Fabricate(:user)) describe "regular user" do
before do
sign_in(Fabricate(:user))
end
it 'only returns the categories that are valid' do
category = Fabricate(:category)
get "/category_hashtags/check.json", params: { category_slugs: [category.slug, 'none'] }
expect(response.status).to eq(200)
expect(JSON.parse(response.body)).to eq(
"valid" => [{ "slug" => category.hashtag_slug, "url" => category.url_with_id }]
)
end
it 'does not return restricted categories for a normal user' do
group = Fabricate(:group)
private_category = Fabricate(:private_category, group: group)
get "/category_hashtags/check.json", params: { category_slugs: [private_category.slug] }
expect(response.status).to eq(200)
expect(JSON.parse(response.body)).to eq("valid" => [])
end
end end
it 'only returns the categories that are valid' do describe "admin user" do
category = Fabricate(:category) it 'returns restricted categories for an admin' do
admin = sign_in(Fabricate(:admin))
group = Fabricate(:group)
group.add(admin)
private_category = Fabricate(:private_category, group: group)
get "/category_hashtags/check.json", params: { category_slugs: [category.slug, 'none'] } get "/category_hashtags/check.json",
params: { category_slugs: [private_category.slug] }
expect(response.status).to eq(200) expect(response.status).to eq(200)
expect(JSON.parse(response.body)).to eq( expect(JSON.parse(response.body)).to eq(
"valid" => [{ "slug" => category.hashtag_slug, "url" => category.url_with_id }] "valid" => [{ "slug" => private_category.hashtag_slug, "url" => private_category.url_with_id }]
) )
end end
it 'does not return restricted categories for a normal user' do
group = Fabricate(:group)
private_category = Fabricate(:private_category, group: group)
get "/category_hashtags/check.json", params: { category_slugs: [private_category.slug] }
expect(response.status).to eq(200)
expect(JSON.parse(response.body)).to eq("valid" => [])
end
it 'returns restricted categories for an admin' do
admin = sign_in(Fabricate(:admin))
group = Fabricate(:group)
group.add(admin)
private_category = Fabricate(:private_category, group: group)
get "/category_hashtags/check.json",
params: { category_slugs: [private_category.slug] }
expect(response.status).to eq(200)
expect(JSON.parse(response.body)).to eq(
"valid" => [{ "slug" => private_category.hashtag_slug, "url" => private_category.url_with_id }]
)
end end
end end