fix: workspaces query to correctly user username from users table (#15305)

The subquery on the users table was incorrectly using the username from
the `workspaces` table, not the `users` table.

This passed `sqlc-vet` because the column did exist in the query, it
just was not the correct one.
This commit is contained in:
Steven Masley
2024-10-31 12:33:07 -04:00
committed by GitHub
parent 4849b4d8ac
commit 9d03e0429f
3 changed files with 35 additions and 2 deletions

View File

@ -14947,7 +14947,7 @@ WHERE
-- Filter by owner_name -- Filter by owner_name
AND CASE AND CASE
WHEN $8 :: text != '' THEN WHEN $8 :: text != '' THEN
workspaces.owner_id = (SELECT id FROM users WHERE lower(owner_username) = lower($8) AND deleted = false) workspaces.owner_id = (SELECT id FROM users WHERE lower(users.username) = lower($8) AND deleted = false)
ELSE true ELSE true
END END
-- Filter by template_name -- Filter by template_name

View File

@ -233,7 +233,7 @@ WHERE
-- Filter by owner_name -- Filter by owner_name
AND CASE AND CASE
WHEN @owner_username :: text != '' THEN WHEN @owner_username :: text != '' THEN
workspaces.owner_id = (SELECT id FROM users WHERE lower(owner_username) = lower(@owner_username) AND deleted = false) workspaces.owner_id = (SELECT id FROM users WHERE lower(users.username) = lower(@owner_username) AND deleted = false)
ELSE true ELSE true
END END
-- Filter by template_name -- Filter by template_name

View File

@ -1313,6 +1313,39 @@ func TestWorkspaceFilterManual(t *testing.T) {
require.NoError(t, err) require.NoError(t, err)
require.Len(t, res.Workspaces, 0) require.Len(t, res.Workspaces, 0)
}) })
t.Run("Owner", func(t *testing.T) {
t.Parallel()
client := coderdtest.New(t, &coderdtest.Options{IncludeProvisionerDaemon: true})
user := coderdtest.CreateFirstUser(t, client)
otherUser, _ := coderdtest.CreateAnotherUser(t, client, user.OrganizationID, rbac.RoleOwner())
version := coderdtest.CreateTemplateVersion(t, client, user.OrganizationID, nil)
coderdtest.AwaitTemplateVersionJobCompleted(t, client, version.ID)
template := coderdtest.CreateTemplate(t, client, user.OrganizationID, version.ID)
// Add a non-matching workspace
coderdtest.CreateWorkspace(t, otherUser, template.ID)
workspaces := []codersdk.Workspace{
coderdtest.CreateWorkspace(t, client, template.ID),
coderdtest.CreateWorkspace(t, client, template.ID),
}
ctx, cancel := context.WithTimeout(context.Background(), testutil.WaitLong)
defer cancel()
sdkUser, err := client.User(ctx, codersdk.Me)
require.NoError(t, err)
// match owner name
res, err := client.Workspaces(ctx, codersdk.WorkspaceFilter{
FilterQuery: fmt.Sprintf("owner:%s", sdkUser.Username),
})
require.NoError(t, err)
require.Len(t, res.Workspaces, len(workspaces))
for _, found := range res.Workspaces {
require.Equal(t, found.OwnerName, sdkUser.Username)
}
})
t.Run("IDs", func(t *testing.T) { t.Run("IDs", func(t *testing.T) {
t.Parallel() t.Parallel()
client := coderdtest.New(t, &coderdtest.Options{IncludeProvisionerDaemon: true}) client := coderdtest.New(t, &coderdtest.Options{IncludeProvisionerDaemon: true})