@knapsack/spec-utils 4.78.9 → 4.78.10--canary.5706.50eecc2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/package.json +10 -10
- package/.turbo/turbo-build.log +0 -4
- package/.turbo/turbo-lint.log +0 -4
- package/.turbo/turbo-test.log +0 -50
- package/dist/align/align.vtest.d.ts +0 -2
- package/dist/align/align.vtest.d.ts.map +0 -1
- package/dist/align/align.vtest.js +0 -46
- package/dist/align/align.vtest.js.map +0 -1
- package/dist/analyze-exports.sandbox-components.vtest.d.ts +0 -2
- package/dist/analyze-exports.sandbox-components.vtest.d.ts.map +0 -1
- package/dist/analyze-exports.sandbox-components.vtest.js +0 -51
- package/dist/analyze-exports.sandbox-components.vtest.js.map +0 -1
- package/dist/analyze-exports.vtest.d.ts +0 -2
- package/dist/analyze-exports.vtest.d.ts.map +0 -1
- package/dist/analyze-exports.vtest.js +0 -160
- package/dist/analyze-exports.vtest.js.map +0 -1
- package/dist/convert-to-spec.vtest.d.ts +0 -2
- package/dist/convert-to-spec.vtest.d.ts.map +0 -1
- package/dist/convert-to-spec.vtest.js +0 -131
- package/dist/convert-to-spec.vtest.js.map +0 -1
- package/dist/get-ts-config.vtest.d.ts +0 -2
- package/dist/get-ts-config.vtest.d.ts.map +0 -1
- package/dist/get-ts-config.vtest.js +0 -9
- package/dist/get-ts-config.vtest.js.map +0 -1
- package/dist/resolve.vtest.d.ts +0 -2
- package/dist/resolve.vtest.d.ts.map +0 -1
- package/dist/resolve.vtest.js +0 -57
- package/dist/resolve.vtest.js.map +0 -1
- package/dist/utils.vtest.d.ts +0 -2
- package/dist/utils.vtest.d.ts.map +0 -1
- package/dist/utils.vtest.js +0 -37
- package/dist/utils.vtest.js.map +0 -1
- package/src/align/align.vtest.ts +0 -56
- package/src/align/get-exports.bench.ts +0 -28
- package/src/align/resolve.bench.ts +0 -20
- package/src/align/utils.ts +0 -14
- package/src/analyze-exports.sandbox-components.vtest.ts +0 -53
- package/src/analyze-exports.ts +0 -54
- package/src/analyze-exports.vtest.ts +0 -178
- package/src/analyze-symbol.ts +0 -213
- package/src/analyze-type.ts +0 -316
- package/src/boot.ts +0 -31
- package/src/convert-to-spec.ts +0 -196
- package/src/convert-to-spec.vtest.ts +0 -136
- package/src/get-exports.ts +0 -70
- package/src/get-ts-config.ts +0 -96
- package/src/get-ts-config.vtest.ts +0 -9
- package/src/index.ts +0 -5
- package/src/resolve.ts +0 -54
- package/src/resolve.vtest.ts +0 -69
- package/src/test-fixtures/basics.ts +0 -17
- package/src/test-fixtures/functions.ts +0 -50
- package/src/test-fixtures/index.ts +0 -2
- package/src/types.ts +0 -66
- package/src/utils.ts +0 -61
- package/src/utils.vtest.ts +0 -39
package/dist/resolve.vtest.js
DELETED
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { join } from 'node:path';
|
|
3
|
-
import { resolveTsModule } from './resolve.js';
|
|
4
|
-
describe('resolve module tests', () => {
|
|
5
|
-
it('resolves @knapsack/utils', () => {
|
|
6
|
-
const { resolvedFileName, isExternalLibraryImport } = resolveTsModule({
|
|
7
|
-
containingFile: import.meta.filename,
|
|
8
|
-
moduleName: '@knapsack/utils',
|
|
9
|
-
});
|
|
10
|
-
expect(resolvedFileName).toBeTruthy();
|
|
11
|
-
expect(resolvedFileName).toMatch(/\.d\.ts$/);
|
|
12
|
-
expect(resolvedFileName).toContain('utils/dist');
|
|
13
|
-
expect(isExternalLibraryImport).toBe(true);
|
|
14
|
-
});
|
|
15
|
-
it('resolves local ts file with .js extension', () => {
|
|
16
|
-
const { resolvedFileName } = resolveTsModule({
|
|
17
|
-
containingFile: import.meta.filename,
|
|
18
|
-
moduleName: './boot.js',
|
|
19
|
-
});
|
|
20
|
-
expect(resolvedFileName).toBe(join(import.meta.dirname, './boot.ts'));
|
|
21
|
-
});
|
|
22
|
-
it('resolves local ts file with .ts extension', () => {
|
|
23
|
-
const { resolvedFileName } = resolveTsModule({
|
|
24
|
-
containingFile: import.meta.filename,
|
|
25
|
-
moduleName: './boot.ts',
|
|
26
|
-
});
|
|
27
|
-
expect(resolvedFileName).toBe(join(import.meta.dirname, './boot.ts'));
|
|
28
|
-
});
|
|
29
|
-
it('resolves a local package.json', () => {
|
|
30
|
-
const { resolvedFileName } = resolveTsModule({
|
|
31
|
-
containingFile: import.meta.filename,
|
|
32
|
-
moduleName: '../package.json',
|
|
33
|
-
});
|
|
34
|
-
expect(resolvedFileName).toMatch(/package\.json$/);
|
|
35
|
-
expect(resolvedFileName).toBe(join(import.meta.dirname, '../package.json'));
|
|
36
|
-
});
|
|
37
|
-
it('resolves a local file', () => {
|
|
38
|
-
const { resolvedFileName } = resolveTsModule({
|
|
39
|
-
containingFile: import.meta.filename,
|
|
40
|
-
moduleName: '../.eslintrc.cjs',
|
|
41
|
-
});
|
|
42
|
-
expect(resolvedFileName).toBe(join(import.meta.dirname, '../.eslintrc.cjs'));
|
|
43
|
-
});
|
|
44
|
-
it('resolves alias of @knapsack/utils', () => {
|
|
45
|
-
const { resolvedFileName } = resolveTsModule({
|
|
46
|
-
containingFile: import.meta.filename,
|
|
47
|
-
moduleName: 'foo',
|
|
48
|
-
pkgPathAliases: {
|
|
49
|
-
foo: '@knapsack/utils',
|
|
50
|
-
},
|
|
51
|
-
});
|
|
52
|
-
expect(resolvedFileName).toBeTruthy();
|
|
53
|
-
expect(resolvedFileName).toMatch(/\.d\.ts$/);
|
|
54
|
-
expect(resolvedFileName).toContain('utils/dist');
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
|
-
//# sourceMappingURL=resolve.vtest.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"resolve.vtest.js","sourceRoot":"","sources":["../src/resolve.vtest.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;QAClC,MAAM,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,GAAG,eAAe,CAAC;YACpE,cAAc,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ;YACpC,UAAU,EAAE,iBAAiB;SAC9B,CAAC,CAAC;QAEH,MAAM,CAAC,gBAAgB,CAAC,CAAC,UAAU,EAAE,CAAC;QACtC,MAAM,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAC7C,MAAM,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;QACjD,MAAM,CAAC,uBAAuB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,EAAE,gBAAgB,EAAE,GAAG,eAAe,CAAC;YAC3C,cAAc,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ;YACpC,UAAU,EAAE,WAAW;SACxB,CAAC,CAAC;QAEH,MAAM,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,EAAE,gBAAgB,EAAE,GAAG,eAAe,CAAC;YAC3C,cAAc,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ;YACpC,UAAU,EAAE,WAAW;SACxB,CAAC,CAAC;QAEH,MAAM,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC,CAAC;IACxE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,EAAE,gBAAgB,EAAE,GAAG,eAAe,CAAC;YAC3C,cAAc,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ;YACpC,UAAU,EAAE,iBAAiB;SAC9B,CAAC,CAAC;QAEH,MAAM,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC;QACnD,MAAM,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,iBAAiB,CAAC,CAAC,CAAC;IAC9E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,uBAAuB,EAAE,GAAG,EAAE;QAC/B,MAAM,EAAE,gBAAgB,EAAE,GAAG,eAAe,CAAC;YAC3C,cAAc,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ;YACpC,UAAU,EAAE,kBAAkB;SAC/B,CAAC,CAAC;QACH,MAAM,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAC3B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,kBAAkB,CAAC,CAC9C,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC3C,MAAM,EAAE,gBAAgB,EAAE,GAAG,eAAe,CAAC;YAC3C,cAAc,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ;YACpC,UAAU,EAAE,KAAK;YACjB,cAAc,EAAE;gBACd,GAAG,EAAE,iBAAiB;aACvB;SACF,CAAC,CAAC;QAEH,MAAM,CAAC,gBAAgB,CAAC,CAAC,UAAU,EAAE,CAAC;QACtC,MAAM,CAAC,gBAAgB,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAC7C,MAAM,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
package/dist/utils.vtest.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils.vtest.d.ts","sourceRoot":"","sources":["../src/utils.vtest.ts"],"names":[],"mappings":""}
|
package/dist/utils.vtest.js
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import ts from 'typescript';
|
|
3
|
-
import { getSetFlags } from './utils.js';
|
|
4
|
-
describe('utils tests', () => {
|
|
5
|
-
it('getSetFlags single flag', () => {
|
|
6
|
-
const single = getSetFlags({
|
|
7
|
-
enumObject: ts.SymbolFlags,
|
|
8
|
-
flags: ts.SymbolFlags.Property,
|
|
9
|
-
});
|
|
10
|
-
expect(single).toEqual(['Property']);
|
|
11
|
-
});
|
|
12
|
-
it('getSetFlags multiple flags', () => {
|
|
13
|
-
const multiple = getSetFlags({
|
|
14
|
-
enumObject: ts.SymbolFlags,
|
|
15
|
-
flags:
|
|
16
|
-
// eslint-disable-next-line no-bitwise
|
|
17
|
-
ts.SymbolFlags.FunctionScopedVariable |
|
|
18
|
-
ts.SymbolFlags.BlockScopedVariable,
|
|
19
|
-
});
|
|
20
|
-
expect(multiple).toEqual([
|
|
21
|
-
'FunctionScopedVariable',
|
|
22
|
-
'BlockScopedVariable',
|
|
23
|
-
]);
|
|
24
|
-
});
|
|
25
|
-
it('single flag with multiple flags extracted', () => {
|
|
26
|
-
// an "Accessor" is both a "GetAccessor" and a "SetAccessor"
|
|
27
|
-
const single = getSetFlags({
|
|
28
|
-
enumObject: ts.SymbolFlags,
|
|
29
|
-
flags: ts.SymbolFlags.Accessor,
|
|
30
|
-
});
|
|
31
|
-
expect(single).toEqual([
|
|
32
|
-
'GetAccessor',
|
|
33
|
-
'SetAccessor',
|
|
34
|
-
]);
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
//# sourceMappingURL=utils.vtest.js.map
|
package/dist/utils.vtest.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils.vtest.js","sourceRoot":"","sources":["../src/utils.vtest.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,MAAM,YAAY,CAAC;AAC5B,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAEzC,QAAQ,CAAC,aAAa,EAAE,GAAG,EAAE;IAC3B,EAAE,CAAC,yBAAyB,EAAE,GAAG,EAAE;QACjC,MAAM,MAAM,GAAG,WAAW,CAAC;YACzB,UAAU,EAAE,EAAE,CAAC,WAAW;YAC1B,KAAK,EAAE,EAAE,CAAC,WAAW,CAAC,QAAQ;SAC/B,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,UAAU,CAAyB,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,QAAQ,GAAG,WAAW,CAAC;YAC3B,UAAU,EAAE,EAAE,CAAC,WAAW;YAC1B,KAAK;YACH,sCAAsC;YACtC,EAAE,CAAC,WAAW,CAAC,sBAAsB;gBACrC,EAAE,CAAC,WAAW,CAAC,mBAAmB;SACrC,CAAC,CAAC;QACH,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC;YACvB,wBAAwB;YACxB,qBAAqB;SACI,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,4DAA4D;QAC5D,MAAM,MAAM,GAAG,WAAW,CAAC;YACzB,UAAU,EAAE,EAAE,CAAC,WAAW;YAC1B,KAAK,EAAE,EAAE,CAAC,WAAW,CAAC,QAAQ;SAC/B,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,aAAa;YACb,aAAa;SACU,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
package/src/align/align.vtest.ts
DELETED
|
@@ -1,56 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect, assert } from 'vitest';
|
|
2
|
-
import { realpath } from 'node:fs/promises';
|
|
3
|
-
import { getJsExportNames, resolvePath } from '@knapsack/file-utils';
|
|
4
|
-
import { resolveTsModule } from '../resolve.js';
|
|
5
|
-
import { getTsExports } from '../get-exports.js';
|
|
6
|
-
import { paths } from './utils.js';
|
|
7
|
-
|
|
8
|
-
describe.for(paths)(`$path`, ({ path }) => {
|
|
9
|
-
it('resolves to same file path', async () => {
|
|
10
|
-
const { absolutePath } = await resolvePath({
|
|
11
|
-
path,
|
|
12
|
-
resolveType: 'types',
|
|
13
|
-
});
|
|
14
|
-
const { resolvedFileName } = resolveTsModule({
|
|
15
|
-
moduleName: path,
|
|
16
|
-
containingFile: import.meta.filename,
|
|
17
|
-
});
|
|
18
|
-
expect(await realpath(resolvedFileName)).toBe(await realpath(absolutePath));
|
|
19
|
-
});
|
|
20
|
-
|
|
21
|
-
it(
|
|
22
|
-
'finds same export names in ts and js',
|
|
23
|
-
{
|
|
24
|
-
timeout: 10_000,
|
|
25
|
-
},
|
|
26
|
-
async () => {
|
|
27
|
-
const { exports } = getTsExports({
|
|
28
|
-
fileName: path,
|
|
29
|
-
});
|
|
30
|
-
const exportNamesFromTs = exports.map((e) => e.getName());
|
|
31
|
-
|
|
32
|
-
const { exports: exportNamesFromJs } = await getJsExportNames({
|
|
33
|
-
path,
|
|
34
|
-
});
|
|
35
|
-
|
|
36
|
-
// the ts details will contain things like types that the js details don't
|
|
37
|
-
// this makes sure that all we found in js is also found in ts
|
|
38
|
-
const exportNamesFromJsSet = new Set(exportNamesFromJs);
|
|
39
|
-
exportNamesFromTs.forEach((e) => {
|
|
40
|
-
exportNamesFromJsSet.delete(e);
|
|
41
|
-
});
|
|
42
|
-
if (path === '@mui/material') {
|
|
43
|
-
// pulling these out b/c they fail test, but we got the other ones
|
|
44
|
-
exportNamesFromJsSet.delete('FormLabelRoot');
|
|
45
|
-
exportNamesFromJsSet.delete('private_createMixins');
|
|
46
|
-
exportNamesFromJsSet.delete('usePagination');
|
|
47
|
-
}
|
|
48
|
-
assert.isEmpty(
|
|
49
|
-
exportNamesFromJsSet,
|
|
50
|
-
`found ${exportNamesFromJsSet.size} extra exports in js: ${[
|
|
51
|
-
...exportNamesFromJsSet,
|
|
52
|
-
].join(', ')}`,
|
|
53
|
-
);
|
|
54
|
-
},
|
|
55
|
-
);
|
|
56
|
-
});
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { bench, describe } from 'vitest';
|
|
2
|
-
import { getJsExportNames } from '@knapsack/file-utils';
|
|
3
|
-
import { getTsExports } from '../get-exports.js';
|
|
4
|
-
import { paths } from './utils.js';
|
|
5
|
-
|
|
6
|
-
paths.forEach(({ path }) => {
|
|
7
|
-
describe(path, () => {
|
|
8
|
-
bench(
|
|
9
|
-
'getTsExports',
|
|
10
|
-
async () => {
|
|
11
|
-
getTsExports({
|
|
12
|
-
fileName: path,
|
|
13
|
-
});
|
|
14
|
-
},
|
|
15
|
-
{},
|
|
16
|
-
);
|
|
17
|
-
|
|
18
|
-
bench(
|
|
19
|
-
'getJsExportNames',
|
|
20
|
-
async () => {
|
|
21
|
-
await getJsExportNames({
|
|
22
|
-
path,
|
|
23
|
-
});
|
|
24
|
-
},
|
|
25
|
-
{},
|
|
26
|
-
);
|
|
27
|
-
});
|
|
28
|
-
});
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
import { describe, bench } from 'vitest';
|
|
2
|
-
import { resolvePath } from '@knapsack/file-utils';
|
|
3
|
-
import { resolveTsModule } from '../resolve.js';
|
|
4
|
-
import { paths } from './utils.js';
|
|
5
|
-
|
|
6
|
-
paths.forEach(({ path }) => {
|
|
7
|
-
describe(path, () => {
|
|
8
|
-
bench('resolveTsModule', () => {
|
|
9
|
-
resolveTsModule({
|
|
10
|
-
containingFile: import.meta.filename,
|
|
11
|
-
moduleName: path,
|
|
12
|
-
});
|
|
13
|
-
});
|
|
14
|
-
bench('resolvePath', async () => {
|
|
15
|
-
await resolvePath({
|
|
16
|
-
path,
|
|
17
|
-
});
|
|
18
|
-
});
|
|
19
|
-
});
|
|
20
|
-
});
|
package/src/align/utils.ts
DELETED
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { analyzeExports } from './analyze-exports.js';
|
|
3
|
-
import { assertTypeInfo } from './utils.js';
|
|
4
|
-
|
|
5
|
-
describe('analyze-exports sandbox components', () => {
|
|
6
|
-
it('analyzes react exports', () => {
|
|
7
|
-
const exports = analyzeExports({
|
|
8
|
-
fileName: '@knapsack/sandbox-components/react',
|
|
9
|
-
});
|
|
10
|
-
const { Button } = exports;
|
|
11
|
-
expect(Button).toBeTruthy();
|
|
12
|
-
assertTypeInfo(Button.typeInfo, 'function');
|
|
13
|
-
const { parameters } = Button.typeInfo;
|
|
14
|
-
const [props] = parameters;
|
|
15
|
-
assertTypeInfo(props.typeInfo, 'object');
|
|
16
|
-
const { properties } = props.typeInfo;
|
|
17
|
-
const { size } = properties;
|
|
18
|
-
assertTypeInfo(size.typeInfo, 'union');
|
|
19
|
-
const { items } = size.typeInfo;
|
|
20
|
-
const sizeValues = items
|
|
21
|
-
.map((item) => {
|
|
22
|
-
assertTypeInfo(item, 'stringLiteral');
|
|
23
|
-
return item.value;
|
|
24
|
-
})
|
|
25
|
-
.sort();
|
|
26
|
-
expect(sizeValues).toEqual(['large', 'medium', 'small'].sort());
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
it('analyzes angular exports', () => {
|
|
30
|
-
const exports = analyzeExports({
|
|
31
|
-
fileName: '@knapsack/angular-sandbox-components',
|
|
32
|
-
});
|
|
33
|
-
const { KsButtonComponent } = exports;
|
|
34
|
-
expect(KsButtonComponent).toBeTruthy();
|
|
35
|
-
assertTypeInfo(KsButtonComponent.typeInfo, 'class');
|
|
36
|
-
const { prototype } = KsButtonComponent.typeInfo;
|
|
37
|
-
assertTypeInfo(prototype.typeInfo, 'object');
|
|
38
|
-
const { hasArrow, click, size, handleClick } =
|
|
39
|
-
prototype.typeInfo.properties;
|
|
40
|
-
assertTypeInfo(hasArrow.typeInfo, 'boolean');
|
|
41
|
-
assertTypeInfo(handleClick.typeInfo, 'function');
|
|
42
|
-
expect(click.typeInfo.tsRawType).toBe('EventEmitter<void>');
|
|
43
|
-
assertTypeInfo(size.typeInfo, 'union');
|
|
44
|
-
const { items } = size.typeInfo;
|
|
45
|
-
const sizeValues = items
|
|
46
|
-
.map((item) => {
|
|
47
|
-
assertTypeInfo(item, 'stringLiteral');
|
|
48
|
-
return item.value;
|
|
49
|
-
})
|
|
50
|
-
.sort();
|
|
51
|
-
expect(sizeValues).toEqual(['large', 'medium', 'small'].sort());
|
|
52
|
-
});
|
|
53
|
-
});
|
package/src/analyze-exports.ts
DELETED
|
@@ -1,54 +0,0 @@
|
|
|
1
|
-
import { arrayToDictionary } from '@knapsack/utils';
|
|
2
|
-
import { analyzeSymbol } from './analyze-symbol.js';
|
|
3
|
-
import { getTsExports } from './get-exports.js';
|
|
4
|
-
|
|
5
|
-
export function analyzeExports({
|
|
6
|
-
fileName,
|
|
7
|
-
pkgPathAliases,
|
|
8
|
-
resolveFromDir,
|
|
9
|
-
}: {
|
|
10
|
-
fileName: string;
|
|
11
|
-
pkgPathAliases?: Record<string, string>;
|
|
12
|
-
resolveFromDir?: string;
|
|
13
|
-
}) {
|
|
14
|
-
const { exports, checker } = getTsExports({
|
|
15
|
-
fileName,
|
|
16
|
-
pkgPathAliases,
|
|
17
|
-
resolveFromDir,
|
|
18
|
-
});
|
|
19
|
-
return arrayToDictionary(
|
|
20
|
-
exports.map((symbol) =>
|
|
21
|
-
analyzeSymbol({
|
|
22
|
-
symbol,
|
|
23
|
-
checker,
|
|
24
|
-
}),
|
|
25
|
-
),
|
|
26
|
-
'name',
|
|
27
|
-
);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
export function analyzeExport({
|
|
31
|
-
fileName,
|
|
32
|
-
exportName,
|
|
33
|
-
pkgPathAliases,
|
|
34
|
-
resolveFromDir,
|
|
35
|
-
}: {
|
|
36
|
-
fileName: string;
|
|
37
|
-
exportName: string;
|
|
38
|
-
pkgPathAliases?: Record<string, string>;
|
|
39
|
-
resolveFromDir?: string;
|
|
40
|
-
}) {
|
|
41
|
-
const { exports, checker } = getTsExports({
|
|
42
|
-
fileName,
|
|
43
|
-
pkgPathAliases,
|
|
44
|
-
resolveFromDir,
|
|
45
|
-
});
|
|
46
|
-
const theExport = exports.find((e) => e.getName() === exportName);
|
|
47
|
-
if (!theExport) {
|
|
48
|
-
throw new Error(`Export ${exportName} not found in ${fileName}`);
|
|
49
|
-
}
|
|
50
|
-
return analyzeSymbol({
|
|
51
|
-
symbol: theExport,
|
|
52
|
-
checker,
|
|
53
|
-
});
|
|
54
|
-
}
|
|
@@ -1,178 +0,0 @@
|
|
|
1
|
-
import { describe, it, expect } from 'vitest';
|
|
2
|
-
import { join } from 'node:path';
|
|
3
|
-
import { analyzeExports } from './analyze-exports.js';
|
|
4
|
-
import { assertTypeInfo } from './utils.js';
|
|
5
|
-
|
|
6
|
-
const tsDetailsSrc = join(import.meta.dirname, '../src/test-fixtures/index.ts');
|
|
7
|
-
const tsDetailsDts = join(
|
|
8
|
-
import.meta.dirname,
|
|
9
|
-
'../dist/test-fixtures/index.d.ts',
|
|
10
|
-
);
|
|
11
|
-
|
|
12
|
-
[tsDetailsSrc, tsDetailsDts].forEach((fileName) => {
|
|
13
|
-
const ext = fileName.endsWith('.d.ts') ? '.d.ts' : '.ts';
|
|
14
|
-
const exports = analyzeExports({ fileName });
|
|
15
|
-
|
|
16
|
-
describe(`analyze-exports tests for ${ext} files`, () => {
|
|
17
|
-
it(`gets export names`, () => {
|
|
18
|
-
const results = analyzeExports({
|
|
19
|
-
fileName,
|
|
20
|
-
});
|
|
21
|
-
const exportNames = Object.keys(results);
|
|
22
|
-
expect(exportNames).toContain('complexFuncTypes');
|
|
23
|
-
expect(exportNames).toContain('doIt');
|
|
24
|
-
});
|
|
25
|
-
|
|
26
|
-
it(`handles basics: number`, () => {
|
|
27
|
-
const { typeInfo } = exports.aNumber;
|
|
28
|
-
expect(typeInfo.type).toBe('number');
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
it(`handles string union`, () => {
|
|
32
|
-
const { typeInfo } = exports.stringUnion;
|
|
33
|
-
assertTypeInfo(typeInfo, 'union');
|
|
34
|
-
const { items } = typeInfo;
|
|
35
|
-
const sizes = items.map((item) => {
|
|
36
|
-
if (item.type !== 'stringLiteral') {
|
|
37
|
-
throw new Error(
|
|
38
|
-
`Expected type to be stringLiteral, got ${item.type}`,
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
return item.value;
|
|
42
|
-
});
|
|
43
|
-
expect(sizes).toEqual(['small', 'medium', 'large']);
|
|
44
|
-
});
|
|
45
|
-
|
|
46
|
-
it(`handles string via type alias`, () => {
|
|
47
|
-
const { typeInfo } = exports.stringViaTypeAlias;
|
|
48
|
-
expect(typeInfo.type).toBe('string');
|
|
49
|
-
});
|
|
50
|
-
|
|
51
|
-
it(`handles jsdoc`, () => {
|
|
52
|
-
const { jsDoc } = exports.complexFuncTypes;
|
|
53
|
-
if (!jsDoc) {
|
|
54
|
-
throw new Error('jsDoc is undefined');
|
|
55
|
-
}
|
|
56
|
-
expect(jsDoc.description).toBe('Some basic types');
|
|
57
|
-
expect(jsDoc.jsDocTags.length).toBe(1);
|
|
58
|
-
expect(jsDoc.jsDocTags).toEqual([
|
|
59
|
-
{ name: 'link', text: 'https://www.example.com' },
|
|
60
|
-
] satisfies typeof jsDoc.jsDocTags);
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
it(`handles basics: string[]`, () => {
|
|
64
|
-
const { typeInfo } = exports.anArrayOfStrings;
|
|
65
|
-
assertTypeInfo(typeInfo, 'array');
|
|
66
|
-
expect(typeInfo.items.type).toBe('string');
|
|
67
|
-
expect(typeInfo.tsRawType).toBe('string[]');
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
it(`handles basics: object`, () => {
|
|
71
|
-
const { typeInfo } = exports.anObject;
|
|
72
|
-
assertTypeInfo(typeInfo, 'object');
|
|
73
|
-
const {
|
|
74
|
-
properties: { a, b, c },
|
|
75
|
-
} = typeInfo;
|
|
76
|
-
expect(a.typeInfo.type).toBe('number');
|
|
77
|
-
expect(b.typeInfo.type).toBe('string');
|
|
78
|
-
assertTypeInfo(c.typeInfo, 'array');
|
|
79
|
-
expect(c.typeInfo.items.type).toBe('string');
|
|
80
|
-
expect(c.typeInfo.tsRawType).toBe('string[]');
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
it(`handles function with basic parameters`, () => {
|
|
84
|
-
const { typeInfo } = exports.aFunction;
|
|
85
|
-
assertTypeInfo(typeInfo, 'function');
|
|
86
|
-
const { parameters, returnType, tsRawType } = typeInfo;
|
|
87
|
-
if (!returnType) {
|
|
88
|
-
throw new Error('returnType is undefined');
|
|
89
|
-
}
|
|
90
|
-
const [param] = parameters;
|
|
91
|
-
expect(tsRawType).toBe('(a: number) => number');
|
|
92
|
-
expect(param.name).toBe('a');
|
|
93
|
-
expect(param.typeInfo.type).toBe('number');
|
|
94
|
-
expect(returnType.type).toBe('number');
|
|
95
|
-
});
|
|
96
|
-
|
|
97
|
-
it(`handles async function with basic parameters`, () => {
|
|
98
|
-
const { typeInfo } = exports.asyncFunction;
|
|
99
|
-
assertTypeInfo(typeInfo, 'function');
|
|
100
|
-
const { parameters, returnType, tsRawType } = typeInfo;
|
|
101
|
-
if (!returnType) {
|
|
102
|
-
throw new Error('returnType is undefined');
|
|
103
|
-
}
|
|
104
|
-
const [param] = parameters;
|
|
105
|
-
expect(param.name).toBe('a');
|
|
106
|
-
expect(param.typeInfo.type).toBe('number');
|
|
107
|
-
expect(tsRawType).toBe('(a: number) => Promise<number>');
|
|
108
|
-
expect(returnType.type).toBe('misc');
|
|
109
|
-
});
|
|
110
|
-
|
|
111
|
-
it(`handles function with complex parameters`, () => {
|
|
112
|
-
const { typeInfo } = exports.complexFuncTypes;
|
|
113
|
-
assertTypeInfo(typeInfo, 'function');
|
|
114
|
-
const [param] = typeInfo.parameters;
|
|
115
|
-
expect(param.name).toBe('obj');
|
|
116
|
-
assertTypeInfo(param.typeInfo, 'object');
|
|
117
|
-
const { properties } = param.typeInfo;
|
|
118
|
-
Object.entries(properties).forEach(([key, { typeInfo: propInfo }]) => {
|
|
119
|
-
switch (key) {
|
|
120
|
-
case 'aString': {
|
|
121
|
-
expect(propInfo.type).toBe('string');
|
|
122
|
-
expect(propInfo.isOptional).toBe(false);
|
|
123
|
-
break;
|
|
124
|
-
}
|
|
125
|
-
case 'anOptionalString': {
|
|
126
|
-
expect(propInfo.type).toBe('string');
|
|
127
|
-
expect(propInfo.isOptional).toBe(true);
|
|
128
|
-
break;
|
|
129
|
-
}
|
|
130
|
-
case 'aBoolean': {
|
|
131
|
-
expect(propInfo.type).toBe('boolean');
|
|
132
|
-
expect(propInfo.isOptional).toBe(false);
|
|
133
|
-
break;
|
|
134
|
-
}
|
|
135
|
-
case 'someSizes': {
|
|
136
|
-
assertTypeInfo(propInfo, 'union');
|
|
137
|
-
const sizes = propInfo.items.map((item) => {
|
|
138
|
-
assertTypeInfo(item, 'stringLiteral');
|
|
139
|
-
return item.value;
|
|
140
|
-
});
|
|
141
|
-
expect(sizes).toEqual(['small', 'medium', 'large']);
|
|
142
|
-
break;
|
|
143
|
-
}
|
|
144
|
-
case 'anArray': {
|
|
145
|
-
assertTypeInfo(propInfo, 'array');
|
|
146
|
-
expect(propInfo.items.type).toBe('string');
|
|
147
|
-
break;
|
|
148
|
-
}
|
|
149
|
-
case 'aFunc': {
|
|
150
|
-
assertTypeInfo(propInfo, 'function');
|
|
151
|
-
const { parameters, returnType } = propInfo;
|
|
152
|
-
if (!returnType) {
|
|
153
|
-
throw new Error('returnType is undefined');
|
|
154
|
-
}
|
|
155
|
-
const [p] = parameters;
|
|
156
|
-
expect(p.name).toBe('a');
|
|
157
|
-
expect(p.typeInfo.type).toBe('string');
|
|
158
|
-
expect(returnType.type).toBe('string');
|
|
159
|
-
break;
|
|
160
|
-
}
|
|
161
|
-
case 'anotherFunc': {
|
|
162
|
-
assertTypeInfo(propInfo, 'function');
|
|
163
|
-
const { parameters } = propInfo;
|
|
164
|
-
const [p] = parameters;
|
|
165
|
-
expect(p.name).toBe('opt');
|
|
166
|
-
assertTypeInfo(p.typeInfo, 'object');
|
|
167
|
-
const { onFoo } = p.typeInfo.properties;
|
|
168
|
-
assertTypeInfo(onFoo.typeInfo, 'function');
|
|
169
|
-
const [onFooParam] = onFoo.typeInfo.parameters;
|
|
170
|
-
expect(onFooParam.name).toBe('a');
|
|
171
|
-
expect(onFooParam.typeInfo.type).toBe('string');
|
|
172
|
-
break;
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
});
|
|
176
|
-
});
|
|
177
|
-
});
|
|
178
|
-
});
|