frictionless-ts 1.0.1
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/LICENSE.md +9 -0
- package/README.md +3 -0
- package/build/dialect/index.d.ts +1 -0
- package/build/dialect/index.js +2 -0
- package/build/dialect/infer.d.ts +3 -0
- package/build/dialect/infer.js +13 -0
- package/build/dialect/infer.spec.d.ts +1 -0
- package/build/dialect/infer.spec.js +89 -0
- package/build/index.d.ts +19 -0
- package/build/index.js +19 -0
- package/build/package/index.d.ts +4 -0
- package/build/package/index.js +5 -0
- package/build/package/infer.d.ts +40 -0
- package/build/package/infer.js +13 -0
- package/build/package/infer.spec.d.ts +1 -0
- package/build/package/infer.spec.js +121 -0
- package/build/package/integrity.d.ts +8 -0
- package/build/package/integrity.js +69 -0
- package/build/package/integrity.spec.d.ts +1 -0
- package/build/package/integrity.spec.js +575 -0
- package/build/package/load.d.ts +1 -0
- package/build/package/load.js +10 -0
- package/build/package/load.spec.d.ts +1 -0
- package/build/package/load.spec.js +117 -0
- package/build/package/save.d.ts +5 -0
- package/build/package/save.js +13 -0
- package/build/package/save.spec.d.ts +1 -0
- package/build/package/save.spec.js +138 -0
- package/build/package/validate.d.ts +20 -0
- package/build/package/validate.js +62 -0
- package/build/package/validate.spec.d.ts +1 -0
- package/build/package/validate.spec.js +172 -0
- package/build/plugin.d.ts +2 -0
- package/build/plugin.js +2 -0
- package/build/resource/index.d.ts +2 -0
- package/build/resource/index.js +3 -0
- package/build/resource/infer.d.ts +22 -0
- package/build/resource/infer.js +49 -0
- package/build/resource/infer.spec.d.ts +1 -0
- package/build/resource/infer.spec.js +164 -0
- package/build/resource/validate.d.ts +12 -0
- package/build/resource/validate.js +35 -0
- package/build/resource/validate.spec.d.ts +1 -0
- package/build/resource/validate.spec.js +147 -0
- package/build/schema/index.d.ts +1 -0
- package/build/schema/index.js +2 -0
- package/build/schema/infer.d.ts +3 -0
- package/build/schema/infer.js +18 -0
- package/build/schema/infer.spec.d.ts +1 -0
- package/build/schema/infer.spec.js +136 -0
- package/build/system.d.ts +6 -0
- package/build/system.js +41 -0
- package/build/table/index.d.ts +3 -0
- package/build/table/index.js +4 -0
- package/build/table/infer.d.ts +6 -0
- package/build/table/infer.js +20 -0
- package/build/table/infer.spec.d.ts +1 -0
- package/build/table/infer.spec.js +177 -0
- package/build/table/load.d.ts +3 -0
- package/build/table/load.js +11 -0
- package/build/table/load.spec.d.ts +1 -0
- package/build/table/load.spec.js +121 -0
- package/build/table/save.d.ts +2 -0
- package/build/table/save.js +11 -0
- package/build/table/save.spec.d.ts +1 -0
- package/build/table/save.spec.js +189 -0
- package/build/table/validate.d.ts +9 -0
- package/build/table/validate.js +26 -0
- package/package.json +38 -0
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
import { writeTempFile } from "@frictionless-ts/dataset";
|
|
2
|
+
import { describe, expect, it } from "vitest";
|
|
3
|
+
import { inferSchema } from "./infer.js";
|
|
4
|
+
describe("inferSchema", () => {
|
|
5
|
+
it("should infer schema from CSV file", async () => {
|
|
6
|
+
const csvPath = await writeTempFile("id,name,age\n1,alice,25\n2,bob,30");
|
|
7
|
+
const resource = { path: csvPath, format: "csv" };
|
|
8
|
+
const schema = await inferSchema(resource);
|
|
9
|
+
expect(schema).toBeDefined();
|
|
10
|
+
expect(schema?.fields).toBeDefined();
|
|
11
|
+
expect(schema?.fields?.length).toBe(3);
|
|
12
|
+
expect(schema?.fields?.[0]?.name).toBe("id");
|
|
13
|
+
expect(schema?.fields?.[1]?.name).toBe("name");
|
|
14
|
+
expect(schema?.fields?.[2]?.name).toBe("age");
|
|
15
|
+
});
|
|
16
|
+
it("should infer field types correctly", async () => {
|
|
17
|
+
const csvPath = await writeTempFile("id,name,score\n1,alice,95.5\n2,bob,87.3");
|
|
18
|
+
const resource = { path: csvPath, format: "csv" };
|
|
19
|
+
const schema = await inferSchema(resource);
|
|
20
|
+
expect(schema?.fields?.[0]?.type).toBe("integer");
|
|
21
|
+
expect(schema?.fields?.[1]?.type).toBe("string");
|
|
22
|
+
expect(schema?.fields?.[2]?.type).toBe("number");
|
|
23
|
+
});
|
|
24
|
+
it("should infer schema from inline data", async () => {
|
|
25
|
+
const resource = {
|
|
26
|
+
name: "test-resource",
|
|
27
|
+
type: "table",
|
|
28
|
+
data: [
|
|
29
|
+
{ id: 1, name: "alice" },
|
|
30
|
+
{ id: 2, name: "bob" },
|
|
31
|
+
],
|
|
32
|
+
};
|
|
33
|
+
const schema = await inferSchema(resource);
|
|
34
|
+
expect(schema).toBeDefined();
|
|
35
|
+
expect(schema?.fields).toBeDefined();
|
|
36
|
+
expect(schema?.fields?.length).toBe(2);
|
|
37
|
+
expect(schema?.fields?.[0]?.name).toBe("id");
|
|
38
|
+
expect(schema?.fields?.[1]?.name).toBe("name");
|
|
39
|
+
});
|
|
40
|
+
it("should infer schema with custom delimiter", async () => {
|
|
41
|
+
const csvPath = await writeTempFile("id|name|value\n1|alice|100\n2|bob|200");
|
|
42
|
+
const resource = {
|
|
43
|
+
path: csvPath,
|
|
44
|
+
format: "csv",
|
|
45
|
+
dialect: { delimiter: "|" },
|
|
46
|
+
};
|
|
47
|
+
const schema = await inferSchema(resource);
|
|
48
|
+
expect(schema).toBeDefined();
|
|
49
|
+
expect(schema?.fields).toBeDefined();
|
|
50
|
+
expect(schema?.fields?.length).toBe(3);
|
|
51
|
+
expect(schema?.fields?.[0]?.name).toBe("id");
|
|
52
|
+
expect(schema?.fields?.[1]?.name).toBe("name");
|
|
53
|
+
expect(schema?.fields?.[2]?.name).toBe("value");
|
|
54
|
+
});
|
|
55
|
+
it("should handle boolean fields", async () => {
|
|
56
|
+
const csvPath = await writeTempFile("id,active\n1,true\n2,false");
|
|
57
|
+
const resource = { path: csvPath, format: "csv" };
|
|
58
|
+
const schema = await inferSchema(resource);
|
|
59
|
+
expect(schema?.fields?.[1]?.type).toBe("boolean");
|
|
60
|
+
});
|
|
61
|
+
it("should handle date fields", async () => {
|
|
62
|
+
const csvPath = await writeTempFile("id,created\n1,2024-01-01\n2,2024-01-02");
|
|
63
|
+
const resource = { path: csvPath, format: "csv" };
|
|
64
|
+
const schema = await inferSchema(resource);
|
|
65
|
+
expect(schema?.fields?.[1]?.type).toBe("date");
|
|
66
|
+
});
|
|
67
|
+
it("should handle mixed numeric types", async () => {
|
|
68
|
+
const csvPath = await writeTempFile("id,value\n1,100\n2,200.5");
|
|
69
|
+
const resource = { path: csvPath, format: "csv" };
|
|
70
|
+
const schema = await inferSchema(resource);
|
|
71
|
+
expect(schema?.fields?.[1]?.type).toBe("string");
|
|
72
|
+
});
|
|
73
|
+
it("should infer schema from single row", async () => {
|
|
74
|
+
const csvPath = await writeTempFile("id,name\n1,alice");
|
|
75
|
+
const resource = { path: csvPath, format: "csv" };
|
|
76
|
+
const schema = await inferSchema(resource);
|
|
77
|
+
expect(schema).toBeDefined();
|
|
78
|
+
expect(schema?.fields).toBeDefined();
|
|
79
|
+
expect(schema?.fields?.length).toBe(2);
|
|
80
|
+
});
|
|
81
|
+
it("should handle empty string values", async () => {
|
|
82
|
+
const csvPath = await writeTempFile("id,name,email\n1,alice,\n2,bob,bob@example.com");
|
|
83
|
+
const resource = { path: csvPath, format: "csv" };
|
|
84
|
+
const schema = await inferSchema(resource);
|
|
85
|
+
expect(schema).toBeDefined();
|
|
86
|
+
expect(schema?.fields?.length).toBe(3);
|
|
87
|
+
expect(schema?.fields?.[2]?.name).toBe("email");
|
|
88
|
+
});
|
|
89
|
+
it("should infer schema with sampleRows option", async () => {
|
|
90
|
+
const csvPath = await writeTempFile("id,name\n1,alice\n2,bob\n3,charlie\n4,david\n5,eve");
|
|
91
|
+
const resource = { path: csvPath, format: "csv" };
|
|
92
|
+
const schema = await inferSchema(resource, { sampleRows: 2 });
|
|
93
|
+
expect(schema).toBeDefined();
|
|
94
|
+
expect(schema?.fields).toBeDefined();
|
|
95
|
+
expect(schema?.fields?.length).toBe(2);
|
|
96
|
+
});
|
|
97
|
+
it("should handle resources with headers only", async () => {
|
|
98
|
+
const csvPath = await writeTempFile("id,name,age");
|
|
99
|
+
const resource = { path: csvPath, format: "csv" };
|
|
100
|
+
const schema = await inferSchema(resource);
|
|
101
|
+
expect(schema).toBeDefined();
|
|
102
|
+
expect(schema?.fields).toBeDefined();
|
|
103
|
+
expect(schema?.fields?.length).toBe(3);
|
|
104
|
+
});
|
|
105
|
+
it("should infer schema from complex inline data", async () => {
|
|
106
|
+
const resource = {
|
|
107
|
+
name: "test-resource",
|
|
108
|
+
type: "table",
|
|
109
|
+
data: [
|
|
110
|
+
{
|
|
111
|
+
id: 1,
|
|
112
|
+
name: "alice",
|
|
113
|
+
score: 95.5,
|
|
114
|
+
active: true,
|
|
115
|
+
created: "2024-01-01",
|
|
116
|
+
},
|
|
117
|
+
{
|
|
118
|
+
id: 2,
|
|
119
|
+
name: "bob",
|
|
120
|
+
score: 87.3,
|
|
121
|
+
active: false,
|
|
122
|
+
created: "2024-01-02",
|
|
123
|
+
},
|
|
124
|
+
],
|
|
125
|
+
};
|
|
126
|
+
const schema = await inferSchema(resource);
|
|
127
|
+
expect(schema).toBeDefined();
|
|
128
|
+
expect(schema?.fields?.length).toBe(5);
|
|
129
|
+
expect(schema?.fields?.find(f => f.name === "id")?.type).toBe("integer");
|
|
130
|
+
expect(schema?.fields?.find(f => f.name === "name")?.type).toBe("string");
|
|
131
|
+
expect(schema?.fields?.find(f => f.name === "score")?.type).toBe("number");
|
|
132
|
+
expect(schema?.fields?.find(f => f.name === "active")?.type).toBe("boolean");
|
|
133
|
+
expect(schema?.fields?.find(f => f.name === "created")?.type).toBe("date");
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infer.spec.js","sourceRoot":"","sources":["../../schema/infer.spec.ts"],"names":[],"mappings":"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","sourcesContent":["import { writeTempFile } from \"@frictionless-ts/dataset\"\nimport { describe, expect, it } from \"vitest\"\nimport { inferSchema } from \"./infer.ts\"\n\ndescribe(\"inferSchema\", () => {\n  it(\"should infer schema from CSV file\", async () => {\n    const csvPath = await writeTempFile(\"id,name,age\\n1,alice,25\\n2,bob,30\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema).toBeDefined()\n    expect(schema?.fields).toBeDefined()\n    expect(schema?.fields?.length).toBe(3)\n    expect(schema?.fields?.[0]?.name).toBe(\"id\")\n    expect(schema?.fields?.[1]?.name).toBe(\"name\")\n    expect(schema?.fields?.[2]?.name).toBe(\"age\")\n  })\n\n  it(\"should infer field types correctly\", async () => {\n    const csvPath = await writeTempFile(\n      \"id,name,score\\n1,alice,95.5\\n2,bob,87.3\",\n    )\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema?.fields?.[0]?.type).toBe(\"integer\")\n    expect(schema?.fields?.[1]?.type).toBe(\"string\")\n    expect(schema?.fields?.[2]?.type).toBe(\"number\")\n  })\n\n  it(\"should infer schema from inline data\", async () => {\n    const resource = {\n      name: \"test-resource\",\n      type: \"table\" as const,\n      data: [\n        { id: 1, name: \"alice\" },\n        { id: 2, name: \"bob\" },\n      ],\n    }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema).toBeDefined()\n    expect(schema?.fields).toBeDefined()\n    expect(schema?.fields?.length).toBe(2)\n    expect(schema?.fields?.[0]?.name).toBe(\"id\")\n    expect(schema?.fields?.[1]?.name).toBe(\"name\")\n  })\n\n  it(\"should infer schema with custom delimiter\", async () => {\n    const csvPath = await writeTempFile(\"id|name|value\\n1|alice|100\\n2|bob|200\")\n    const resource = {\n      path: csvPath,\n      format: \"csv\" as const,\n      dialect: { delimiter: \"|\" },\n    }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema).toBeDefined()\n    expect(schema?.fields).toBeDefined()\n    expect(schema?.fields?.length).toBe(3)\n    expect(schema?.fields?.[0]?.name).toBe(\"id\")\n    expect(schema?.fields?.[1]?.name).toBe(\"name\")\n    expect(schema?.fields?.[2]?.name).toBe(\"value\")\n  })\n\n  it(\"should handle boolean fields\", async () => {\n    const csvPath = await writeTempFile(\"id,active\\n1,true\\n2,false\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema?.fields?.[1]?.type).toBe(\"boolean\")\n  })\n\n  it(\"should handle date fields\", async () => {\n    const csvPath = await writeTempFile(\n      \"id,created\\n1,2024-01-01\\n2,2024-01-02\",\n    )\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema?.fields?.[1]?.type).toBe(\"date\")\n  })\n\n  it(\"should handle mixed numeric types\", async () => {\n    const csvPath = await writeTempFile(\"id,value\\n1,100\\n2,200.5\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema?.fields?.[1]?.type).toBe(\"string\")\n  })\n\n  it(\"should infer schema from single row\", async () => {\n    const csvPath = await writeTempFile(\"id,name\\n1,alice\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema).toBeDefined()\n    expect(schema?.fields).toBeDefined()\n    expect(schema?.fields?.length).toBe(2)\n  })\n\n  it(\"should handle empty string values\", async () => {\n    const csvPath = await writeTempFile(\n      \"id,name,email\\n1,alice,\\n2,bob,bob@example.com\",\n    )\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema).toBeDefined()\n    expect(schema?.fields?.length).toBe(3)\n    expect(schema?.fields?.[2]?.name).toBe(\"email\")\n  })\n\n  it(\"should infer schema with sampleRows option\", async () => {\n    const csvPath = await writeTempFile(\n      \"id,name\\n1,alice\\n2,bob\\n3,charlie\\n4,david\\n5,eve\",\n    )\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const schema = await inferSchema(resource, { sampleRows: 2 })\n\n    expect(schema).toBeDefined()\n    expect(schema?.fields).toBeDefined()\n    expect(schema?.fields?.length).toBe(2)\n  })\n\n  it(\"should handle resources with headers only\", async () => {\n    const csvPath = await writeTempFile(\"id,name,age\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema).toBeDefined()\n    expect(schema?.fields).toBeDefined()\n    expect(schema?.fields?.length).toBe(3)\n  })\n\n  it(\"should infer schema from complex inline data\", async () => {\n    const resource = {\n      name: \"test-resource\",\n      type: \"table\" as const,\n      data: [\n        {\n          id: 1,\n          name: \"alice\",\n          score: 95.5,\n          active: true,\n          created: \"2024-01-01\",\n        },\n        {\n          id: 2,\n          name: \"bob\",\n          score: 87.3,\n          active: false,\n          created: \"2024-01-02\",\n        },\n      ],\n    }\n\n    const schema = await inferSchema(resource)\n\n    expect(schema).toBeDefined()\n    expect(schema?.fields?.length).toBe(5)\n    expect(schema?.fields?.find(f => f.name === \"id\")?.type).toBe(\"integer\")\n    expect(schema?.fields?.find(f => f.name === \"name\")?.type).toBe(\"string\")\n    expect(schema?.fields?.find(f => f.name === \"score\")?.type).toBe(\"number\")\n    expect(schema?.fields?.find(f => f.name === \"active\")?.type).toBe(\"boolean\")\n    expect(schema?.fields?.find(f => f.name === \"created\")?.type).toBe(\"date\")\n  })\n})\n"]}
|
package/build/system.js
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { DatabasePlugin } from "@frictionless-ts/database";
|
|
2
|
+
import { CkanPlugin } from "@frictionless-ts/dataset";
|
|
3
|
+
import { DatahubPlugin } from "@frictionless-ts/dataset";
|
|
4
|
+
import { DescriptorPlugin } from "@frictionless-ts/dataset";
|
|
5
|
+
import { FolderPlugin } from "@frictionless-ts/dataset";
|
|
6
|
+
import { GithubPlugin } from "@frictionless-ts/dataset";
|
|
7
|
+
import { ZenodoPlugin } from "@frictionless-ts/dataset";
|
|
8
|
+
import { ZipPlugin } from "@frictionless-ts/dataset";
|
|
9
|
+
import { CsvPlugin } from "@frictionless-ts/table";
|
|
10
|
+
import { ArrowPlugin } from "@frictionless-ts/table";
|
|
11
|
+
import { InlinePlugin } from "@frictionless-ts/table";
|
|
12
|
+
import { JsonPlugin } from "@frictionless-ts/table";
|
|
13
|
+
import { OdsPlugin } from "@frictionless-ts/table";
|
|
14
|
+
import { ParquetPlugin } from "@frictionless-ts/table";
|
|
15
|
+
import { XlsxPlugin } from "@frictionless-ts/table";
|
|
16
|
+
export class System {
|
|
17
|
+
plugins = [];
|
|
18
|
+
register(PluginClass) {
|
|
19
|
+
this.plugins.unshift(new PluginClass());
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
export const system = new System();
|
|
23
|
+
// Dataset
|
|
24
|
+
system.register(CkanPlugin);
|
|
25
|
+
system.register(DatahubPlugin);
|
|
26
|
+
system.register(DescriptorPlugin);
|
|
27
|
+
system.register(GithubPlugin);
|
|
28
|
+
system.register(ZenodoPlugin);
|
|
29
|
+
system.register(FolderPlugin);
|
|
30
|
+
system.register(ZipPlugin);
|
|
31
|
+
// Table
|
|
32
|
+
system.register(ArrowPlugin);
|
|
33
|
+
system.register(CsvPlugin);
|
|
34
|
+
system.register(InlinePlugin);
|
|
35
|
+
system.register(JsonPlugin);
|
|
36
|
+
system.register(OdsPlugin);
|
|
37
|
+
system.register(ParquetPlugin);
|
|
38
|
+
system.register(XlsxPlugin);
|
|
39
|
+
// Mixed
|
|
40
|
+
system.register(DatabasePlugin);
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3lzdGVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3lzdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQTtBQUMxRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sMEJBQTBCLENBQUE7QUFDckQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDBCQUEwQixDQUFBO0FBQ3hELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDBCQUEwQixDQUFBO0FBQzNELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQTtBQUN2RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMEJBQTBCLENBQUE7QUFDdkQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLDBCQUEwQixDQUFBO0FBQ3ZELE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQTtBQUNwRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFDbEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHdCQUF3QixDQUFBO0FBQ3BELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQTtBQUNyRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFDbkQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLHdCQUF3QixDQUFBO0FBQ2xELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQTtBQUN0RCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFHbkQsTUFBTSxPQUFPLE1BQU07SUFDakIsT0FBTyxHQUFhLEVBQUUsQ0FBQTtJQUV0QixRQUFRLENBQUMsV0FBNkI7UUFDcEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxXQUFXLEVBQUUsQ0FBQyxDQUFBO0lBQ3pDLENBQUM7Q0FDRjtBQUVELE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxJQUFJLE1BQU0sRUFBRSxDQUFBO0FBRWxDLFVBQVU7QUFFVixNQUFNLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxDQUFBO0FBQzNCLE1BQU0sQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLENBQUE7QUFDOUIsTUFBTSxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFBO0FBQ2pDLE1BQU0sQ0FBQyxRQUFRLENBQUMsWUFBWSxDQUFDLENBQUE7QUFDN0IsTUFBTSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsQ0FBQTtBQUM3QixNQUFNLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUFBO0FBQzdCLE1BQU0sQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUE7QUFFMUIsUUFBUTtBQUVSLE1BQU0sQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUE7QUFDNUIsTUFBTSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQTtBQUMxQixNQUFNLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxDQUFBO0FBQzdCLE1BQU0sQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUE7QUFDM0IsTUFBTSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQTtBQUMxQixNQUFNLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFBO0FBQzlCLE1BQU0sQ0FBQyxRQUFRLENBQUMsVUFBVSxDQUFDLENBQUE7QUFFM0IsUUFBUTtBQUVSLE1BQU0sQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEYXRhYmFzZVBsdWdpbiB9IGZyb20gXCJAZnJpY3Rpb25sZXNzLXRzL2RhdGFiYXNlXCJcbmltcG9ydCB7IENrYW5QbHVnaW4gfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy9kYXRhc2V0XCJcbmltcG9ydCB7IERhdGFodWJQbHVnaW4gfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy9kYXRhc2V0XCJcbmltcG9ydCB7IERlc2NyaXB0b3JQbHVnaW4gfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy9kYXRhc2V0XCJcbmltcG9ydCB7IEZvbGRlclBsdWdpbiB9IGZyb20gXCJAZnJpY3Rpb25sZXNzLXRzL2RhdGFzZXRcIlxuaW1wb3J0IHsgR2l0aHViUGx1Z2luIH0gZnJvbSBcIkBmcmljdGlvbmxlc3MtdHMvZGF0YXNldFwiXG5pbXBvcnQgeyBaZW5vZG9QbHVnaW4gfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy9kYXRhc2V0XCJcbmltcG9ydCB7IFppcFBsdWdpbiB9IGZyb20gXCJAZnJpY3Rpb25sZXNzLXRzL2RhdGFzZXRcIlxuaW1wb3J0IHsgQ3N2UGx1Z2luIH0gZnJvbSBcIkBmcmljdGlvbmxlc3MtdHMvdGFibGVcIlxuaW1wb3J0IHsgQXJyb3dQbHVnaW4gfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy90YWJsZVwiXG5pbXBvcnQgeyBJbmxpbmVQbHVnaW4gfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy90YWJsZVwiXG5pbXBvcnQgeyBKc29uUGx1Z2luIH0gZnJvbSBcIkBmcmljdGlvbmxlc3MtdHMvdGFibGVcIlxuaW1wb3J0IHsgT2RzUGx1Z2luIH0gZnJvbSBcIkBmcmljdGlvbmxlc3MtdHMvdGFibGVcIlxuaW1wb3J0IHsgUGFycXVldFBsdWdpbiB9IGZyb20gXCJAZnJpY3Rpb25sZXNzLXRzL3RhYmxlXCJcbmltcG9ydCB7IFhsc3hQbHVnaW4gfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy90YWJsZVwiXG5pbXBvcnQgdHlwZSB7IFBsdWdpbiB9IGZyb20gXCIuL3BsdWdpbi50c1wiXG5cbmV4cG9ydCBjbGFzcyBTeXN0ZW0ge1xuICBwbHVnaW5zOiBQbHVnaW5bXSA9IFtdXG5cbiAgcmVnaXN0ZXIoUGx1Z2luQ2xhc3M6IG5ldyAoKSA9PiBQbHVnaW4pIHtcbiAgICB0aGlzLnBsdWdpbnMudW5zaGlmdChuZXcgUGx1Z2luQ2xhc3MoKSlcbiAgfVxufVxuXG5leHBvcnQgY29uc3Qgc3lzdGVtID0gbmV3IFN5c3RlbSgpXG5cbi8vIERhdGFzZXRcblxuc3lzdGVtLnJlZ2lzdGVyKENrYW5QbHVnaW4pXG5zeXN0ZW0ucmVnaXN0ZXIoRGF0YWh1YlBsdWdpbilcbnN5c3RlbS5yZWdpc3RlcihEZXNjcmlwdG9yUGx1Z2luKVxuc3lzdGVtLnJlZ2lzdGVyKEdpdGh1YlBsdWdpbilcbnN5c3RlbS5yZWdpc3RlcihaZW5vZG9QbHVnaW4pXG5zeXN0ZW0ucmVnaXN0ZXIoRm9sZGVyUGx1Z2luKVxuc3lzdGVtLnJlZ2lzdGVyKFppcFBsdWdpbilcblxuLy8gVGFibGVcblxuc3lzdGVtLnJlZ2lzdGVyKEFycm93UGx1Z2luKVxuc3lzdGVtLnJlZ2lzdGVyKENzdlBsdWdpbilcbnN5c3RlbS5yZWdpc3RlcihJbmxpbmVQbHVnaW4pXG5zeXN0ZW0ucmVnaXN0ZXIoSnNvblBsdWdpbilcbnN5c3RlbS5yZWdpc3RlcihPZHNQbHVnaW4pXG5zeXN0ZW0ucmVnaXN0ZXIoUGFycXVldFBsdWdpbilcbnN5c3RlbS5yZWdpc3RlcihYbHN4UGx1Z2luKVxuXG4vLyBNaXhlZFxuXG5zeXN0ZW0ucmVnaXN0ZXIoRGF0YWJhc2VQbHVnaW4pXG4iXX0=
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { loadTable } from "./load.js";
|
|
2
|
+
export { saveTable } from "./save.js";
|
|
3
|
+
export { validateTable } from "./validate.js";
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90YWJsZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sV0FBVyxDQUFBO0FBQ3JDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxXQUFXLENBQUE7QUFDckMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IGxvYWRUYWJsZSB9IGZyb20gXCIuL2xvYWQudHNcIlxuZXhwb3J0IHsgc2F2ZVRhYmxlIH0gZnJvbSBcIi4vc2F2ZS50c1wiXG5leHBvcnQgeyB2YWxpZGF0ZVRhYmxlIH0gZnJvbSBcIi4vdmFsaWRhdGUudHNcIlxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { Resource } from "@frictionless-ts/metadata";
|
|
2
|
+
export declare function inferTable(resource: Partial<Resource>): Promise<{
|
|
3
|
+
dialect: import("@frictionless-ts/metadata").Dialect;
|
|
4
|
+
schema: import("@frictionless-ts/metadata").Schema;
|
|
5
|
+
table: import("@frictionless-ts/table").Table;
|
|
6
|
+
} | undefined>;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { resolveDialect, resolveSchema } from "@frictionless-ts/metadata";
|
|
2
|
+
import { inferSchemaFromTable } from "@frictionless-ts/table";
|
|
3
|
+
import { inferDialect } from "../dialect/index.js";
|
|
4
|
+
import { loadTable } from "./load.js";
|
|
5
|
+
export async function inferTable(resource) {
|
|
6
|
+
let dialect = await resolveDialect(resource.dialect);
|
|
7
|
+
if (!dialect) {
|
|
8
|
+
dialect = await inferDialect(resource);
|
|
9
|
+
}
|
|
10
|
+
const table = await loadTable({ ...resource, dialect }, { denormalized: true });
|
|
11
|
+
if (!table) {
|
|
12
|
+
return undefined;
|
|
13
|
+
}
|
|
14
|
+
let schema = await resolveSchema(resource.schema);
|
|
15
|
+
if (!schema) {
|
|
16
|
+
schema = await inferSchemaFromTable(table);
|
|
17
|
+
}
|
|
18
|
+
return { dialect, schema, table };
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5mZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi90YWJsZS9pbmZlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsY0FBYyxFQUFFLGFBQWEsRUFBRSxNQUFNLDJCQUEyQixDQUFBO0FBQ3pFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHdCQUF3QixDQUFBO0FBQzdELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUNsRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sV0FBVyxDQUFBO0FBRXJDLE1BQU0sQ0FBQyxLQUFLLFVBQVUsVUFBVSxDQUFDLFFBQTJCO0lBQzFELElBQUksT0FBTyxHQUFHLE1BQU0sY0FBYyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQTtJQUNwRCxJQUFJLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDYixPQUFPLEdBQUcsTUFBTSxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUE7SUFDeEMsQ0FBQztJQUVELE1BQU0sS0FBSyxHQUFHLE1BQU0sU0FBUyxDQUMzQixFQUFFLEdBQUcsUUFBUSxFQUFFLE9BQU8sRUFBRSxFQUN4QixFQUFFLFlBQVksRUFBRSxJQUFJLEVBQUUsQ0FDdkIsQ0FBQTtJQUVELElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNYLE9BQU8sU0FBUyxDQUFBO0lBQ2xCLENBQUM7SUFFRCxJQUFJLE1BQU0sR0FBRyxNQUFNLGFBQWEsQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLENBQUE7SUFDakQsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ1osTUFBTSxHQUFHLE1BQU0sb0JBQW9CLENBQUMsS0FBSyxDQUFDLENBQUE7SUFDNUMsQ0FBQztJQUVELE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxDQUFBO0FBQ25DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFJlc291cmNlIH0gZnJvbSBcIkBmcmljdGlvbmxlc3MtdHMvbWV0YWRhdGFcIlxuaW1wb3J0IHsgcmVzb2x2ZURpYWxlY3QsIHJlc29sdmVTY2hlbWEgfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy9tZXRhZGF0YVwiXG5pbXBvcnQgeyBpbmZlclNjaGVtYUZyb21UYWJsZSB9IGZyb20gXCJAZnJpY3Rpb25sZXNzLXRzL3RhYmxlXCJcbmltcG9ydCB7IGluZmVyRGlhbGVjdCB9IGZyb20gXCIuLi9kaWFsZWN0L2luZGV4LnRzXCJcbmltcG9ydCB7IGxvYWRUYWJsZSB9IGZyb20gXCIuL2xvYWQudHNcIlxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaW5mZXJUYWJsZShyZXNvdXJjZTogUGFydGlhbDxSZXNvdXJjZT4pIHtcbiAgbGV0IGRpYWxlY3QgPSBhd2FpdCByZXNvbHZlRGlhbGVjdChyZXNvdXJjZS5kaWFsZWN0KVxuICBpZiAoIWRpYWxlY3QpIHtcbiAgICBkaWFsZWN0ID0gYXdhaXQgaW5mZXJEaWFsZWN0KHJlc291cmNlKVxuICB9XG5cbiAgY29uc3QgdGFibGUgPSBhd2FpdCBsb2FkVGFibGUoXG4gICAgeyAuLi5yZXNvdXJjZSwgZGlhbGVjdCB9LFxuICAgIHsgZGVub3JtYWxpemVkOiB0cnVlIH0sXG4gIClcblxuICBpZiAoIXRhYmxlKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZFxuICB9XG5cbiAgbGV0IHNjaGVtYSA9IGF3YWl0IHJlc29sdmVTY2hlbWEocmVzb3VyY2Uuc2NoZW1hKVxuICBpZiAoIXNjaGVtYSkge1xuICAgIHNjaGVtYSA9IGF3YWl0IGluZmVyU2NoZW1hRnJvbVRhYmxlKHRhYmxlKVxuICB9XG5cbiAgcmV0dXJuIHsgZGlhbGVjdCwgc2NoZW1hLCB0YWJsZSB9XG59XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import { writeTempFile } from "@frictionless-ts/dataset";
|
|
2
|
+
import { describe, expect, it } from "vitest";
|
|
3
|
+
import { inferTable } from "./infer.js";
|
|
4
|
+
describe("inferTable", () => {
|
|
5
|
+
it("should infer table with dialect and schema from CSV", async () => {
|
|
6
|
+
const csvPath = await writeTempFile("id,name\n1,alice\n2,bob");
|
|
7
|
+
const resource = { path: csvPath, format: "csv" };
|
|
8
|
+
const result = await inferTable(resource);
|
|
9
|
+
expect(result).toBeDefined();
|
|
10
|
+
expect(result?.dialect).toBeDefined();
|
|
11
|
+
expect(result?.schema).toBeDefined();
|
|
12
|
+
expect(result?.table).toBeDefined();
|
|
13
|
+
});
|
|
14
|
+
it("should use provided dialect when available", async () => {
|
|
15
|
+
const csvPath = await writeTempFile("id|name\n1|alice\n2|bob");
|
|
16
|
+
const resource = {
|
|
17
|
+
path: csvPath,
|
|
18
|
+
format: "csv",
|
|
19
|
+
dialect: { delimiter: "|" },
|
|
20
|
+
};
|
|
21
|
+
const result = await inferTable(resource);
|
|
22
|
+
expect(result).toBeDefined();
|
|
23
|
+
expect(result?.dialect).toBeDefined();
|
|
24
|
+
expect(result?.dialect.delimiter).toBe("|");
|
|
25
|
+
expect(result?.schema).toBeDefined();
|
|
26
|
+
expect(result?.table).toBeDefined();
|
|
27
|
+
});
|
|
28
|
+
it("should use provided schema when available", async () => {
|
|
29
|
+
const csvPath = await writeTempFile("id,name\n1,alice\n2,bob");
|
|
30
|
+
const resource = {
|
|
31
|
+
path: csvPath,
|
|
32
|
+
format: "csv",
|
|
33
|
+
schema: {
|
|
34
|
+
fields: [
|
|
35
|
+
{ name: "id", type: "integer" },
|
|
36
|
+
{ name: "name", type: "string" },
|
|
37
|
+
],
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
const result = await inferTable(resource);
|
|
41
|
+
expect(result).toBeDefined();
|
|
42
|
+
expect(result?.dialect).toBeDefined();
|
|
43
|
+
expect(result?.schema).toBeDefined();
|
|
44
|
+
expect(result?.schema.fields).toHaveLength(2);
|
|
45
|
+
expect(result?.table).toBeDefined();
|
|
46
|
+
});
|
|
47
|
+
it("should infer table with custom delimiter", async () => {
|
|
48
|
+
const csvPath = await writeTempFile("id;name;age\n1;alice;25\n2;bob;30");
|
|
49
|
+
const resource = {
|
|
50
|
+
path: csvPath,
|
|
51
|
+
format: "csv",
|
|
52
|
+
dialect: { delimiter: ";" },
|
|
53
|
+
};
|
|
54
|
+
const result = await inferTable(resource);
|
|
55
|
+
expect(result).toBeDefined();
|
|
56
|
+
expect(result?.dialect).toBeDefined();
|
|
57
|
+
expect(result?.dialect.delimiter).toBe(";");
|
|
58
|
+
expect(result?.schema).toBeDefined();
|
|
59
|
+
expect(result?.table).toBeDefined();
|
|
60
|
+
});
|
|
61
|
+
it("should infer table from inline data", async () => {
|
|
62
|
+
const resource = {
|
|
63
|
+
name: "test-resource",
|
|
64
|
+
type: "table",
|
|
65
|
+
data: [
|
|
66
|
+
{ id: 1, name: "alice" },
|
|
67
|
+
{ id: 2, name: "bob" },
|
|
68
|
+
],
|
|
69
|
+
};
|
|
70
|
+
const result = await inferTable(resource);
|
|
71
|
+
expect(result).toBeDefined();
|
|
72
|
+
expect(result?.dialect).toBeDefined();
|
|
73
|
+
expect(result?.schema).toBeDefined();
|
|
74
|
+
expect(result?.table).toBeDefined();
|
|
75
|
+
});
|
|
76
|
+
it("should infer schema with various data types", async () => {
|
|
77
|
+
const csvPath = await writeTempFile("id,name,score,active\n1,alice,95.5,true\n2,bob,87.3,false");
|
|
78
|
+
const resource = { path: csvPath, format: "csv" };
|
|
79
|
+
const result = await inferTable(resource);
|
|
80
|
+
expect(result).toBeDefined();
|
|
81
|
+
expect(result?.schema).toBeDefined();
|
|
82
|
+
expect(result?.schema.fields).toBeDefined();
|
|
83
|
+
expect(result?.table).toBeDefined();
|
|
84
|
+
});
|
|
85
|
+
it("should infer table with numeric columns", async () => {
|
|
86
|
+
const csvPath = await writeTempFile("id,score\n1,95.5\n2,87.3\n3,100");
|
|
87
|
+
const resource = { path: csvPath, format: "csv" };
|
|
88
|
+
const result = await inferTable(resource);
|
|
89
|
+
expect(result).toBeDefined();
|
|
90
|
+
expect(result?.schema).toBeDefined();
|
|
91
|
+
expect(result?.schema.fields).toBeDefined();
|
|
92
|
+
expect(result?.table).toBeDefined();
|
|
93
|
+
});
|
|
94
|
+
it("should infer table with date columns", async () => {
|
|
95
|
+
const csvPath = await writeTempFile("id,created\n1,2024-01-01\n2,2024-01-02");
|
|
96
|
+
const resource = { path: csvPath, format: "csv" };
|
|
97
|
+
const result = await inferTable(resource);
|
|
98
|
+
expect(result).toBeDefined();
|
|
99
|
+
expect(result?.schema).toBeDefined();
|
|
100
|
+
expect(result?.table).toBeDefined();
|
|
101
|
+
});
|
|
102
|
+
it("should infer table with boolean columns", async () => {
|
|
103
|
+
const csvPath = await writeTempFile("id,active\n1,true\n2,false\n3,true");
|
|
104
|
+
const resource = { path: csvPath, format: "csv" };
|
|
105
|
+
const result = await inferTable(resource);
|
|
106
|
+
expect(result).toBeDefined();
|
|
107
|
+
expect(result?.schema).toBeDefined();
|
|
108
|
+
expect(result?.table).toBeDefined();
|
|
109
|
+
});
|
|
110
|
+
it("should handle table with quoted fields", async () => {
|
|
111
|
+
const csvPath = await writeTempFile('id,name,description\n1,"alice","Test, data"\n2,"bob","Normal"');
|
|
112
|
+
const resource = { path: csvPath, format: "csv" };
|
|
113
|
+
const result = await inferTable(resource);
|
|
114
|
+
expect(result).toBeDefined();
|
|
115
|
+
expect(result?.dialect).toBeDefined();
|
|
116
|
+
expect(result?.schema).toBeDefined();
|
|
117
|
+
expect(result?.table).toBeDefined();
|
|
118
|
+
});
|
|
119
|
+
it("should infer table with single row", async () => {
|
|
120
|
+
const csvPath = await writeTempFile("id,name\n1,alice");
|
|
121
|
+
const resource = { path: csvPath, format: "csv" };
|
|
122
|
+
const result = await inferTable(resource);
|
|
123
|
+
expect(result).toBeDefined();
|
|
124
|
+
expect(result?.dialect).toBeDefined();
|
|
125
|
+
expect(result?.schema).toBeDefined();
|
|
126
|
+
expect(result?.table).toBeDefined();
|
|
127
|
+
});
|
|
128
|
+
it("should infer table with empty values", async () => {
|
|
129
|
+
const csvPath = await writeTempFile("id,name\n1,alice\n2,");
|
|
130
|
+
const resource = { path: csvPath, format: "csv" };
|
|
131
|
+
const result = await inferTable(resource);
|
|
132
|
+
expect(result).toBeDefined();
|
|
133
|
+
expect(result?.schema).toBeDefined();
|
|
134
|
+
expect(result?.table).toBeDefined();
|
|
135
|
+
});
|
|
136
|
+
it("should infer table with headers only", async () => {
|
|
137
|
+
const csvPath = await writeTempFile("id,name,age");
|
|
138
|
+
const resource = { path: csvPath, format: "csv" };
|
|
139
|
+
const result = await inferTable(resource);
|
|
140
|
+
expect(result).toBeDefined();
|
|
141
|
+
});
|
|
142
|
+
it("should use both provided dialect and schema", async () => {
|
|
143
|
+
const csvPath = await writeTempFile("id|name\n1|alice\n2|bob");
|
|
144
|
+
const resource = {
|
|
145
|
+
path: csvPath,
|
|
146
|
+
format: "csv",
|
|
147
|
+
dialect: { delimiter: "|" },
|
|
148
|
+
schema: {
|
|
149
|
+
fields: [
|
|
150
|
+
{ name: "id", type: "integer" },
|
|
151
|
+
{ name: "name", type: "string" },
|
|
152
|
+
],
|
|
153
|
+
},
|
|
154
|
+
};
|
|
155
|
+
const result = await inferTable(resource);
|
|
156
|
+
expect(result).toBeDefined();
|
|
157
|
+
expect(result?.dialect).toBeDefined();
|
|
158
|
+
expect(result?.dialect.delimiter).toBe("|");
|
|
159
|
+
expect(result?.schema).toBeDefined();
|
|
160
|
+
expect(result?.schema.fields).toHaveLength(2);
|
|
161
|
+
expect(result?.table).toBeDefined();
|
|
162
|
+
});
|
|
163
|
+
it("should infer table with tab delimiter", async () => {
|
|
164
|
+
const csvPath = await writeTempFile("id\tname\n1\talice\n2\tbob");
|
|
165
|
+
const resource = {
|
|
166
|
+
path: csvPath,
|
|
167
|
+
format: "csv",
|
|
168
|
+
dialect: { delimiter: "\t" },
|
|
169
|
+
};
|
|
170
|
+
const result = await inferTable(resource);
|
|
171
|
+
expect(result).toBeDefined();
|
|
172
|
+
expect(result?.dialect).toBeDefined();
|
|
173
|
+
expect(result?.schema).toBeDefined();
|
|
174
|
+
expect(result?.table).toBeDefined();
|
|
175
|
+
});
|
|
176
|
+
});
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infer.spec.js","sourceRoot":"","sources":["../../table/infer.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAA;AACxD,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AAC7C,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AAEvC,QAAQ,CAAC,YAAY,EAAE,GAAG,EAAE;IAC1B,EAAE,CAAC,qDAAqD,EAAE,KAAK,IAAI,EAAE;QACnE,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,yBAAyB,CAAC,CAAA;QAC9D,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAc,EAAE,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACrC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;QAC1D,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,yBAAyB,CAAC,CAAA;QAC9D,MAAM,QAAQ,GAAG;YACf,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,KAAc;YACtB,OAAO,EAAE,EAAE,SAAS,EAAE,GAAG,EAAE;SAC5B,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACrC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC3C,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,2CAA2C,EAAE,KAAK,IAAI,EAAE;QACzD,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,yBAAyB,CAAC,CAAA;QAC9D,MAAM,QAAQ,GAAG;YACf,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,KAAc;YACtB,MAAM,EAAE;gBACN,MAAM,EAAE;oBACN,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,SAAkB,EAAE;oBACxC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,QAAiB,EAAE;iBAC1C;aACF;SACF,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACrC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;QAC7C,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,0CAA0C,EAAE,KAAK,IAAI,EAAE;QACxD,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,mCAAmC,CAAC,CAAA;QACxE,MAAM,QAAQ,GAAG;YACf,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,KAAc;YACtB,OAAO,EAAE,EAAE,SAAS,EAAE,GAAG,EAAE;SAC5B,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACrC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC3C,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,qCAAqC,EAAE,KAAK,IAAI,EAAE;QACnD,MAAM,QAAQ,GAAG;YACf,IAAI,EAAE,eAAe;YACrB,IAAI,EAAE,OAAgB;YACtB,IAAI,EAAE;gBACJ,EAAE,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE;gBACxB,EAAE,EAAE,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE;aACvB;SACF,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACrC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC3D,MAAM,OAAO,GAAG,MAAM,aAAa,CACjC,2DAA2D,CAC5D,CAAA;QACD,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAc,EAAE,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC3C,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,iCAAiC,CAAC,CAAA;QACtE,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAc,EAAE,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC3C,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,OAAO,GAAG,MAAM,aAAa,CACjC,wCAAwC,CACzC,CAAA;QACD,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAc,EAAE,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;QACvD,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,oCAAoC,CAAC,CAAA;QACzE,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAc,EAAE,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,wCAAwC,EAAE,KAAK,IAAI,EAAE;QACtD,MAAM,OAAO,GAAG,MAAM,aAAa,CACjC,+DAA+D,CAChE,CAAA;QACD,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAc,EAAE,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACrC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,oCAAoC,EAAE,KAAK,IAAI,EAAE;QAClD,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,kBAAkB,CAAC,CAAA;QACvD,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAc,EAAE,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACrC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,sBAAsB,CAAC,CAAA;QAC3D,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAc,EAAE,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;QACpD,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,aAAa,CAAC,CAAA;QAClD,MAAM,QAAQ,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,KAAc,EAAE,CAAA;QAE1D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;IAC9B,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,6CAA6C,EAAE,KAAK,IAAI,EAAE;QAC3D,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,yBAAyB,CAAC,CAAA;QAC9D,MAAM,QAAQ,GAAG;YACf,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,KAAc;YACtB,OAAO,EAAE,EAAE,SAAS,EAAE,GAAG,EAAE;YAC3B,MAAM,EAAE;gBACN,MAAM,EAAE;oBACN,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,SAAkB,EAAE;oBACxC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,QAAiB,EAAE;iBAC1C;aACF;SACF,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACrC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;QAC3C,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAA;QAC7C,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,uCAAuC,EAAE,KAAK,IAAI,EAAE;QACrD,MAAM,OAAO,GAAG,MAAM,aAAa,CAAC,4BAA4B,CAAC,CAAA;QACjE,MAAM,QAAQ,GAAG;YACf,IAAI,EAAE,OAAO;YACb,MAAM,EAAE,KAAc;YACtB,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE;SAC7B,CAAA;QAED,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAA;QAEzC,MAAM,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QAC5B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,WAAW,EAAE,CAAA;QACrC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,WAAW,EAAE,CAAA;QACpC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,WAAW,EAAE,CAAA;IACrC,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA","sourcesContent":["import { writeTempFile } from \"@frictionless-ts/dataset\"\nimport { describe, expect, it } from \"vitest\"\nimport { inferTable } from \"./infer.ts\"\n\ndescribe(\"inferTable\", () => {\n  it(\"should infer table with dialect and schema from CSV\", async () => {\n    const csvPath = await writeTempFile(\"id,name\\n1,alice\\n2,bob\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.dialect).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should use provided dialect when available\", async () => {\n    const csvPath = await writeTempFile(\"id|name\\n1|alice\\n2|bob\")\n    const resource = {\n      path: csvPath,\n      format: \"csv\" as const,\n      dialect: { delimiter: \"|\" },\n    }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.dialect).toBeDefined()\n    expect(result?.dialect.delimiter).toBe(\"|\")\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should use provided schema when available\", async () => {\n    const csvPath = await writeTempFile(\"id,name\\n1,alice\\n2,bob\")\n    const resource = {\n      path: csvPath,\n      format: \"csv\" as const,\n      schema: {\n        fields: [\n          { name: \"id\", type: \"integer\" as const },\n          { name: \"name\", type: \"string\" as const },\n        ],\n      },\n    }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.dialect).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.schema.fields).toHaveLength(2)\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer table with custom delimiter\", async () => {\n    const csvPath = await writeTempFile(\"id;name;age\\n1;alice;25\\n2;bob;30\")\n    const resource = {\n      path: csvPath,\n      format: \"csv\" as const,\n      dialect: { delimiter: \";\" },\n    }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.dialect).toBeDefined()\n    expect(result?.dialect.delimiter).toBe(\";\")\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer table from inline data\", async () => {\n    const resource = {\n      name: \"test-resource\",\n      type: \"table\" as const,\n      data: [\n        { id: 1, name: \"alice\" },\n        { id: 2, name: \"bob\" },\n      ],\n    }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.dialect).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer schema with various data types\", async () => {\n    const csvPath = await writeTempFile(\n      \"id,name,score,active\\n1,alice,95.5,true\\n2,bob,87.3,false\",\n    )\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.schema.fields).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer table with numeric columns\", async () => {\n    const csvPath = await writeTempFile(\"id,score\\n1,95.5\\n2,87.3\\n3,100\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.schema.fields).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer table with date columns\", async () => {\n    const csvPath = await writeTempFile(\n      \"id,created\\n1,2024-01-01\\n2,2024-01-02\",\n    )\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer table with boolean columns\", async () => {\n    const csvPath = await writeTempFile(\"id,active\\n1,true\\n2,false\\n3,true\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should handle table with quoted fields\", async () => {\n    const csvPath = await writeTempFile(\n      'id,name,description\\n1,\"alice\",\"Test, data\"\\n2,\"bob\",\"Normal\"',\n    )\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.dialect).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer table with single row\", async () => {\n    const csvPath = await writeTempFile(\"id,name\\n1,alice\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.dialect).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer table with empty values\", async () => {\n    const csvPath = await writeTempFile(\"id,name\\n1,alice\\n2,\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer table with headers only\", async () => {\n    const csvPath = await writeTempFile(\"id,name,age\")\n    const resource = { path: csvPath, format: \"csv\" as const }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n  })\n\n  it(\"should use both provided dialect and schema\", async () => {\n    const csvPath = await writeTempFile(\"id|name\\n1|alice\\n2|bob\")\n    const resource = {\n      path: csvPath,\n      format: \"csv\" as const,\n      dialect: { delimiter: \"|\" },\n      schema: {\n        fields: [\n          { name: \"id\", type: \"integer\" as const },\n          { name: \"name\", type: \"string\" as const },\n        ],\n      },\n    }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.dialect).toBeDefined()\n    expect(result?.dialect.delimiter).toBe(\"|\")\n    expect(result?.schema).toBeDefined()\n    expect(result?.schema.fields).toHaveLength(2)\n    expect(result?.table).toBeDefined()\n  })\n\n  it(\"should infer table with tab delimiter\", async () => {\n    const csvPath = await writeTempFile(\"id\\tname\\n1\\talice\\n2\\tbob\")\n    const resource = {\n      path: csvPath,\n      format: \"csv\" as const,\n      dialect: { delimiter: \"\\t\" },\n    }\n\n    const result = await inferTable(resource)\n\n    expect(result).toBeDefined()\n    expect(result?.dialect).toBeDefined()\n    expect(result?.schema).toBeDefined()\n    expect(result?.table).toBeDefined()\n  })\n})\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { Resource } from "@frictionless-ts/metadata";
|
|
2
|
+
import type { LoadTableOptions } from "@frictionless-ts/table";
|
|
3
|
+
export declare function loadTable(resource: Partial<Resource>, options?: LoadTableOptions): Promise<import("@frictionless-ts/table").Table | undefined>;
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { system } from "../system.js";
|
|
2
|
+
export async function loadTable(resource, options) {
|
|
3
|
+
for (const plugin of system.plugins) {
|
|
4
|
+
const table = await plugin.loadTable?.(resource, options);
|
|
5
|
+
if (table) {
|
|
6
|
+
return table;
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
return undefined;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3RhYmxlL2xvYWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGNBQWMsQ0FBQTtBQUVyQyxNQUFNLENBQUMsS0FBSyxVQUFVLFNBQVMsQ0FDN0IsUUFBMkIsRUFDM0IsT0FBMEI7SUFFMUIsS0FBSyxNQUFNLE1BQU0sSUFBSSxNQUFNLENBQUMsT0FBTyxFQUFFLENBQUM7UUFDcEMsTUFBTSxLQUFLLEdBQUcsTUFBTSxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxDQUFBO1FBQ3pELElBQUksS0FBSyxFQUFFLENBQUM7WUFDVixPQUFPLEtBQUssQ0FBQTtRQUNkLENBQUM7SUFDSCxDQUFDO0lBRUQsT0FBTyxTQUFTLENBQUE7QUFDbEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUmVzb3VyY2UgfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy9tZXRhZGF0YVwiXG5pbXBvcnQgdHlwZSB7IExvYWRUYWJsZU9wdGlvbnMgfSBmcm9tIFwiQGZyaWN0aW9ubGVzcy10cy90YWJsZVwiXG5pbXBvcnQgeyBzeXN0ZW0gfSBmcm9tIFwiLi4vc3lzdGVtLnRzXCJcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGxvYWRUYWJsZShcbiAgcmVzb3VyY2U6IFBhcnRpYWw8UmVzb3VyY2U+LFxuICBvcHRpb25zPzogTG9hZFRhYmxlT3B0aW9ucyxcbikge1xuICBmb3IgKGNvbnN0IHBsdWdpbiBvZiBzeXN0ZW0ucGx1Z2lucykge1xuICAgIGNvbnN0IHRhYmxlID0gYXdhaXQgcGx1Z2luLmxvYWRUYWJsZT8uKHJlc291cmNlLCBvcHRpb25zKVxuICAgIGlmICh0YWJsZSkge1xuICAgICAgcmV0dXJuIHRhYmxlXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIHVuZGVmaW5lZFxufVxuIl19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|