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:
Krzysztof Kotlarek 2020-04-17 09:04:10 +10:00 committed by GitHub
parent e96e57c629
commit e8e764c064
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 3 additions and 2 deletions

View File

@ -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")