mirror of https://github.com/coder/coder.git
190 lines
5.6 KiB
Go
190 lines
5.6 KiB
Go
package coderd_test
|
|
|
|
import (
|
|
"context"
|
|
"net/http"
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
"golang.org/x/xerrors"
|
|
|
|
"github.com/coder/coder/v2/codersdk"
|
|
"github.com/coder/coder/v2/enterprise/coderd/coderdenttest"
|
|
"github.com/coder/coder/v2/enterprise/coderd/license"
|
|
"github.com/coder/coder/v2/testutil"
|
|
)
|
|
|
|
func TestPostLicense(t *testing.T) {
|
|
t.Parallel()
|
|
|
|
t.Run("Success", func(t *testing.T) {
|
|
t.Parallel()
|
|
client, _ := coderdenttest.New(t, &coderdenttest.Options{DontAddLicense: true})
|
|
respLic := coderdenttest.AddLicense(t, client, coderdenttest.LicenseOptions{
|
|
AccountType: license.AccountTypeSalesforce,
|
|
AccountID: "testing",
|
|
Features: license.Features{
|
|
codersdk.FeatureAuditLog: 1,
|
|
},
|
|
})
|
|
assert.GreaterOrEqual(t, respLic.ID, int32(0))
|
|
// just a couple spot checks for sanity
|
|
assert.Equal(t, "testing", respLic.Claims["account_id"])
|
|
features, err := respLic.FeaturesClaims()
|
|
require.NoError(t, err)
|
|
assert.EqualValues(t, 1, features[codersdk.FeatureAuditLog])
|
|
})
|
|
|
|
t.Run("Unauthorized", func(t *testing.T) {
|
|
t.Parallel()
|
|
client, _ := coderdenttest.New(t, &coderdenttest.Options{DontAddLicense: true})
|
|
client.SetSessionToken("")
|
|
_, err := client.AddLicense(context.Background(), codersdk.AddLicenseRequest{
|
|
License: "content",
|
|
})
|
|
errResp := &codersdk.Error{}
|
|
if xerrors.As(err, &errResp) {
|
|
assert.Equal(t, 401, errResp.StatusCode())
|
|
} else {
|
|
t.Error("expected to get error status 401")
|
|
}
|
|
})
|
|
|
|
t.Run("Corrupted", func(t *testing.T) {
|
|
t.Parallel()
|
|
client, _ := coderdenttest.New(t, &coderdenttest.Options{DontAddLicense: true})
|
|
coderdenttest.AddLicense(t, client, coderdenttest.LicenseOptions{})
|
|
_, err := client.AddLicense(context.Background(), codersdk.AddLicenseRequest{
|
|
License: "invalid",
|
|
})
|
|
errResp := &codersdk.Error{}
|
|
if xerrors.As(err, &errResp) {
|
|
assert.Equal(t, 400, errResp.StatusCode())
|
|
} else {
|
|
t.Error("expected to get error status 400")
|
|
}
|
|
})
|
|
}
|
|
|
|
func TestGetLicense(t *testing.T) {
|
|
t.Parallel()
|
|
t.Run("Success", func(t *testing.T) {
|
|
t.Parallel()
|
|
client, _ := coderdenttest.New(t, &coderdenttest.Options{DontAddLicense: true})
|
|
ctx, cancel := context.WithTimeout(context.Background(), testutil.WaitLong)
|
|
defer cancel()
|
|
|
|
coderdenttest.AddLicense(t, client, coderdenttest.LicenseOptions{
|
|
AccountID: "testing",
|
|
Features: license.Features{
|
|
codersdk.FeatureAuditLog: 1,
|
|
codersdk.FeatureSCIM: 1,
|
|
codersdk.FeatureBrowserOnly: 1,
|
|
codersdk.FeatureTemplateRBAC: 1,
|
|
},
|
|
})
|
|
|
|
coderdenttest.AddLicense(t, client, coderdenttest.LicenseOptions{
|
|
AccountID: "testing2",
|
|
Features: license.Features{
|
|
codersdk.FeatureAuditLog: 1,
|
|
codersdk.FeatureSCIM: 1,
|
|
codersdk.FeatureBrowserOnly: 1,
|
|
codersdk.FeatureUserLimit: 200,
|
|
},
|
|
Trial: true,
|
|
})
|
|
|
|
licenses, err := client.Licenses(ctx)
|
|
require.NoError(t, err)
|
|
require.Len(t, licenses, 2)
|
|
assert.Equal(t, int32(1), licenses[0].ID)
|
|
assert.Equal(t, "testing", licenses[0].Claims["account_id"])
|
|
|
|
features, err := licenses[0].FeaturesClaims()
|
|
require.NoError(t, err)
|
|
assert.Equal(t, map[codersdk.FeatureName]int64{
|
|
codersdk.FeatureAuditLog: 1,
|
|
codersdk.FeatureSCIM: 1,
|
|
codersdk.FeatureBrowserOnly: 1,
|
|
codersdk.FeatureTemplateRBAC: 1,
|
|
}, features)
|
|
assert.Equal(t, int32(2), licenses[1].ID)
|
|
assert.Equal(t, "testing2", licenses[1].Claims["account_id"])
|
|
assert.Equal(t, true, licenses[1].Claims["trial"])
|
|
|
|
features, err = licenses[1].FeaturesClaims()
|
|
require.NoError(t, err)
|
|
assert.Equal(t, map[codersdk.FeatureName]int64{
|
|
codersdk.FeatureUserLimit: 200,
|
|
codersdk.FeatureAuditLog: 1,
|
|
codersdk.FeatureSCIM: 1,
|
|
codersdk.FeatureBrowserOnly: 1,
|
|
}, features)
|
|
})
|
|
}
|
|
|
|
func TestDeleteLicense(t *testing.T) {
|
|
t.Parallel()
|
|
t.Run("Empty", func(t *testing.T) {
|
|
t.Parallel()
|
|
client, _ := coderdenttest.New(t, &coderdenttest.Options{DontAddLicense: true})
|
|
ctx, cancel := context.WithTimeout(context.Background(), testutil.WaitLong)
|
|
defer cancel()
|
|
|
|
err := client.DeleteLicense(ctx, 1)
|
|
errResp := &codersdk.Error{}
|
|
if xerrors.As(err, &errResp) {
|
|
assert.Equal(t, 404, errResp.StatusCode())
|
|
} else {
|
|
t.Error("expected to get error status 404")
|
|
}
|
|
})
|
|
|
|
t.Run("BadID", func(t *testing.T) {
|
|
t.Parallel()
|
|
client, _ := coderdenttest.New(t, &coderdenttest.Options{DontAddLicense: true})
|
|
ctx, cancel := context.WithTimeout(context.Background(), testutil.WaitLong)
|
|
defer cancel()
|
|
|
|
//nolint:gocritic // RBAC is irrelevant here.
|
|
resp, err := client.Request(ctx, http.MethodDelete, "/api/v2/licenses/drivers", nil)
|
|
require.NoError(t, err)
|
|
assert.Equal(t, http.StatusNotFound, resp.StatusCode)
|
|
require.NoError(t, resp.Body.Close())
|
|
})
|
|
|
|
t.Run("Success", func(t *testing.T) {
|
|
t.Parallel()
|
|
client, _ := coderdenttest.New(t, &coderdenttest.Options{DontAddLicense: true})
|
|
ctx, cancel := context.WithTimeout(context.Background(), testutil.WaitLong)
|
|
defer cancel()
|
|
|
|
coderdenttest.AddLicense(t, client, coderdenttest.LicenseOptions{
|
|
AccountID: "testing",
|
|
Features: license.Features{
|
|
codersdk.FeatureAuditLog: 1,
|
|
},
|
|
})
|
|
coderdenttest.AddLicense(t, client, coderdenttest.LicenseOptions{
|
|
AccountID: "testing2",
|
|
Features: license.Features{
|
|
codersdk.FeatureAuditLog: 1,
|
|
codersdk.FeatureUserLimit: 200,
|
|
},
|
|
})
|
|
|
|
licenses, err := client.Licenses(ctx)
|
|
require.NoError(t, err)
|
|
assert.Len(t, licenses, 2)
|
|
for _, l := range licenses {
|
|
err = client.DeleteLicense(ctx, l.ID)
|
|
require.NoError(t, err)
|
|
}
|
|
licenses, err = client.Licenses(ctx)
|
|
require.NoError(t, err)
|
|
assert.Len(t, licenses, 0)
|
|
})
|
|
}
|