@zenstackhq/testtools 3.0.0-alpha.6 → 3.0.0-alpha.8

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,20 @@ 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
36
  generateTsSchemaFromFile: () => generateTsSchemaFromFile
36
37
  });
37
38
  module.exports = __toCommonJS(src_exports);
38
39
 
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");
40
+ // src/project.ts
43
41
  var import_node_fs = __toESM(require("fs"), 1);
44
42
  var import_node_path = __toESM(require("path"), 1);
45
43
  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, extraSourceFiles) {
44
+ function createTestProject() {
66
45
  const { name: workDir } = import_tmp.default.dirSync({
67
46
  unsafeCleanup: true
68
47
  });
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
48
  import_node_fs.default.mkdirSync(import_node_path.default.join(workDir, "node_modules"));
80
49
  const nodeModules = import_node_fs.default.readdirSync(import_node_path.default.join(__dirname, "../node_modules"));
81
50
  for (const entry of nodeModules) {
@@ -87,17 +56,18 @@ ${schemaText}`);
87
56
  const zenstackPackages = [
88
57
  "language",
89
58
  "sdk",
90
- "runtime"
59
+ "runtime",
60
+ "cli"
91
61
  ];
92
62
  import_node_fs.default.mkdirSync(import_node_path.default.join(workDir, "node_modules/@zenstackhq"));
93
63
  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");
64
+ import_node_fs.default.symlinkSync(import_node_path.default.join(__dirname, `../../${pkg}`), import_node_path.default.join(workDir, `node_modules/@zenstackhq/${pkg}`), "dir");
95
65
  }
96
66
  import_node_fs.default.writeFileSync(import_node_path.default.join(workDir, "package.json"), JSON.stringify({
97
67
  name: "test",
98
68
  version: "1.0.0",
99
69
  type: "module"
100
- }));
70
+ }, null, 4));
101
71
  import_node_fs.default.writeFileSync(import_node_path.default.join(workDir, "tsconfig.json"), JSON.stringify({
102
72
  compilerOptions: {
103
73
  module: "ESNext",
@@ -110,21 +80,62 @@ ${schemaText}`);
110
80
  include: [
111
81
  "**/*.ts"
112
82
  ]
113
- }));
83
+ }, null, 4));
84
+ return workDir;
85
+ }
86
+ __name(createTestProject, "createTestProject");
87
+
88
+ // src/schema.ts
89
+ var import_sdk = require("@zenstackhq/sdk");
90
+ var import_glob = require("glob");
91
+ var import_node_child_process = require("child_process");
92
+ var import_node_fs2 = __toESM(require("fs"), 1);
93
+ var import_node_path2 = __toESM(require("path"), 1);
94
+ var import_ts_pattern = require("ts-pattern");
95
+ function makePrelude(provider, dbName) {
96
+ return (0, import_ts_pattern.match)(provider).with("sqlite", () => {
97
+ return `
98
+ datasource db {
99
+ provider = 'sqlite'
100
+ url = '${dbName ?? ":memory:"}'
101
+ }
102
+ `;
103
+ }).with("postgresql", () => {
104
+ return `
105
+ datasource db {
106
+ provider = 'postgresql'
107
+ url = 'postgres://postgres:postgres@localhost:5432/${dbName}'
108
+ }
109
+ `;
110
+ }).exhaustive();
111
+ }
112
+ __name(makePrelude, "makePrelude");
113
+ async function generateTsSchema(schemaText, provider = "sqlite", dbName, extraSourceFiles) {
114
+ const workDir = createTestProject();
115
+ console.log(`Work directory: ${workDir}`);
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, dbName)}
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
+ const tsPath = import_node_path2.default.join(workDir, "schema.ts");
124
+ await generator.generate(zmodelPath, pluginModelFiles, tsPath);
114
125
  if (extraSourceFiles) {
115
126
  for (const [fileName, content] of Object.entries(extraSourceFiles)) {
116
- const filePath = import_node_path.default.resolve(workDir, `${fileName}.ts`);
117
- import_node_fs.default.mkdirSync(import_node_path.default.dirname(filePath), {
127
+ const filePath = import_node_path2.default.resolve(workDir, `${fileName}.ts`);
128
+ import_node_fs2.default.mkdirSync(import_node_path2.default.dirname(filePath), {
118
129
  recursive: true
119
130
  });
120
- import_node_fs.default.writeFileSync(filePath, content);
131
+ import_node_fs2.default.writeFileSync(filePath, content);
121
132
  }
122
133
  }
123
134
  (0, import_node_child_process.execSync)("npx tsc", {
124
135
  cwd: workDir,
125
136
  stdio: "inherit"
126
137
  });
127
- const module2 = await import(import_node_path.default.join(workDir, "schema.js"));
138
+ const module2 = await import(import_node_path2.default.join(workDir, "schema.js"));
128
139
  return {
129
140
  workDir,
130
141
  schema: module2.schema
@@ -132,12 +143,13 @@ ${schemaText}`);
132
143
  }
133
144
  __name(generateTsSchema, "generateTsSchema");
134
145
  function generateTsSchemaFromFile(filePath) {
135
- const schemaText = import_node_fs.default.readFileSync(filePath, "utf8");
146
+ const schemaText = import_node_fs2.default.readFileSync(filePath, "utf8");
136
147
  return generateTsSchema(schemaText);
137
148
  }
138
149
  __name(generateTsSchemaFromFile, "generateTsSchemaFromFile");
139
150
  // Annotate the CommonJS export names for ESM import in node:
140
151
  0 && (module.exports = {
152
+ createTestProject,
141
153
  generateTsSchema,
142
154
  generateTsSchemaFromFile
143
155
  });
@@ -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 extraSourceFiles?: Record<string, 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(zmodelPath, `${noPrelude ? '' : makePrelude(provider, dbName)}\\n\\n${schemaText}`);\n\n const pluginModelFiles = glob.sync(path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel'));\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 strict: true,\n },\n include: ['**/*.ts'],\n }),\n );\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 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","extraSourceFiles","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","strict","include","fileName","content","Object","entries","filePath","dirname","recursive","execSync","cwd","stdio","schema","generateTsSchemaFromFile","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', 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 extraSourceFiles?: Record<string, string>,\n) {\n const workDir = createTestProject();\n console.log(`Work directory: ${workDir}`);\n\n const zmodelPath = path.join(workDir, 'schema.zmodel');\n const noPrelude = schemaText.includes('datasource ');\n fs.writeFileSync(zmodelPath, `${noPrelude ? '' : makePrelude(provider, dbName)}\\n\\n${schemaText}`);\n\n const pluginModelFiles = glob.sync(path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel'));\n\n const generator = new TsSchemaGenerator();\n const tsPath = path.join(workDir, 'schema.ts');\n await generator.generate(zmodelPath, pluginModelFiles, tsPath);\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 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":["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","dbName","match","with","exhaustive","generateTsSchema","schemaText","extraSourceFiles","workDir","createTestProject","console","log","zmodelPath","path","join","noPrelude","includes","fs","writeFileSync","pluginModelFiles","glob","sync","resolve","__dirname","generator","TsSchemaGenerator","tsPath","generate","fileName","content","Object","entries","filePath","mkdirSync","dirname","recursive","execSync","cwd","stdio","module","schema","generateTsSchemaFromFile","readFileSync"]}
package/dist/index.d.cts CHANGED
@@ -1,5 +1,7 @@
1
1
  import { SchemaDef } from '@zenstackhq/sdk/schema';
2
2
 
3
+ declare function createTestProject(): string;
4
+
3
5
  declare function generateTsSchema(schemaText: string, provider?: 'sqlite' | 'postgresql', dbName?: string, extraSourceFiles?: Record<string, string>): Promise<{
4
6
  workDir: string;
5
7
  schema: SchemaDef;
@@ -9,4 +11,4 @@ declare function generateTsSchemaFromFile(filePath: string): Promise<{
9
11
  schema: SchemaDef;
10
12
  }>;
11
13
 
12
- export { generateTsSchema, generateTsSchemaFromFile };
14
+ export { createTestProject, generateTsSchema, generateTsSchemaFromFile };
package/dist/index.d.ts CHANGED
@@ -1,5 +1,7 @@
1
1
  import { SchemaDef } from '@zenstackhq/sdk/schema';
2
2
 
3
+ declare function createTestProject(): string;
4
+
3
5
  declare function generateTsSchema(schemaText: string, provider?: 'sqlite' | 'postgresql', dbName?: string, extraSourceFiles?: Record<string, string>): Promise<{
4
6
  workDir: string;
5
7
  schema: SchemaDef;
@@ -9,4 +11,4 @@ declare function generateTsSchemaFromFile(filePath: string): Promise<{
9
11
  schema: SchemaDef;
10
12
  }>;
11
13
 
12
- export { generateTsSchema, generateTsSchemaFromFile };
14
+ export { createTestProject, generateTsSchema, generateTsSchemaFromFile };
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 "child_process";
4
+ // src/project.ts
8
5
  import fs from "fs";
9
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, extraSourceFiles) {
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,17 +20,18 @@ ${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",
@@ -75,21 +44,62 @@ ${schemaText}`);
75
44
  include: [
76
45
  "**/*.ts"
77
46
  ]
78
- }));
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, dbName) {
60
+ return match(provider).with("sqlite", () => {
61
+ return `
62
+ datasource db {
63
+ provider = 'sqlite'
64
+ url = '${dbName ?? ":memory:"}'
65
+ }
66
+ `;
67
+ }).with("postgresql", () => {
68
+ return `
69
+ datasource db {
70
+ provider = 'postgresql'
71
+ url = 'postgres://postgres:postgres@localhost:5432/${dbName}'
72
+ }
73
+ `;
74
+ }).exhaustive();
75
+ }
76
+ __name(makePrelude, "makePrelude");
77
+ async function generateTsSchema(schemaText, provider = "sqlite", dbName, extraSourceFiles) {
78
+ const workDir = createTestProject();
79
+ console.log(`Work directory: ${workDir}`);
80
+ const zmodelPath = path2.join(workDir, "schema.zmodel");
81
+ const noPrelude = schemaText.includes("datasource ");
82
+ fs2.writeFileSync(zmodelPath, `${noPrelude ? "" : makePrelude(provider, dbName)}
83
+
84
+ ${schemaText}`);
85
+ const pluginModelFiles = glob.sync(path2.resolve(__dirname, "../../runtime/src/plugins/**/plugin.zmodel"));
86
+ const generator = new TsSchemaGenerator();
87
+ const tsPath = path2.join(workDir, "schema.ts");
88
+ await generator.generate(zmodelPath, pluginModelFiles, tsPath);
79
89
  if (extraSourceFiles) {
80
90
  for (const [fileName, content] of Object.entries(extraSourceFiles)) {
81
- const filePath = path.resolve(workDir, `${fileName}.ts`);
82
- fs.mkdirSync(path.dirname(filePath), {
91
+ const filePath = path2.resolve(workDir, `${fileName}.ts`);
92
+ fs2.mkdirSync(path2.dirname(filePath), {
83
93
  recursive: true
84
94
  });
85
- fs.writeFileSync(filePath, content);
95
+ fs2.writeFileSync(filePath, content);
86
96
  }
87
97
  }
88
98
  execSync("npx tsc", {
89
99
  cwd: workDir,
90
100
  stdio: "inherit"
91
101
  });
92
- const module = await import(path.join(workDir, "schema.js"));
102
+ const module = await import(path2.join(workDir, "schema.js"));
93
103
  return {
94
104
  workDir,
95
105
  schema: module.schema
@@ -97,11 +107,12 @@ ${schemaText}`);
97
107
  }
98
108
  __name(generateTsSchema, "generateTsSchema");
99
109
  function generateTsSchemaFromFile(filePath) {
100
- const schemaText = fs.readFileSync(filePath, "utf8");
110
+ const schemaText = fs2.readFileSync(filePath, "utf8");
101
111
  return generateTsSchema(schemaText);
102
112
  }
103
113
  __name(generateTsSchemaFromFile, "generateTsSchemaFromFile");
104
114
  export {
115
+ createTestProject,
105
116
  generateTsSchema,
106
117
  generateTsSchemaFromFile
107
118
  };
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 extraSourceFiles?: Record<string, 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(zmodelPath, `${noPrelude ? '' : makePrelude(provider, dbName)}\\n\\n${schemaText}`);\n\n const pluginModelFiles = glob.sync(path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel'));\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 strict: true,\n },\n include: ['**/*.ts'],\n }),\n );\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 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":["TsSchemaGenerator","glob","execSync","fs","path","tmp","match","makePrelude","provider","dbName","match","with","exhaustive","generateTsSchema","schemaText","extraSourceFiles","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","strict","include","fileName","content","Object","entries","filePath","dirname","recursive","execSync","cwd","stdio","schema","generateTsSchemaFromFile","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', 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 extraSourceFiles?: Record<string, string>,\n) {\n const workDir = createTestProject();\n console.log(`Work directory: ${workDir}`);\n\n const zmodelPath = path.join(workDir, 'schema.zmodel');\n const noPrelude = schemaText.includes('datasource ');\n fs.writeFileSync(zmodelPath, `${noPrelude ? '' : makePrelude(provider, dbName)}\\n\\n${schemaText}`);\n\n const pluginModelFiles = glob.sync(path.resolve(__dirname, '../../runtime/src/plugins/**/plugin.zmodel'));\n\n const generator = new TsSchemaGenerator();\n const tsPath = path.join(workDir, 'schema.ts');\n await generator.generate(zmodelPath, pluginModelFiles, tsPath);\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 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":["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","dbName","match","with","exhaustive","generateTsSchema","schemaText","extraSourceFiles","workDir","createTestProject","console","log","zmodelPath","path","join","noPrelude","includes","fs","writeFileSync","pluginModelFiles","glob","sync","resolve","__dirname","generator","TsSchemaGenerator","tsPath","generate","fileName","content","Object","entries","filePath","mkdirSync","dirname","recursive","execSync","cwd","stdio","module","schema","generateTsSchemaFromFile","readFileSync"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zenstackhq/testtools",
3
- "version": "3.0.0-alpha.6",
3
+ "version": "3.0.0-alpha.8",
4
4
  "description": "ZenStack Test Tools",
5
5
  "type": "module",
6
6
  "keywords": [],
@@ -27,8 +27,8 @@
27
27
  "ts-pattern": "^5.7.1",
28
28
  "prisma": "^6.0.0",
29
29
  "typescript": "^5.0.0",
30
- "@zenstackhq/language": "3.0.0-alpha.6",
31
- "@zenstackhq/sdk": "3.0.0-alpha.6"
30
+ "@zenstackhq/language": "3.0.0-alpha.8",
31
+ "@zenstackhq/sdk": "3.0.0-alpha.8"
32
32
  },
33
33
  "peerDependencies": {
34
34
  "better-sqlite3": "^11.8.1",
@@ -36,8 +36,8 @@
36
36
  },
37
37
  "devDependencies": {
38
38
  "@types/tmp": "^0.2.6",
39
- "@zenstackhq/eslint-config": "3.0.0-alpha.6",
40
- "@zenstackhq/typescript-config": "3.0.0-alpha.6"
39
+ "@zenstackhq/eslint-config": "3.0.0-alpha.8",
40
+ "@zenstackhq/typescript-config": "3.0.0-alpha.8"
41
41
  },
42
42
  "scripts": {
43
43
  "build": "tsup-node",