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:
parent
e302c0af8b
commit
f415712269
|
@ -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
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue