// NetUserGetLocalGroups() would return a list of LocalGroupUserInfo0
        // elements which hold the names of local groups where the user participates.
        // The list does not follow any sorting order.
-       //
-       // If no groups can be found for this user, NetUserGetLocalGroups() should
-       // always return the SID of a single group called "None", which
-       // also happens to be the primary group for the local user.
        err = windows.NetUserGetLocalGroups(nil, q, 0, windows.LG_INCLUDE_INDIRECT, &p0, windows.MAX_PREFERRED_LENGTH, &entriesRead, &totalEntries)
        if err != nil {
                return nil, err
        }
        defer syscall.NetApiBufferFree(p0)
        if entriesRead == 0 {
-               return nil, fmt.Errorf("listGroupsForUsernameAndDomain: NetUserGetLocalGroups() returned an empty list for domain: %s, username: %s", domain, username)
+               return nil, nil
        }
        entries := (*[1024]windows.LocalGroupUserInfo0)(unsafe.Pointer(p0))[:entriesRead:entriesRead]
        var sids []string
 
 // windowsTestAcount creates a test user and returns a token for that user.
 // If the user already exists, it will be deleted and recreated.
 // The caller is responsible for closing the token.
-func windowsTestAcount(t *testing.T) syscall.Token {
+func windowsTestAcount(t *testing.T) (syscall.Token, *User) {
+       const testUserName = "GoStdTestUser01"
        var password [33]byte
        rand.Read(password[:])
        // Add special chars to ensure it satisfies password requirements.
        pwd := base64.StdEncoding.EncodeToString(password[:]) + "_-As@!%*(1)4#2"
-       name, err := syscall.UTF16PtrFromString("GoStdTestUser01")
+       name, err := syscall.UTF16PtrFromString(testUserName)
        if err != nil {
                t.Fatal(err)
        }
        } else if err != nil {
                t.Fatal(err)
        }
+       t.Cleanup(func() {
+               if err = windows.NetUserDel(nil, name); err != nil {
+                       if !errors.Is(err, windows.NERR_UserNotFound) {
+                               t.Fatal(err)
+                       }
+               }
+       })
        domain, err := syscall.UTF16PtrFromString(".")
        if err != nil {
                t.Fatal(err)
        }
        t.Cleanup(func() {
                token.Close()
-               if err = windows.NetUserDel(nil, name); err != nil {
-                       if !errors.Is(err, windows.NERR_UserNotFound) {
-                               t.Fatal(err)
-                       }
-               }
        })
-       return token
+       usr, err := Lookup(testUserName)
+       if err != nil {
+               t.Fatal(err)
+       }
+       return token, usr
 }
 
 func TestImpersonatedSelf(t *testing.T) {
        }
 
        // Create a test user and log in as that user.
-       token := windowsTestAcount(t)
+       token, _ := windowsTestAcount(t)
 
        // Impersonate the test user.
        if err = windows.ImpersonateLoggedOnUser(token); err != nil {
                t.Fatalf("%v\n%s", err, out)
        }
 }
+
+func TestGroupIdsTestUser(t *testing.T) {
+       // Create a test user and log in as that user.
+       _, user := windowsTestAcount(t)
+
+       gids, err := user.GroupIds()
+       if err != nil {
+               t.Fatal(err)
+       }
+
+       if err != nil {
+               t.Fatalf("%+v.GroupIds(): %v", user, err)
+       }
+       if !containsID(gids, user.Gid) {
+               t.Errorf("%+v.GroupIds() = %v; does not contain user GID %s", user, gids, user.Gid)
+       }
+}