mirror of
https://github.com/fleetdm/fleet
synced 2026-05-20 15:38:39 +00:00
<!-- Add the related story/sub-task/bug number, like Resolves #123, or remove if NA --> **Related issue:** Resolves #37244 # Checklist for submitter If some of the following don't apply, delete the relevant line. - [x] Changes file added for user-visible changes in `changes/`, `orbit/changes/` or `ee/fleetd-chrome/changes`. See [Changes files](https://github.com/fleetdm/fleet/blob/main/docs/Contributing/guides/committing-changes.md#changes-files) for more information. ## Testing - [x] QA'd all new/changed functionality manually <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit * **Refactor** * Internal MySQL utility package reorganized and all internal imports updated to the new platform location; no changes to end-user functionality or behavior. * **Documentation** * Added platform package documentation describing infrastructure responsibilities and architectural boundaries to guide maintainers. <sub>✏️ Tip: You can customize this high-level summary in your review settings.</sub> <!-- end of auto-generated comment: release notes by coderabbit.ai -->
110 lines
3 KiB
Go
110 lines
3 KiB
Go
package platform_test
|
|
|
|
import (
|
|
"regexp"
|
|
"testing"
|
|
|
|
"github.com/fleetdm/fleet/v4/server/archtest"
|
|
)
|
|
|
|
const m = archtest.ModuleName
|
|
|
|
// TestPlatformPackageDependencies checks that platform packages are NOT dependent on Fleet domain packages
|
|
// to maintain decoupling and modularity. This is a catch-all test.
|
|
func TestPlatformPackageDependencies(t *testing.T) {
|
|
t.Parallel()
|
|
archtest.NewPackageTest(t, m+"/server/platform...").
|
|
OnlyInclude(regexp.MustCompile(`^github\.com/fleetdm/`)).
|
|
WithTests().
|
|
ShouldNotDependOn(m+"/...").
|
|
IgnoreDeps(
|
|
// Platform packages can depend on each other
|
|
m+"/server/platform...",
|
|
// Infra packages
|
|
m+"/server/contexts/authz",
|
|
m+"/server/contexts/ctxerr",
|
|
m+"/server/contexts/license",
|
|
m+"/server/contexts/logging",
|
|
m+"/server/contexts/publicip",
|
|
).
|
|
Check()
|
|
}
|
|
|
|
// TestEndpointerPackageDependencies checks that endpointer package is not dependent on other Fleet domain packages
|
|
// to maintain decoupling and modularity.
|
|
func TestEndpointerPackageDependencies(t *testing.T) {
|
|
t.Parallel()
|
|
archtest.NewPackageTest(t, m+"/server/platform/endpointer").
|
|
OnlyInclude(regexp.MustCompile(`^github\.com/fleetdm/`)).
|
|
WithTests().
|
|
ShouldNotDependOn(m+"/...").
|
|
IgnoreDeps(
|
|
// Platform packages
|
|
m+"/server/platform...",
|
|
// Other infra packages
|
|
m+"/server/contexts/authz",
|
|
m+"/server/contexts/ctxerr",
|
|
m+"/server/contexts/license",
|
|
m+"/server/contexts/logging",
|
|
m+"/server/contexts/publicip",
|
|
).
|
|
Check()
|
|
}
|
|
|
|
func TestHTTPPackageDependencies(t *testing.T) {
|
|
t.Parallel()
|
|
archtest.NewPackageTest(t, m+"/server/platform/http").
|
|
OnlyInclude(regexp.MustCompile(`^github\.com/fleetdm/`)).
|
|
WithTests().
|
|
ShouldNotDependOn(m + "/...").
|
|
Check()
|
|
}
|
|
|
|
func TestAuthzCheckPackageDependencies(t *testing.T) {
|
|
t.Parallel()
|
|
archtest.NewPackageTest(t, m+"/server/platform/middleware/authzcheck").
|
|
OnlyInclude(regexp.MustCompile(`^github\.com/fleetdm/`)).
|
|
WithTests().
|
|
IgnoreDeps(
|
|
// Platform packages
|
|
m+"/server/platform/http",
|
|
// Other infra packages
|
|
m+"/server/contexts/authz",
|
|
).
|
|
Check()
|
|
}
|
|
|
|
func TestRatelimitPackageDependencies(t *testing.T) {
|
|
t.Parallel()
|
|
archtest.NewPackageTest(t, m+"/server/platform/middleware/ratelimit").
|
|
OnlyInclude(regexp.MustCompile(`^github\.com/fleetdm/`)).
|
|
WithTests().
|
|
ShouldNotDependOn(m+"/...").
|
|
IgnoreDeps(
|
|
// Platform packages
|
|
m+"/server/platform/http",
|
|
// Other infra packages
|
|
m+"/server/contexts/authz",
|
|
m+"/server/contexts/ctxerr",
|
|
m+"/server/contexts/publicip",
|
|
).
|
|
Check()
|
|
}
|
|
|
|
// TestMysqlPackageDependencies checks that mysql package is not dependent on other Fleet domain packages
|
|
// to maintain decoupling and modularity.
|
|
func TestMysqlPackageDependencies(t *testing.T) {
|
|
t.Parallel()
|
|
archtest.NewPackageTest(t, m+"/server/platform/mysql...").
|
|
OnlyInclude(regexp.MustCompile(`^github\.com/fleetdm/`)).
|
|
WithTests().
|
|
ShouldNotDependOn(m+"/...").
|
|
IgnoreDeps(
|
|
// Ignore our own packages
|
|
m+"/server/platform/mysql...",
|
|
// Other infra packages
|
|
m+"/server/platform/http",
|
|
m+"/server/contexts/ctxerr",
|
|
).
|
|
Check()
|
|
}
|