mirror of
https://github.com/empayre/fleet.git
synced 2024-11-07 09:18:59 +00:00
4f4185372d
This is just to pass down the context to the datastore layer, it doesn't use it just yet - this will be in a follow-up PR.
56 lines
1.6 KiB
Go
56 lines
1.6 KiB
Go
package mysql
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
|
|
"github.com/fleetdm/fleet/v4/server/fleet"
|
|
"github.com/fleetdm/fleet/v4/server/ptr"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestSessionGetters(t *testing.T) {
|
|
ds := CreateMySQLDS(t)
|
|
defer ds.Close()
|
|
|
|
user, err := ds.NewUser(context.Background(), &fleet.User{
|
|
Password: []byte("supersecret"),
|
|
Email: "other@bobcom",
|
|
GlobalRole: ptr.String(fleet.RoleObserver),
|
|
})
|
|
require.NoError(t, err)
|
|
|
|
session, err := ds.NewSession(context.Background(), &fleet.Session{UserID: user.ID, Key: "somekey"})
|
|
require.NoError(t, err)
|
|
require.NotZero(t, session.ID)
|
|
|
|
gotByID, err := ds.SessionByID(context.Background(), session.ID)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, session.Key, gotByID.Key)
|
|
|
|
gotByKey, err := ds.SessionByKey(context.Background(), session.Key)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, session.ID, gotByKey.ID)
|
|
|
|
newSession, err := ds.NewSession(context.Background(), &fleet.Session{UserID: user.ID, Key: "somekey2"})
|
|
require.NoError(t, err)
|
|
|
|
sessions, err := ds.ListSessionsForUser(context.Background(), user.ID)
|
|
require.NoError(t, err)
|
|
require.Len(t, sessions, 2)
|
|
|
|
require.NoError(t, ds.DestroySession(context.Background(), session))
|
|
|
|
prevAccessedAt := newSession.AccessedAt
|
|
|
|
require.NoError(t, ds.MarkSessionAccessed(context.Background(), newSession))
|
|
|
|
sessions, err = ds.ListSessionsForUser(context.Background(), user.ID)
|
|
require.NoError(t, err)
|
|
require.Len(t, sessions, 1)
|
|
require.NotEqual(t, prevAccessedAt, sessions[0].AccessedAt)
|
|
|
|
require.NoError(t, ds.DestroyAllSessionsForUser(context.Background(), user.ID))
|
|
}
|