FIX: flaky groups_controller_spec (#9439)
Sometimes spec which is testing order groups by user count is failing. My theory is that cause is the randomness of Postgres when the order value is the same for 2 rows. In spec, we got three groups `moderator_group` - 0 users `group` - 1 user `other_group` - 1 user And we are expecting that controller will return them in ascending order [moderator, group, other_group] Because `group` and `other_group` contain the same amount of users, we are dealing with luck Therefore, I believe that adding one more user to other_group should make that query reliable. It was not crashing on my local machine, so I am not 100% sure.
This commit is contained in:
parent
e96e57c629
commit
e8e764c064
|
@ -4,6 +4,7 @@ require 'rails_helper'
|
||||||
|
|
||||||
describe GroupsController do
|
describe GroupsController do
|
||||||
fab!(:user) { Fabricate(:user) }
|
fab!(:user) { Fabricate(:user) }
|
||||||
|
let(:other_user) { Fabricate(:user) }
|
||||||
let(:group) { Fabricate(:group, users: [user]) }
|
let(:group) { Fabricate(:group, users: [user]) }
|
||||||
let(:moderator_group_id) { Group::AUTO_GROUPS[:moderators] }
|
let(:moderator_group_id) { Group::AUTO_GROUPS[:moderators] }
|
||||||
fab!(:admin) { Fabricate(:admin) }
|
fab!(:admin) { Fabricate(:admin) }
|
||||||
|
@ -91,7 +92,7 @@ describe GroupsController do
|
||||||
sign_in(user)
|
sign_in(user)
|
||||||
end
|
end
|
||||||
|
|
||||||
let!(:other_group) { Fabricate(:group, name: "other_group", users: [user]) }
|
let!(:other_group) { Fabricate(:group, name: "other_group", users: [user, other_user]) }
|
||||||
|
|
||||||
context "with default (descending) order" do
|
context "with default (descending) order" do
|
||||||
it "sorts by name" do
|
it "sorts by name" do
|
||||||
|
@ -116,7 +117,7 @@ describe GroupsController do
|
||||||
body = JSON.parse(response.body)
|
body = JSON.parse(response.body)
|
||||||
|
|
||||||
expect(body["groups"].map { |g| g["id"] }).to eq([
|
expect(body["groups"].map { |g| g["id"] }).to eq([
|
||||||
group.id, other_group.id, moderator_group_id
|
other_group.id, group.id, moderator_group_id
|
||||||
])
|
])
|
||||||
|
|
||||||
expect(body["load_more_groups"]).to eq("/groups?order=user_count&page=1")
|
expect(body["load_more_groups"]).to eq("/groups?order=user_count&page=1")
|
||||||
|
|
Loading…
Reference in New Issue