mirror of
https://github.com/coder/coder.git
synced 2025-07-18 14:17:22 +00:00
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:
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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})
|
||||||
|
Reference in New Issue
Block a user