Some checks are pending
Bidi Control Character Guard / bidi-control-guard (push) Waiting to run
Circular Dependency Check / Check for new circular dependencies (push) Waiting to run
Citus Migration Smoke / Combined migrations on single-node Citus (push) Waiting to run
E2E Fresh Install Tests / fresh-install-e2e (push) Waiting to run
ext-v2 guardrails / Run ext-v2 guard and ESLint (push) Waiting to run
Integration Tests / Check for relevant changes (push) Waiting to run
Integration Tests / ${{ (github.event_name == 'schedule' || github.event.inputs.suite == 'full') && 'Full integration suite' || 'Tier-1 integration subset' }} (push) Blocked by required conditions
Mobile checks / Mobile lint + typecheck (push) Waiting to run
Mobile checks / Mobile unit tests (push) Waiting to run
Mobile checks / Mobile dependency audit (report) (push) Waiting to run
Mobile checks / Mobile reproducibility checks (push) Waiting to run
Secrets guard (env backups) / Ensure no tracked env backup files (push) Waiting to run
Temporal Readiness / fast-readiness (push) Waiting to run
Temporal Readiness / docker-parity (push) Waiting to run
TypeScript Type Check / Nx affected typecheck (push) Waiting to run
Unit Tests / Skipped-test budget (push) Waiting to run
Unit Tests / Nx affected unit tests (push) Waiting to run
Unit Tests / Server unit coverage (informational) (push) Waiting to run
Validate Tenant Management Schema / Check for relevant changes (push) Waiting to run
Validate Tenant Management Schema / Validate Tenant Management Schema (push) Blocked by required conditions
EE Workflows Build Guard / ee-workflows-build-guard (push) Waiting to run
Excluded: .git, node_modules, secrets/, compose.env, assemblyscript tgz Source: /opt/alga-psa on psa.joliet.tech
46 lines
1.6 KiB
TypeScript
46 lines
1.6 KiB
TypeScript
import path from 'node:path';
|
|
import { Linter } from 'eslint';
|
|
import { describe, expect, it } from 'vitest';
|
|
|
|
describe('module boundary enforcement (eslint rule)', () => {
|
|
it('blocks vertical-to-vertical imports', async () => {
|
|
const { default: rule } = await import('../../eslint-plugin-custom-rules/no-feature-to-feature-imports.js');
|
|
|
|
const linter = new Linter();
|
|
linter.defineRule('custom-rules/no-feature-to-feature-imports', rule);
|
|
|
|
const messages = linter.verify(
|
|
"import '@alga-psa/billing';\nexport {};\n",
|
|
{
|
|
parserOptions: { ecmaVersion: 2020, sourceType: 'module' },
|
|
rules: { 'custom-rules/no-feature-to-feature-imports': 'error' },
|
|
},
|
|
{
|
|
filename: path.join(process.cwd(), 'packages/clients/src/__lintTmp_invalid.ts'),
|
|
}
|
|
);
|
|
|
|
expect(messages.some((m) => m.ruleId === 'custom-rules/no-feature-to-feature-imports')).toBe(true);
|
|
});
|
|
|
|
it('allows vertical-to-horizontal imports', async () => {
|
|
const { default: rule } = await import('../../eslint-plugin-custom-rules/no-feature-to-feature-imports.js');
|
|
|
|
const linter = new Linter();
|
|
linter.defineRule('custom-rules/no-feature-to-feature-imports', rule);
|
|
|
|
const messages = linter.verify(
|
|
"import '@alga-psa/types';\nexport {};\n",
|
|
{
|
|
parserOptions: { ecmaVersion: 2020, sourceType: 'module' },
|
|
rules: { 'custom-rules/no-feature-to-feature-imports': 'error' },
|
|
},
|
|
{
|
|
filename: path.join(process.cwd(), 'packages/clients/src/__lintTmp_valid.ts'),
|
|
}
|
|
);
|
|
|
|
expect(messages).toHaveLength(0);
|
|
});
|
|
});
|