@zenstackhq/testtools 3.0.0-alpha.2 → 3.0.0-alpha.20

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/dist/index.cjs CHANGED
@@ -31,51 +31,21 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
31
31
  // src/index.ts
32
32
  var src_exports = {};
33
33
  __export(src_exports, {
34
+ createTestProject: () => createTestProject,
34
35
  generateTsSchema: () => generateTsSchema,
35
- generateTsSchemaFromFile: () => generateTsSchemaFromFile
36
+ generateTsSchemaFromFile: () => generateTsSchemaFromFile,
37
+ generateTsSchemaInPlace: () => generateTsSchemaInPlace
36
38
  });
37
39
  module.exports = __toCommonJS(src_exports);
38
40
 
39
- // src/schema.ts
40
- var import_sdk = require("@zenstackhq/sdk");
41
- var import_glob = require("glob");
42
- var import_node_child_process = require("child_process");
41
+ // src/project.ts
43
42
  var import_node_fs = __toESM(require("fs"), 1);
44
43
  var import_node_path = __toESM(require("path"), 1);
45
44
  var import_tmp = __toESM(require("tmp"), 1);
46
- var import_ts_pattern = require("ts-pattern");
47
- function makePrelude(provider, dbName) {
48
- return (0, import_ts_pattern.match)(provider).with("sqlite", () => {
49
- return `
50
- datasource db {
51
- provider = 'sqlite'
52
- url = '${dbName ?? ":memory:"}'
53
- }
54
- `;
55
- }).with("postgresql", () => {
56
- return `
57
- datasource db {
58
- provider = 'postgresql'
59
- url = 'postgres://postgres:postgres@localhost:5432/${dbName}'
60
- }
61
- `;
62
- }).exhaustive();
63
- }
64
- __name(makePrelude, "makePrelude");
65
- async function generateTsSchema(schemaText, provider = "sqlite", dbName) {
45
+ function createTestProject() {
66
46
  const { name: workDir } = import_tmp.default.dirSync({
67
47
  unsafeCleanup: true
68
48
  });
69
- console.log(`Working directory: ${workDir}`);
70
- const zmodelPath = import_node_path.default.join(workDir, "schema.zmodel");
71
- const noPrelude = schemaText.includes("datasource ");
72
- import_node_fs.default.writeFileSync(zmodelPath, `${noPrelude ? "" : makePrelude(provider, dbName)}
73
-
74
- ${schemaText}`);
75
- const pluginModelFiles = import_glob.glob.sync(import_node_path.default.resolve(__dirname, "../../runtime/src/plugins/**/plugin.zmodel"));
76
- const generator = new import_sdk.TsSchemaGenerator();
77
- const tsPath = import_node_path.default.join(workDir, "schema.ts");
78
- await generator.generate(zmodelPath, pluginModelFiles, tsPath);
79
49
  import_node_fs.default.mkdirSync(import_node_path.default.join(workDir, "node_modules"));
80
50
  const nodeModules = import_node_fs.default.readdirSync(import_node_path.default.join(__dirname, "../node_modules"));
81
51
  for (const entry of nodeModules) {
@@ -87,45 +57,112 @@ ${schemaText}`);
87
57
  const zenstackPackages = [
88
58
  "language",
89
59
  "sdk",
90
- "runtime"
60
+ "runtime",
61
+ "cli"
91
62
  ];
92
63
  import_node_fs.default.mkdirSync(import_node_path.default.join(workDir, "node_modules/@zenstackhq"));
93
64
  for (const pkg of zenstackPackages) {
94
- import_node_fs.default.symlinkSync(import_node_path.default.join(__dirname, `../../${pkg}/dist`), import_node_path.default.join(workDir, `node_modules/@zenstackhq/${pkg}`), "dir");
65
+ import_node_fs.default.symlinkSync(import_node_path.default.join(__dirname, `../../${pkg}`), import_node_path.default.join(workDir, `node_modules/@zenstackhq/${pkg}`), "dir");
95
66
  }
96
67
  import_node_fs.default.writeFileSync(import_node_path.default.join(workDir, "package.json"), JSON.stringify({
97
68
  name: "test",
98
69
  version: "1.0.0",
99
70
  type: "module"
100
- }));
71
+ }, null, 4));
101
72
  import_node_fs.default.writeFileSync(import_node_path.default.join(workDir, "tsconfig.json"), JSON.stringify({
102
73
  compilerOptions: {
103
74
  module: "ESNext",
104
75
  target: "ESNext",
105
76
  moduleResolution: "Bundler",
106
77
  esModuleInterop: true,
107
- skipLibCheck: true
78
+ skipLibCheck: true,
79
+ strict: true
80
+ },
81
+ include: [
82
+ "**/*.ts"
83
+ ]
84
+ }, null, 4));
85
+ return workDir;
86
+ }
87
+ __name(createTestProject, "createTestProject");
88
+
89
+ // src/schema.ts
90
+ var import_sdk = require("@zenstackhq/sdk");
91
+ var import_glob = require("glob");
92
+ var import_node_child_process = require("child_process");
93
+ var import_node_fs2 = __toESM(require("fs"), 1);
94
+ var import_node_path2 = __toESM(require("path"), 1);
95
+ var import_ts_pattern = require("ts-pattern");
96
+ function makePrelude(provider, dbUrl) {
97
+ return (0, import_ts_pattern.match)(provider).with("sqlite", () => {
98
+ return `
99
+ datasource db {
100
+ provider = 'sqlite'
101
+ url = '${dbUrl ?? "file:./test.db"}'
102
+ }
103
+ `;
104
+ }).with("postgresql", () => {
105
+ return `
106
+ datasource db {
107
+ provider = 'postgresql'
108
+ url = '${dbUrl ?? "postgres://postgres:postgres@localhost:5432/db"}'
109
+ }
110
+ `;
111
+ }).exhaustive();
112
+ }
113
+ __name(makePrelude, "makePrelude");
114
+ async function generateTsSchema(schemaText, provider = "sqlite", dbUrl, extraSourceFiles) {
115
+ const workDir = createTestProject();
116
+ const zmodelPath = import_node_path2.default.join(workDir, "schema.zmodel");
117
+ const noPrelude = schemaText.includes("datasource ");
118
+ import_node_fs2.default.writeFileSync(zmodelPath, `${noPrelude ? "" : makePrelude(provider, dbUrl)}
119
+
120
+ ${schemaText}`);
121
+ const pluginModelFiles = import_glob.glob.sync(import_node_path2.default.resolve(__dirname, "../../runtime/src/plugins/**/plugin.zmodel"));
122
+ const generator = new import_sdk.TsSchemaGenerator();
123
+ await generator.generate(zmodelPath, pluginModelFiles, workDir);
124
+ if (extraSourceFiles) {
125
+ for (const [fileName, content] of Object.entries(extraSourceFiles)) {
126
+ const filePath = import_node_path2.default.resolve(workDir, `${fileName}.ts`);
127
+ import_node_fs2.default.mkdirSync(import_node_path2.default.dirname(filePath), {
128
+ recursive: true
129
+ });
130
+ import_node_fs2.default.writeFileSync(filePath, content);
108
131
  }
109
- }));
132
+ }
133
+ return compileAndLoad(workDir);
134
+ }
135
+ __name(generateTsSchema, "generateTsSchema");
136
+ async function compileAndLoad(workDir) {
110
137
  (0, import_node_child_process.execSync)("npx tsc", {
111
138
  cwd: workDir,
112
139
  stdio: "inherit"
113
140
  });
114
- const module2 = await import(import_node_path.default.join(workDir, "schema.js"));
141
+ const module2 = await import(import_node_path2.default.join(workDir, "schema.js"));
115
142
  return {
116
143
  workDir,
117
144
  schema: module2.schema
118
145
  };
119
146
  }
120
- __name(generateTsSchema, "generateTsSchema");
147
+ __name(compileAndLoad, "compileAndLoad");
121
148
  function generateTsSchemaFromFile(filePath) {
122
- const schemaText = import_node_fs.default.readFileSync(filePath, "utf8");
149
+ const schemaText = import_node_fs2.default.readFileSync(filePath, "utf8");
123
150
  return generateTsSchema(schemaText);
124
151
  }
125
152
  __name(generateTsSchemaFromFile, "generateTsSchemaFromFile");
153
+ async function generateTsSchemaInPlace(schemaPath) {
154
+ const workDir = import_node_path2.default.dirname(schemaPath);
155
+ const pluginModelFiles = import_glob.glob.sync(import_node_path2.default.resolve(__dirname, "../../runtime/src/plugins/**/plugin.zmodel"));
156
+ const generator = new import_sdk.TsSchemaGenerator();
157
+ await generator.generate(schemaPath, pluginModelFiles, workDir);
158
+ return compileAndLoad(workDir);
159
+ }
160
+ __name(generateTsSchemaInPlace, "generateTsSchemaInPlace");
126
161
  // Annotate the CommonJS export names for ESM import in node:
127
162
  0 && (module.exports = {
163
+ createTestProject,
128
164
  generateTsSchema,
129
- generateTsSchemaFromFile
165
+ generateTsSchemaFromFile,
166
+ generateTsSchemaInPlace
130
167
  });
131
168
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts","../src/schema.ts"],"sourcesContent":["export * from './schema';\n","import { TsSchemaGenerator } from '@zenstackhq/sdk';\nimport type { SchemaDef } from '@zenstackhq/sdk/schema';\nimport { glob } from 'glob';\nimport { execSync } from 'node:child_process';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport tmp from 'tmp';\nimport { match } from 'ts-pattern';\n\nfunction makePrelude(provider: 'sqlite' | 'postgresql', dbName?: string) {\n return match(provider)\n .with('sqlite', () => {\n return `\ndatasource db {\n provider = 'sqlite'\n url = '${dbName ?? ':memory:'}'\n}\n`;\n })\n .with('postgresql', () => {\n return `\ndatasource db {\n provider = 'postgresql'\n url = 'postgres://postgres:postgres@localhost:5432/${dbName}'\n}\n`;\n })\n .exhaustive();\n}\n\nexport async function generateTsSchema(\n schemaText: string,\n provider: 'sqlite' | 'postgresql' = 'sqlite',\n dbName?: string\n) {\n const { name: workDir } = tmp.dirSync({ unsafeCleanup: true });\n console.log(`Working directory: ${workDir}`);\n\n const zmodelPath = path.join(workDir, 'schema.zmodel');\n const noPrelude = schemaText.includes('datasource ');\n fs.writeFileSync(\n zmodelPath,\n `${noPrelude ? '' : makePrelude(provider, dbName)}\\n\\n${schemaText}`\n );\n\n const pluginModelFiles = glob.sync(\n path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel')\n );\n\n const generator = new TsSchemaGenerator();\n const tsPath = path.join(workDir, 'schema.ts');\n await generator.generate(zmodelPath, pluginModelFiles, tsPath);\n\n fs.mkdirSync(path.join(workDir, 'node_modules'));\n\n // symlink all entries from \"node_modules\"\n const nodeModules = fs.readdirSync(path.join(__dirname, '../node_modules'));\n for (const entry of nodeModules) {\n if (entry.startsWith('@zenstackhq')) {\n continue;\n }\n fs.symlinkSync(\n path.join(__dirname, '../node_modules', entry),\n path.join(workDir, 'node_modules', entry),\n 'dir'\n );\n }\n\n // in addition, symlink zenstack packages\n const zenstackPackages = ['language', 'sdk', 'runtime'];\n fs.mkdirSync(path.join(workDir, 'node_modules/@zenstackhq'));\n for (const pkg of zenstackPackages) {\n fs.symlinkSync(\n path.join(__dirname, `../../${pkg}/dist`),\n path.join(workDir, `node_modules/@zenstackhq/${pkg}`),\n 'dir'\n );\n }\n\n fs.writeFileSync(\n path.join(workDir, 'package.json'),\n JSON.stringify({\n name: 'test',\n version: '1.0.0',\n type: 'module',\n })\n );\n\n fs.writeFileSync(\n path.join(workDir, 'tsconfig.json'),\n JSON.stringify({\n compilerOptions: {\n module: 'ESNext',\n target: 'ESNext',\n moduleResolution: 'Bundler',\n esModuleInterop: true,\n skipLibCheck: true,\n },\n })\n );\n\n // compile the generated TS schema\n execSync('npx tsc', {\n cwd: workDir,\n stdio: 'inherit',\n });\n\n // load the schema module\n const module = await import(path.join(workDir, 'schema.js'));\n return { workDir, schema: module.schema as SchemaDef };\n}\n\nexport function generateTsSchemaFromFile(filePath: string) {\n const schemaText = fs.readFileSync(filePath, 'utf8');\n return generateTsSchema(schemaText);\n}\n"],"mappings":"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","names":["makePrelude","provider","dbName","match","with","exhaustive","generateTsSchema","schemaText","name","workDir","tmp","dirSync","unsafeCleanup","console","log","zmodelPath","path","join","noPrelude","includes","fs","writeFileSync","pluginModelFiles","glob","sync","resolve","__dirname","generator","TsSchemaGenerator","tsPath","generate","mkdirSync","nodeModules","readdirSync","entry","startsWith","symlinkSync","zenstackPackages","pkg","JSON","stringify","version","type","compilerOptions","module","target","moduleResolution","esModuleInterop","skipLibCheck","execSync","cwd","stdio","schema","generateTsSchemaFromFile","filePath","readFileSync"]}
1
+ {"version":3,"sources":["../src/index.ts","../src/project.ts","../src/schema.ts"],"sourcesContent":["export * from './project';\nexport * from './schema';\n","import fs from 'node:fs';\nimport path from 'node:path';\nimport tmp from 'tmp';\n\nexport function createTestProject() {\n const { name: workDir } = tmp.dirSync({ unsafeCleanup: true });\n\n fs.mkdirSync(path.join(workDir, 'node_modules'));\n\n // symlink all entries from \"node_modules\"\n const nodeModules = fs.readdirSync(path.join(__dirname, '../node_modules'));\n for (const entry of nodeModules) {\n if (entry.startsWith('@zenstackhq')) {\n continue;\n }\n fs.symlinkSync(\n path.join(__dirname, '../node_modules', entry),\n path.join(workDir, 'node_modules', entry),\n 'dir',\n );\n }\n\n // in addition, symlink zenstack packages\n const zenstackPackages = ['language', 'sdk', 'runtime', 'cli'];\n fs.mkdirSync(path.join(workDir, 'node_modules/@zenstackhq'));\n for (const pkg of zenstackPackages) {\n fs.symlinkSync(\n path.join(__dirname, `../../${pkg}`),\n path.join(workDir, `node_modules/@zenstackhq/${pkg}`),\n 'dir',\n );\n }\n\n fs.writeFileSync(\n path.join(workDir, 'package.json'),\n JSON.stringify(\n {\n name: 'test',\n version: '1.0.0',\n type: 'module',\n },\n null,\n 4,\n ),\n );\n\n fs.writeFileSync(\n path.join(workDir, 'tsconfig.json'),\n JSON.stringify(\n {\n compilerOptions: {\n module: 'ESNext',\n target: 'ESNext',\n moduleResolution: 'Bundler',\n esModuleInterop: true,\n skipLibCheck: true,\n strict: true,\n },\n include: ['**/*.ts'],\n },\n null,\n 4,\n ),\n );\n\n return workDir;\n}\n","import { TsSchemaGenerator } from '@zenstackhq/sdk';\nimport type { SchemaDef } from '@zenstackhq/sdk/schema';\nimport { glob } from 'glob';\nimport { execSync } from 'node:child_process';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { match } from 'ts-pattern';\nimport { createTestProject } from './project';\n\nfunction makePrelude(provider: 'sqlite' | 'postgresql', dbUrl?: string) {\n return match(provider)\n .with('sqlite', () => {\n return `\ndatasource db {\n provider = 'sqlite'\n url = '${dbUrl ?? 'file:./test.db'}'\n}\n`;\n })\n .with('postgresql', () => {\n return `\ndatasource db {\n provider = 'postgresql'\n url = '${dbUrl ?? 'postgres://postgres:postgres@localhost:5432/db'}'\n}\n`;\n })\n .exhaustive();\n}\n\nexport async function generateTsSchema(\n schemaText: string,\n provider: 'sqlite' | 'postgresql' = 'sqlite',\n dbUrl?: string,\n extraSourceFiles?: Record<string, string>,\n) {\n const workDir = createTestProject();\n\n const zmodelPath = path.join(workDir, 'schema.zmodel');\n const noPrelude = schemaText.includes('datasource ');\n fs.writeFileSync(zmodelPath, `${noPrelude ? '' : makePrelude(provider, dbUrl)}\\n\\n${schemaText}`);\n\n const pluginModelFiles = glob.sync(path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel'));\n\n const generator = new TsSchemaGenerator();\n await generator.generate(zmodelPath, pluginModelFiles, workDir);\n\n if (extraSourceFiles) {\n for (const [fileName, content] of Object.entries(extraSourceFiles)) {\n const filePath = path.resolve(workDir, `${fileName}.ts`);\n fs.mkdirSync(path.dirname(filePath), { recursive: true });\n fs.writeFileSync(filePath, content);\n }\n }\n\n // compile the generated TS schema\n return compileAndLoad(workDir);\n}\n\nasync function compileAndLoad(workDir: string) {\n execSync('npx tsc', {\n cwd: workDir,\n stdio: 'inherit',\n });\n\n // load the schema module\n const module = await import(path.join(workDir, 'schema.js'));\n return { workDir, schema: module.schema as SchemaDef };\n}\n\nexport function generateTsSchemaFromFile(filePath: string) {\n const schemaText = fs.readFileSync(filePath, 'utf8');\n return generateTsSchema(schemaText);\n}\n\nexport async function generateTsSchemaInPlace(schemaPath: string) {\n const workDir = path.dirname(schemaPath);\n const pluginModelFiles = glob.sync(path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel'));\n\n const generator = new TsSchemaGenerator();\n await generator.generate(schemaPath, pluginModelFiles, workDir);\n return compileAndLoad(workDir);\n}\n"],"mappings":"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","names":["createTestProject","name","workDir","tmp","dirSync","unsafeCleanup","fs","mkdirSync","path","join","nodeModules","readdirSync","__dirname","entry","startsWith","symlinkSync","zenstackPackages","pkg","writeFileSync","JSON","stringify","version","type","compilerOptions","module","target","moduleResolution","esModuleInterop","skipLibCheck","strict","include","import_node_fs","import_node_path","makePrelude","provider","dbUrl","match","with","exhaustive","generateTsSchema","schemaText","extraSourceFiles","workDir","createTestProject","zmodelPath","path","join","noPrelude","includes","fs","writeFileSync","pluginModelFiles","glob","sync","resolve","__dirname","generator","TsSchemaGenerator","generate","fileName","content","Object","entries","filePath","mkdirSync","dirname","recursive","compileAndLoad","execSync","cwd","stdio","module","schema","generateTsSchemaFromFile","readFileSync","generateTsSchemaInPlace","schemaPath"]}
package/dist/index.d.cts CHANGED
@@ -1,6 +1,8 @@
1
1
  import { SchemaDef } from '@zenstackhq/sdk/schema';
2
2
 
3
- declare function generateTsSchema(schemaText: string, provider?: 'sqlite' | 'postgresql', dbName?: string): Promise<{
3
+ declare function createTestProject(): string;
4
+
5
+ declare function generateTsSchema(schemaText: string, provider?: 'sqlite' | 'postgresql', dbUrl?: string, extraSourceFiles?: Record<string, string>): Promise<{
4
6
  workDir: string;
5
7
  schema: SchemaDef;
6
8
  }>;
@@ -8,5 +10,9 @@ declare function generateTsSchemaFromFile(filePath: string): Promise<{
8
10
  workDir: string;
9
11
  schema: SchemaDef;
10
12
  }>;
13
+ declare function generateTsSchemaInPlace(schemaPath: string): Promise<{
14
+ workDir: string;
15
+ schema: SchemaDef;
16
+ }>;
11
17
 
12
- export { generateTsSchema, generateTsSchemaFromFile };
18
+ export { createTestProject, generateTsSchema, generateTsSchemaFromFile, generateTsSchemaInPlace };
package/dist/index.d.ts CHANGED
@@ -1,6 +1,8 @@
1
1
  import { SchemaDef } from '@zenstackhq/sdk/schema';
2
2
 
3
- declare function generateTsSchema(schemaText: string, provider?: 'sqlite' | 'postgresql', dbName?: string): Promise<{
3
+ declare function createTestProject(): string;
4
+
5
+ declare function generateTsSchema(schemaText: string, provider?: 'sqlite' | 'postgresql', dbUrl?: string, extraSourceFiles?: Record<string, string>): Promise<{
4
6
  workDir: string;
5
7
  schema: SchemaDef;
6
8
  }>;
@@ -8,5 +10,9 @@ declare function generateTsSchemaFromFile(filePath: string): Promise<{
8
10
  workDir: string;
9
11
  schema: SchemaDef;
10
12
  }>;
13
+ declare function generateTsSchemaInPlace(schemaPath: string): Promise<{
14
+ workDir: string;
15
+ schema: SchemaDef;
16
+ }>;
11
17
 
12
- export { generateTsSchema, generateTsSchemaFromFile };
18
+ export { createTestProject, generateTsSchema, generateTsSchemaFromFile, generateTsSchemaInPlace };
package/dist/index.js CHANGED
@@ -1,46 +1,14 @@
1
1
  var __defProp = Object.defineProperty;
2
2
  var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
3
 
4
- // src/schema.ts
5
- import { TsSchemaGenerator } from "@zenstackhq/sdk";
6
- import { glob } from "glob";
7
- import { execSync } from "node:child_process";
8
- import fs from "node:fs";
9
- import path from "node:path";
4
+ // src/project.ts
5
+ import fs from "fs";
6
+ import path from "path";
10
7
  import tmp from "tmp";
11
- import { match } from "ts-pattern";
12
- function makePrelude(provider, dbName) {
13
- return match(provider).with("sqlite", () => {
14
- return `
15
- datasource db {
16
- provider = 'sqlite'
17
- url = '${dbName ?? ":memory:"}'
18
- }
19
- `;
20
- }).with("postgresql", () => {
21
- return `
22
- datasource db {
23
- provider = 'postgresql'
24
- url = 'postgres://postgres:postgres@localhost:5432/${dbName}'
25
- }
26
- `;
27
- }).exhaustive();
28
- }
29
- __name(makePrelude, "makePrelude");
30
- async function generateTsSchema(schemaText, provider = "sqlite", dbName) {
8
+ function createTestProject() {
31
9
  const { name: workDir } = tmp.dirSync({
32
10
  unsafeCleanup: true
33
11
  });
34
- console.log(`Working directory: ${workDir}`);
35
- const zmodelPath = path.join(workDir, "schema.zmodel");
36
- const noPrelude = schemaText.includes("datasource ");
37
- fs.writeFileSync(zmodelPath, `${noPrelude ? "" : makePrelude(provider, dbName)}
38
-
39
- ${schemaText}`);
40
- const pluginModelFiles = glob.sync(path.resolve(__dirname, "../../runtime/src/plugins/**/plugin.zmodel"));
41
- const generator = new TsSchemaGenerator();
42
- const tsPath = path.join(workDir, "schema.ts");
43
- await generator.generate(zmodelPath, pluginModelFiles, tsPath);
44
12
  fs.mkdirSync(path.join(workDir, "node_modules"));
45
13
  const nodeModules = fs.readdirSync(path.join(__dirname, "../node_modules"));
46
14
  for (const entry of nodeModules) {
@@ -52,44 +20,111 @@ ${schemaText}`);
52
20
  const zenstackPackages = [
53
21
  "language",
54
22
  "sdk",
55
- "runtime"
23
+ "runtime",
24
+ "cli"
56
25
  ];
57
26
  fs.mkdirSync(path.join(workDir, "node_modules/@zenstackhq"));
58
27
  for (const pkg of zenstackPackages) {
59
- fs.symlinkSync(path.join(__dirname, `../../${pkg}/dist`), path.join(workDir, `node_modules/@zenstackhq/${pkg}`), "dir");
28
+ fs.symlinkSync(path.join(__dirname, `../../${pkg}`), path.join(workDir, `node_modules/@zenstackhq/${pkg}`), "dir");
60
29
  }
61
30
  fs.writeFileSync(path.join(workDir, "package.json"), JSON.stringify({
62
31
  name: "test",
63
32
  version: "1.0.0",
64
33
  type: "module"
65
- }));
34
+ }, null, 4));
66
35
  fs.writeFileSync(path.join(workDir, "tsconfig.json"), JSON.stringify({
67
36
  compilerOptions: {
68
37
  module: "ESNext",
69
38
  target: "ESNext",
70
39
  moduleResolution: "Bundler",
71
40
  esModuleInterop: true,
72
- skipLibCheck: true
41
+ skipLibCheck: true,
42
+ strict: true
43
+ },
44
+ include: [
45
+ "**/*.ts"
46
+ ]
47
+ }, null, 4));
48
+ return workDir;
49
+ }
50
+ __name(createTestProject, "createTestProject");
51
+
52
+ // src/schema.ts
53
+ import { TsSchemaGenerator } from "@zenstackhq/sdk";
54
+ import { glob } from "glob";
55
+ import { execSync } from "child_process";
56
+ import fs2 from "fs";
57
+ import path2 from "path";
58
+ import { match } from "ts-pattern";
59
+ function makePrelude(provider, dbUrl) {
60
+ return match(provider).with("sqlite", () => {
61
+ return `
62
+ datasource db {
63
+ provider = 'sqlite'
64
+ url = '${dbUrl ?? "file:./test.db"}'
65
+ }
66
+ `;
67
+ }).with("postgresql", () => {
68
+ return `
69
+ datasource db {
70
+ provider = 'postgresql'
71
+ url = '${dbUrl ?? "postgres://postgres:postgres@localhost:5432/db"}'
72
+ }
73
+ `;
74
+ }).exhaustive();
75
+ }
76
+ __name(makePrelude, "makePrelude");
77
+ async function generateTsSchema(schemaText, provider = "sqlite", dbUrl, extraSourceFiles) {
78
+ const workDir = createTestProject();
79
+ const zmodelPath = path2.join(workDir, "schema.zmodel");
80
+ const noPrelude = schemaText.includes("datasource ");
81
+ fs2.writeFileSync(zmodelPath, `${noPrelude ? "" : makePrelude(provider, dbUrl)}
82
+
83
+ ${schemaText}`);
84
+ const pluginModelFiles = glob.sync(path2.resolve(__dirname, "../../runtime/src/plugins/**/plugin.zmodel"));
85
+ const generator = new TsSchemaGenerator();
86
+ await generator.generate(zmodelPath, pluginModelFiles, workDir);
87
+ if (extraSourceFiles) {
88
+ for (const [fileName, content] of Object.entries(extraSourceFiles)) {
89
+ const filePath = path2.resolve(workDir, `${fileName}.ts`);
90
+ fs2.mkdirSync(path2.dirname(filePath), {
91
+ recursive: true
92
+ });
93
+ fs2.writeFileSync(filePath, content);
73
94
  }
74
- }));
95
+ }
96
+ return compileAndLoad(workDir);
97
+ }
98
+ __name(generateTsSchema, "generateTsSchema");
99
+ async function compileAndLoad(workDir) {
75
100
  execSync("npx tsc", {
76
101
  cwd: workDir,
77
102
  stdio: "inherit"
78
103
  });
79
- const module = await import(path.join(workDir, "schema.js"));
104
+ const module = await import(path2.join(workDir, "schema.js"));
80
105
  return {
81
106
  workDir,
82
107
  schema: module.schema
83
108
  };
84
109
  }
85
- __name(generateTsSchema, "generateTsSchema");
110
+ __name(compileAndLoad, "compileAndLoad");
86
111
  function generateTsSchemaFromFile(filePath) {
87
- const schemaText = fs.readFileSync(filePath, "utf8");
112
+ const schemaText = fs2.readFileSync(filePath, "utf8");
88
113
  return generateTsSchema(schemaText);
89
114
  }
90
115
  __name(generateTsSchemaFromFile, "generateTsSchemaFromFile");
116
+ async function generateTsSchemaInPlace(schemaPath) {
117
+ const workDir = path2.dirname(schemaPath);
118
+ const pluginModelFiles = glob.sync(path2.resolve(__dirname, "../../runtime/src/plugins/**/plugin.zmodel"));
119
+ const generator = new TsSchemaGenerator();
120
+ await generator.generate(schemaPath, pluginModelFiles, workDir);
121
+ return compileAndLoad(workDir);
122
+ }
123
+ __name(generateTsSchemaInPlace, "generateTsSchemaInPlace");
91
124
  export {
125
+ createTestProject,
92
126
  generateTsSchema,
93
- generateTsSchemaFromFile
127
+ generateTsSchemaFromFile,
128
+ generateTsSchemaInPlace
94
129
  };
95
130
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/schema.ts"],"sourcesContent":["import { TsSchemaGenerator } from '@zenstackhq/sdk';\nimport type { SchemaDef } from '@zenstackhq/sdk/schema';\nimport { glob } from 'glob';\nimport { execSync } from 'node:child_process';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport tmp from 'tmp';\nimport { match } from 'ts-pattern';\n\nfunction makePrelude(provider: 'sqlite' | 'postgresql', dbName?: string) {\n return match(provider)\n .with('sqlite', () => {\n return `\ndatasource db {\n provider = 'sqlite'\n url = '${dbName ?? ':memory:'}'\n}\n`;\n })\n .with('postgresql', () => {\n return `\ndatasource db {\n provider = 'postgresql'\n url = 'postgres://postgres:postgres@localhost:5432/${dbName}'\n}\n`;\n })\n .exhaustive();\n}\n\nexport async function generateTsSchema(\n schemaText: string,\n provider: 'sqlite' | 'postgresql' = 'sqlite',\n dbName?: string\n) {\n const { name: workDir } = tmp.dirSync({ unsafeCleanup: true });\n console.log(`Working directory: ${workDir}`);\n\n const zmodelPath = path.join(workDir, 'schema.zmodel');\n const noPrelude = schemaText.includes('datasource ');\n fs.writeFileSync(\n zmodelPath,\n `${noPrelude ? '' : makePrelude(provider, dbName)}\\n\\n${schemaText}`\n );\n\n const pluginModelFiles = glob.sync(\n path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel')\n );\n\n const generator = new TsSchemaGenerator();\n const tsPath = path.join(workDir, 'schema.ts');\n await generator.generate(zmodelPath, pluginModelFiles, tsPath);\n\n fs.mkdirSync(path.join(workDir, 'node_modules'));\n\n // symlink all entries from \"node_modules\"\n const nodeModules = fs.readdirSync(path.join(__dirname, '../node_modules'));\n for (const entry of nodeModules) {\n if (entry.startsWith('@zenstackhq')) {\n continue;\n }\n fs.symlinkSync(\n path.join(__dirname, '../node_modules', entry),\n path.join(workDir, 'node_modules', entry),\n 'dir'\n );\n }\n\n // in addition, symlink zenstack packages\n const zenstackPackages = ['language', 'sdk', 'runtime'];\n fs.mkdirSync(path.join(workDir, 'node_modules/@zenstackhq'));\n for (const pkg of zenstackPackages) {\n fs.symlinkSync(\n path.join(__dirname, `../../${pkg}/dist`),\n path.join(workDir, `node_modules/@zenstackhq/${pkg}`),\n 'dir'\n );\n }\n\n fs.writeFileSync(\n path.join(workDir, 'package.json'),\n JSON.stringify({\n name: 'test',\n version: '1.0.0',\n type: 'module',\n })\n );\n\n fs.writeFileSync(\n path.join(workDir, 'tsconfig.json'),\n JSON.stringify({\n compilerOptions: {\n module: 'ESNext',\n target: 'ESNext',\n moduleResolution: 'Bundler',\n esModuleInterop: true,\n skipLibCheck: true,\n },\n })\n );\n\n // compile the generated TS schema\n execSync('npx tsc', {\n cwd: workDir,\n stdio: 'inherit',\n });\n\n // load the schema module\n const module = await import(path.join(workDir, 'schema.js'));\n return { workDir, schema: module.schema as SchemaDef };\n}\n\nexport function generateTsSchemaFromFile(filePath: string) {\n const schemaText = fs.readFileSync(filePath, 'utf8');\n return generateTsSchema(schemaText);\n}\n"],"mappings":";;;;AAAA,SAASA,yBAAyB;AAElC,SAASC,YAAY;AACrB,SAASC,gBAAgB;AACzB,OAAOC,QAAQ;AACf,OAAOC,UAAU;AACjB,OAAOC,SAAS;AAChB,SAASC,aAAa;AAEtB,SAASC,YAAYC,UAAmCC,QAAe;AACnE,SAAOC,MAAMF,QAAAA,EACRG,KAAK,UAAU,MAAA;AACZ,WAAO;;;aAGNF,UAAU,UAAA;;;EAGf,CAAA,EACCE,KAAK,cAAc,MAAA;AAChB,WAAO;;;yDAGsCF,MAAAA;;;EAGjD,CAAA,EACCG,WAAU;AACnB;AAnBSL;AAqBT,eAAsBM,iBAClBC,YACAN,WAAoC,UACpCC,QAAe;AAEf,QAAM,EAAEM,MAAMC,QAAO,IAAKC,IAAIC,QAAQ;IAAEC,eAAe;EAAK,CAAA;AAC5DC,UAAQC,IAAI,sBAAsBL,OAAAA,EAAS;AAE3C,QAAMM,aAAaC,KAAKC,KAAKR,SAAS,eAAA;AACtC,QAAMS,YAAYX,WAAWY,SAAS,aAAA;AACtCC,KAAGC,cACCN,YACA,GAAGG,YAAY,KAAKlB,YAAYC,UAAUC,MAAAA,CAAAA;;EAAcK,UAAAA,EAAY;AAGxE,QAAMe,mBAAmBC,KAAKC,KAC1BR,KAAKS,QAAQC,WAAW,4CAAA,CAAA;AAG5B,QAAMC,YAAY,IAAIC,kBAAAA;AACtB,QAAMC,SAASb,KAAKC,KAAKR,SAAS,WAAA;AAClC,QAAMkB,UAAUG,SAASf,YAAYO,kBAAkBO,MAAAA;AAEvDT,KAAGW,UAAUf,KAAKC,KAAKR,SAAS,cAAA,CAAA;AAGhC,QAAMuB,cAAcZ,GAAGa,YAAYjB,KAAKC,KAAKS,WAAW,iBAAA,CAAA;AACxD,aAAWQ,SAASF,aAAa;AAC7B,QAAIE,MAAMC,WAAW,aAAA,GAAgB;AACjC;IACJ;AACAf,OAAGgB,YACCpB,KAAKC,KAAKS,WAAW,mBAAmBQ,KAAAA,GACxClB,KAAKC,KAAKR,SAAS,gBAAgByB,KAAAA,GACnC,KAAA;EAER;AAGA,QAAMG,mBAAmB;IAAC;IAAY;IAAO;;AAC7CjB,KAAGW,UAAUf,KAAKC,KAAKR,SAAS,0BAAA,CAAA;AAChC,aAAW6B,OAAOD,kBAAkB;AAChCjB,OAAGgB,YACCpB,KAAKC,KAAKS,WAAW,SAASY,GAAAA,OAAU,GACxCtB,KAAKC,KAAKR,SAAS,4BAA4B6B,GAAAA,EAAK,GACpD,KAAA;EAER;AAEAlB,KAAGC,cACCL,KAAKC,KAAKR,SAAS,cAAA,GACnB8B,KAAKC,UAAU;IACXhC,MAAM;IACNiC,SAAS;IACTC,MAAM;EACV,CAAA,CAAA;AAGJtB,KAAGC,cACCL,KAAKC,KAAKR,SAAS,eAAA,GACnB8B,KAAKC,UAAU;IACXG,iBAAiB;MACbC,QAAQ;MACRC,QAAQ;MACRC,kBAAkB;MAClBC,iBAAiB;MACjBC,cAAc;IAClB;EACJ,CAAA,CAAA;AAIJC,WAAS,WAAW;IAChBC,KAAKzC;IACL0C,OAAO;EACX,CAAA;AAGA,QAAMP,SAAS,MAAM,OAAO5B,KAAKC,KAAKR,SAAS,WAAA;AAC/C,SAAO;IAAEA;IAAS2C,QAAQR,OAAOQ;EAAoB;AACzD;AAhFsB9C;AAkFf,SAAS+C,yBAAyBC,UAAgB;AACrD,QAAM/C,aAAaa,GAAGmC,aAAaD,UAAU,MAAA;AAC7C,SAAOhD,iBAAiBC,UAAAA;AAC5B;AAHgB8C;","names":["TsSchemaGenerator","glob","execSync","fs","path","tmp","match","makePrelude","provider","dbName","match","with","exhaustive","generateTsSchema","schemaText","name","workDir","tmp","dirSync","unsafeCleanup","console","log","zmodelPath","path","join","noPrelude","includes","fs","writeFileSync","pluginModelFiles","glob","sync","resolve","__dirname","generator","TsSchemaGenerator","tsPath","generate","mkdirSync","nodeModules","readdirSync","entry","startsWith","symlinkSync","zenstackPackages","pkg","JSON","stringify","version","type","compilerOptions","module","target","moduleResolution","esModuleInterop","skipLibCheck","execSync","cwd","stdio","schema","generateTsSchemaFromFile","filePath","readFileSync"]}
1
+ {"version":3,"sources":["../src/project.ts","../src/schema.ts"],"sourcesContent":["import fs from 'node:fs';\nimport path from 'node:path';\nimport tmp from 'tmp';\n\nexport function createTestProject() {\n const { name: workDir } = tmp.dirSync({ unsafeCleanup: true });\n\n fs.mkdirSync(path.join(workDir, 'node_modules'));\n\n // symlink all entries from \"node_modules\"\n const nodeModules = fs.readdirSync(path.join(__dirname, '../node_modules'));\n for (const entry of nodeModules) {\n if (entry.startsWith('@zenstackhq')) {\n continue;\n }\n fs.symlinkSync(\n path.join(__dirname, '../node_modules', entry),\n path.join(workDir, 'node_modules', entry),\n 'dir',\n );\n }\n\n // in addition, symlink zenstack packages\n const zenstackPackages = ['language', 'sdk', 'runtime', 'cli'];\n fs.mkdirSync(path.join(workDir, 'node_modules/@zenstackhq'));\n for (const pkg of zenstackPackages) {\n fs.symlinkSync(\n path.join(__dirname, `../../${pkg}`),\n path.join(workDir, `node_modules/@zenstackhq/${pkg}`),\n 'dir',\n );\n }\n\n fs.writeFileSync(\n path.join(workDir, 'package.json'),\n JSON.stringify(\n {\n name: 'test',\n version: '1.0.0',\n type: 'module',\n },\n null,\n 4,\n ),\n );\n\n fs.writeFileSync(\n path.join(workDir, 'tsconfig.json'),\n JSON.stringify(\n {\n compilerOptions: {\n module: 'ESNext',\n target: 'ESNext',\n moduleResolution: 'Bundler',\n esModuleInterop: true,\n skipLibCheck: true,\n strict: true,\n },\n include: ['**/*.ts'],\n },\n null,\n 4,\n ),\n );\n\n return workDir;\n}\n","import { TsSchemaGenerator } from '@zenstackhq/sdk';\nimport type { SchemaDef } from '@zenstackhq/sdk/schema';\nimport { glob } from 'glob';\nimport { execSync } from 'node:child_process';\nimport fs from 'node:fs';\nimport path from 'node:path';\nimport { match } from 'ts-pattern';\nimport { createTestProject } from './project';\n\nfunction makePrelude(provider: 'sqlite' | 'postgresql', dbUrl?: string) {\n return match(provider)\n .with('sqlite', () => {\n return `\ndatasource db {\n provider = 'sqlite'\n url = '${dbUrl ?? 'file:./test.db'}'\n}\n`;\n })\n .with('postgresql', () => {\n return `\ndatasource db {\n provider = 'postgresql'\n url = '${dbUrl ?? 'postgres://postgres:postgres@localhost:5432/db'}'\n}\n`;\n })\n .exhaustive();\n}\n\nexport async function generateTsSchema(\n schemaText: string,\n provider: 'sqlite' | 'postgresql' = 'sqlite',\n dbUrl?: string,\n extraSourceFiles?: Record<string, string>,\n) {\n const workDir = createTestProject();\n\n const zmodelPath = path.join(workDir, 'schema.zmodel');\n const noPrelude = schemaText.includes('datasource ');\n fs.writeFileSync(zmodelPath, `${noPrelude ? '' : makePrelude(provider, dbUrl)}\\n\\n${schemaText}`);\n\n const pluginModelFiles = glob.sync(path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel'));\n\n const generator = new TsSchemaGenerator();\n await generator.generate(zmodelPath, pluginModelFiles, workDir);\n\n if (extraSourceFiles) {\n for (const [fileName, content] of Object.entries(extraSourceFiles)) {\n const filePath = path.resolve(workDir, `${fileName}.ts`);\n fs.mkdirSync(path.dirname(filePath), { recursive: true });\n fs.writeFileSync(filePath, content);\n }\n }\n\n // compile the generated TS schema\n return compileAndLoad(workDir);\n}\n\nasync function compileAndLoad(workDir: string) {\n execSync('npx tsc', {\n cwd: workDir,\n stdio: 'inherit',\n });\n\n // load the schema module\n const module = await import(path.join(workDir, 'schema.js'));\n return { workDir, schema: module.schema as SchemaDef };\n}\n\nexport function generateTsSchemaFromFile(filePath: string) {\n const schemaText = fs.readFileSync(filePath, 'utf8');\n return generateTsSchema(schemaText);\n}\n\nexport async function generateTsSchemaInPlace(schemaPath: string) {\n const workDir = path.dirname(schemaPath);\n const pluginModelFiles = glob.sync(path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel'));\n\n const generator = new TsSchemaGenerator();\n await generator.generate(schemaPath, pluginModelFiles, workDir);\n return compileAndLoad(workDir);\n}\n"],"mappings":"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","names":["fs","path","tmp","createTestProject","name","workDir","tmp","dirSync","unsafeCleanup","fs","mkdirSync","path","join","nodeModules","readdirSync","__dirname","entry","startsWith","symlinkSync","zenstackPackages","pkg","writeFileSync","JSON","stringify","version","type","compilerOptions","module","target","moduleResolution","esModuleInterop","skipLibCheck","strict","include","TsSchemaGenerator","glob","execSync","fs","path","match","makePrelude","provider","dbUrl","match","with","exhaustive","generateTsSchema","schemaText","extraSourceFiles","workDir","createTestProject","zmodelPath","path","join","noPrelude","includes","fs","writeFileSync","pluginModelFiles","glob","sync","resolve","__dirname","generator","TsSchemaGenerator","generate","fileName","content","Object","entries","filePath","mkdirSync","dirname","recursive","compileAndLoad","execSync","cwd","stdio","module","schema","generateTsSchemaFromFile","readFileSync","generateTsSchemaInPlace","schemaPath"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zenstackhq/testtools",
3
- "version": "3.0.0-alpha.2",
3
+ "version": "3.0.0-alpha.20",
4
4
  "description": "ZenStack Test Tools",
5
5
  "type": "module",
6
6
  "keywords": [],
@@ -22,27 +22,27 @@
22
22
  }
23
23
  },
24
24
  "dependencies": {
25
- "@types/node": "^20.0.0",
26
25
  "glob": "^11.0.2",
27
26
  "tmp": "^0.2.3",
28
27
  "ts-pattern": "^5.7.1",
29
- "typescript": "^5.8.3",
30
- "prisma": "^6.9.0",
31
- "@zenstackhq/language": "3.0.0-alpha.2",
32
- "@zenstackhq/sdk": "3.0.0-alpha.2"
28
+ "prisma": "^6.0.0",
29
+ "typescript": "^5.0.0",
30
+ "@zenstackhq/sdk": "3.0.0-alpha.20",
31
+ "@zenstackhq/language": "3.0.0-alpha.20"
33
32
  },
34
33
  "peerDependencies": {
35
- "better-sqlite3": "^11.8.1",
34
+ "better-sqlite3": "^12.2.0",
36
35
  "pg": "^8.13.1"
37
36
  },
38
37
  "devDependencies": {
39
- "@types/tmp": "^0.2.6"
38
+ "@types/tmp": "^0.2.6",
39
+ "@zenstackhq/typescript-config": "3.0.0-alpha.20",
40
+ "@zenstackhq/eslint-config": "3.0.0-alpha.20"
40
41
  },
41
42
  "scripts": {
42
43
  "build": "tsup-node",
43
44
  "watch": "tsup-node --watch",
44
45
  "lint": "eslint src --ext ts",
45
- "test": "vitest",
46
46
  "pack": "pnpm pack"
47
47
  }
48
48
  }