goby-database 2.0.13 → 2.0.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,10 +1,16 @@
1
1
  {
2
2
  "name": "goby-database",
3
- "version": "2.0.13",
3
+ "version": "2.0.14",
4
4
  "description": "This will hold the core better-sqlite3-powered application for creating and modifying goby databases",
5
5
  "main": "dist/index.js",
6
6
  "files": [
7
- "/dist"
7
+ "/dist",
8
+ "!dist/sandbox.js",
9
+ "!dist/sandbox.d.ts",
10
+ "!dist/sandbox.js.map",
11
+ "!dist/unit-tests.js",
12
+ "!dist/unit-tests.d.ts",
13
+ "!dist/unit-tests.js.map"
8
14
  ],
9
15
  "types": "dist/index.d.ts",
10
16
  "scripts": {
package/dist/sandbox.d.ts DELETED
@@ -1 +0,0 @@
1
- export {};
package/dist/sandbox.js DELETED
@@ -1,94 +0,0 @@
1
- import { readable_junctionlist } from './utils.js';
2
- console.log('--------------------------------------------------------');
3
- console.log('SANDBOX: running test...\n');
4
- import Project from './index.js';
5
- const project = new Project(':memory:');
6
- console.log('--------------------------------------------------------');
7
- console.log('SANDBOX: setting up book-author-script schema\n');
8
- project.action_edit_class_schema({
9
- class_edits: [
10
- { type: 'create', class_name: 'author' },
11
- { type: 'create', class_name: 'book' },
12
- { type: 'create', class_name: 'script' }
13
- ],
14
- property_edits: [
15
- { type: 'create', class_name: 'author', prop_name: 'age', config: { type: 'data', data_type: 'number', max_values: 1 } },
16
- { type: 'create', class_name: 'author', prop_name: 'works', config: { type: 'relation', max_values: null } },
17
- { type: 'create', class_name: 'author', prop_name: 'books read', config: { type: 'relation', max_values: null } },
18
- { type: 'create', class_name: 'book', prop_name: 'author', config: { type: 'relation', max_values: 1 } }
19
- ],
20
- relationship_edits: [
21
- { type: 'create', sides: [{ class_name: 'author', prop_name: 'works' }, { class_name: 'book', prop_name: 'author' }] },
22
- { type: 'create', sides: [{ class_name: 'author', prop_name: 'works' }, { class_name: 'script' }] },
23
- { type: 'create', sides: [{ class_name: 'author', prop_name: 'books read' }, { class_name: 'book' }] }
24
- ]
25
- });
26
- console.log(project.junction_cache.map(a => a.sides));
27
- console.log('--------------------------------------------------------');
28
- console.log('SANDBOX: adding items to classes\n');
29
- project.action_add_row(1);
30
- project.action_add_row(2);
31
- project.action_add_row(2);
32
- project.action_add_row(3);
33
- console.log('--------------------------------------------------------');
34
- console.log('SANDBOX: making connections between items in classes\n');
35
- project.action_make_relation({
36
- class_id: 1,
37
- prop_id: 3,
38
- item_id: 1
39
- }, {
40
- class_id: 2,
41
- prop_id: 2,
42
- item_id: 2
43
- });
44
- project.action_make_relation({
45
- class_id: 1,
46
- prop_id: 3,
47
- item_id: 1
48
- }, {
49
- class_id: 2,
50
- prop_id: 2,
51
- item_id: 3
52
- });
53
- project.action_make_relation({
54
- class_id: 1,
55
- prop_id: 3,
56
- item_id: 1
57
- }, {
58
- class_id: 3,
59
- item_id: 4
60
- });
61
- project.action_make_relation({
62
- class_id: 1,
63
- prop_id: 4,
64
- item_id: 1
65
- }, {
66
- class_id: 2,
67
- item_id: 2
68
- });
69
- project.refresh_caches(['classlist', 'items', 'junctions']);
70
- console.log('--------------------------------------------------------');
71
- console.log('SANDBOX: deleting author property in books\n');
72
- project.action_edit_class_schema({
73
- property_edits: [
74
- {
75
- type: 'delete',
76
- class_id: 2,
77
- prop_id: 2
78
- },
79
- {
80
- type: 'create',
81
- class_id: 2,
82
- prop_name: 'author2',
83
- config: {
84
- type: 'relation',
85
- max_values: 1
86
- }
87
- }
88
- ],
89
- relationship_edits: [
90
- { type: 'create', sides: [{ class_id: 1, prop_id: 3 }, { class_id: 2, prop_name: 'author2' }] }
91
- ]
92
- });
93
- console.log(readable_junctionlist(project.junction_cache, project.class_cache));
94
- //# sourceMappingURL=sandbox.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sandbox.js","sourceRoot":"","sources":["../src/sandbox.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- export {};
@@ -1,82 +0,0 @@
1
- import { partial_relation_match } from "./utils.js";
2
- testRelationMatching();
3
- function testRelationMatching() {
4
- const test1_old = [
5
- { class_id: 1, prop_id: 100 },
6
- { class_id: 2, prop_id: 200 },
7
- ];
8
- const test1_new = [
9
- { class_id: 1, prop_id: 100 },
10
- { class_id: 2, prop_id: 300 },
11
- ];
12
- const test2_old = [
13
- { class_id: 1, prop_id: 100 },
14
- { class_id: 2, prop_id: 200 },
15
- ];
16
- const test2_new = [
17
- { class_id: 1, prop_id: 300 },
18
- { class_id: 2, prop_id: 400 },
19
- ];
20
- // Case 3: Non-matching classes
21
- const test3_old = [
22
- { class_id: 1, prop_id: 100 },
23
- { class_id: 2, prop_id: 200 },
24
- ];
25
- const test3_new = [
26
- { class_id: 3, prop_id: 100 },
27
- { class_id: 4, prop_id: 200 },
28
- ];
29
- const test4a_old = [
30
- { class_id: 1, prop_id: 100 },
31
- { class_id: 1, prop_id: 200 },
32
- ];
33
- const test4a_new = [
34
- { class_id: 1, prop_id: 100 },
35
- { class_id: 1, prop_id: 300 },
36
- ];
37
- // Case 4b: Same class on both sides with no matching properties
38
- const test4b_old = [
39
- { class_id: 1, prop_id: 100 },
40
- { class_id: 1, prop_id: 200 },
41
- ];
42
- const test4b_new = [
43
- { class_id: 1, prop_id: 300 },
44
- { class_id: 1, prop_id: 400 },
45
- ];
46
- // Case 5: Reversed order matching
47
- const test5_old = [
48
- { class_id: 1, prop_id: 100 },
49
- { class_id: 2, prop_id: 200 },
50
- ];
51
- const test5_new = [
52
- { class_id: 2, prop_id: 200 },
53
- { class_id: 1, prop_id: 300 },
54
- ];
55
- // Case 6: Undefined property IDs
56
- const test6_old = [
57
- { class_id: 1 },
58
- { class_id: 2, prop_id: 200 },
59
- ];
60
- const test6_new = [
61
- { class_id: 1, prop_id: 100 },
62
- { class_id: 2 },
63
- ];
64
- // Case 7: Undefined property IDs on same side
65
- const test7_old = [
66
- { class_id: 1 },
67
- { class_id: 2, prop_id: 200 },
68
- ];
69
- const test7_new = [
70
- { class_id: 1 },
71
- { class_id: 2, prop_id: 100 },
72
- ];
73
- console.log("same class, at least one prop (expect true)", partial_relation_match(test1_new, test1_old));
74
- console.log("same class, no props (expect false)", partial_relation_match(test2_old, test2_new));
75
- console.log("different classes (expect false)", partial_relation_match(test3_old, test3_new));
76
- console.log("only one class, matching prop (expect true)", partial_relation_match(test4a_new, test4a_old));
77
- console.log("only one class, no props (expect false)", partial_relation_match(test4b_old, test4b_new));
78
- console.log("reversed class order, prop matching (expect true)", partial_relation_match(test5_new, test5_old));
79
- console.log("undefined prop (expect false)", partial_relation_match(test6_old, test6_new));
80
- console.log("undefined prop 2 (expect false)", partial_relation_match(test7_old, test7_new));
81
- }
82
- //# sourceMappingURL=unit-tests.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"unit-tests.js","sourceRoot":"","sources":["../src/unit-tests.ts"],"names":[],"mappings":"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"}