knex 3.2.2 → 3.2.4

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.
Files changed (199) hide show
  1. package/CHANGELOG.md +2447 -2441
  2. package/CONTRIBUTING.md +190 -190
  3. package/LICENSE +22 -22
  4. package/README.md +156 -156
  5. package/UPGRADING.md +245 -245
  6. package/bin/cli.js +516 -516
  7. package/bin/knexfile-runtime-error.js +27 -27
  8. package/bin/utils/cli-config-utils.js +217 -217
  9. package/bin/utils/constants.js +7 -7
  10. package/bin/utils/migrationsLister.js +37 -37
  11. package/knex.js +23 -23
  12. package/knex.mjs +11 -11
  13. package/lib/builder-interface-augmenter.js +120 -120
  14. package/lib/client.js +585 -585
  15. package/lib/constants.js +61 -61
  16. package/lib/dialects/better-sqlite3/index.js +101 -101
  17. package/lib/dialects/cockroachdb/crdb-columncompiler.js +14 -14
  18. package/lib/dialects/cockroachdb/crdb-querybuilder.js +11 -11
  19. package/lib/dialects/cockroachdb/crdb-querycompiler.js +122 -122
  20. package/lib/dialects/cockroachdb/crdb-tablecompiler.js +46 -46
  21. package/lib/dialects/cockroachdb/crdb-viewcompiler.js +15 -15
  22. package/lib/dialects/cockroachdb/index.js +86 -86
  23. package/lib/dialects/index.js +34 -34
  24. package/lib/dialects/mssql/index.js +498 -498
  25. package/lib/dialects/mssql/mssql-formatter.js +34 -34
  26. package/lib/dialects/mssql/query/mssql-querycompiler.js +601 -601
  27. package/lib/dialects/mssql/schema/mssql-columncompiler.js +185 -185
  28. package/lib/dialects/mssql/schema/mssql-compiler.js +91 -91
  29. package/lib/dialects/mssql/schema/mssql-tablecompiler.js +393 -393
  30. package/lib/dialects/mssql/schema/mssql-viewcompiler.js +55 -55
  31. package/lib/dialects/mssql/transaction.js +176 -176
  32. package/lib/dialects/mysql/index.js +317 -317
  33. package/lib/dialects/mysql/query/mysql-querybuilder.js +14 -14
  34. package/lib/dialects/mysql/query/mysql-querycompiler.js +292 -292
  35. package/lib/dialects/mysql/schema/mysql-columncompiler.js +193 -193
  36. package/lib/dialects/mysql/schema/mysql-compiler.js +60 -60
  37. package/lib/dialects/mysql/schema/mysql-tablecompiler.js +426 -426
  38. package/lib/dialects/mysql/schema/mysql-viewbuilder.js +21 -21
  39. package/lib/dialects/mysql/schema/mysql-viewcompiler.js +15 -15
  40. package/lib/dialects/mysql/transaction.js +46 -46
  41. package/lib/dialects/mysql2/index.js +53 -53
  42. package/lib/dialects/mysql2/transaction.js +44 -44
  43. package/lib/dialects/oracle/DEAD_CODE.md +5 -5
  44. package/lib/dialects/oracle/index.js +92 -92
  45. package/lib/dialects/oracle/query/oracle-querycompiler.js +343 -343
  46. package/lib/dialects/oracle/schema/internal/incrementUtils.js +22 -22
  47. package/lib/dialects/oracle/schema/internal/trigger.js +155 -155
  48. package/lib/dialects/oracle/schema/oracle-columnbuilder.js +17 -17
  49. package/lib/dialects/oracle/schema/oracle-columncompiler.js +126 -126
  50. package/lib/dialects/oracle/schema/oracle-compiler.js +124 -124
  51. package/lib/dialects/oracle/schema/oracle-tablecompiler.js +210 -210
  52. package/lib/dialects/oracle/utils.js +107 -107
  53. package/lib/dialects/oracledb/index.js +381 -381
  54. package/lib/dialects/oracledb/query/oracledb-querycompiler.js +481 -481
  55. package/lib/dialects/oracledb/schema/oracledb-columncompiler.js +61 -61
  56. package/lib/dialects/oracledb/schema/oracledb-tablecompiler.js +19 -19
  57. package/lib/dialects/oracledb/schema/oracledb-viewbuilder.js +13 -13
  58. package/lib/dialects/oracledb/schema/oracledb-viewcompiler.js +19 -19
  59. package/lib/dialects/oracledb/transaction.js +98 -98
  60. package/lib/dialects/oracledb/utils.js +208 -208
  61. package/lib/dialects/pgnative/index.js +60 -60
  62. package/lib/dialects/postgres/execution/pg-transaction.js +19 -19
  63. package/lib/dialects/postgres/index.js +373 -373
  64. package/lib/dialects/postgres/query/pg-querybuilder.js +43 -43
  65. package/lib/dialects/postgres/query/pg-querycompiler.js +400 -400
  66. package/lib/dialects/postgres/schema/pg-columncompiler.js +162 -162
  67. package/lib/dialects/postgres/schema/pg-compiler.js +138 -138
  68. package/lib/dialects/postgres/schema/pg-tablecompiler.js +331 -331
  69. package/lib/dialects/postgres/schema/pg-viewbuilder.js +21 -21
  70. package/lib/dialects/postgres/schema/pg-viewcompiler.js +35 -35
  71. package/lib/dialects/redshift/index.js +86 -86
  72. package/lib/dialects/redshift/query/redshift-querycompiler.js +163 -163
  73. package/lib/dialects/redshift/schema/redshift-columnbuilder.js +22 -22
  74. package/lib/dialects/redshift/schema/redshift-columncompiler.js +67 -67
  75. package/lib/dialects/redshift/schema/redshift-compiler.js +14 -14
  76. package/lib/dialects/redshift/schema/redshift-tablecompiler.js +134 -134
  77. package/lib/dialects/redshift/schema/redshift-viewcompiler.js +11 -11
  78. package/lib/dialects/redshift/transaction.js +32 -32
  79. package/lib/dialects/sqlite3/execution/sqlite-transaction.js +172 -172
  80. package/lib/dialects/sqlite3/index.js +263 -263
  81. package/lib/dialects/sqlite3/query/sqlite-querybuilder.js +33 -33
  82. package/lib/dialects/sqlite3/query/sqlite-querycompiler.js +341 -341
  83. package/lib/dialects/sqlite3/schema/ddl.js +380 -380
  84. package/lib/dialects/sqlite3/schema/internal/compiler.js +327 -327
  85. package/lib/dialects/sqlite3/schema/internal/parser-combinator.js +161 -161
  86. package/lib/dialects/sqlite3/schema/internal/parser.js +638 -638
  87. package/lib/dialects/sqlite3/schema/internal/sqlite-ddl-operations.js +41 -41
  88. package/lib/dialects/sqlite3/schema/internal/tokenizer.js +38 -38
  89. package/lib/dialects/sqlite3/schema/internal/utils.js +12 -12
  90. package/lib/dialects/sqlite3/schema/sqlite-columncompiler.js +50 -50
  91. package/lib/dialects/sqlite3/schema/sqlite-compiler.js +80 -80
  92. package/lib/dialects/sqlite3/schema/sqlite-tablecompiler.js +364 -364
  93. package/lib/dialects/sqlite3/schema/sqlite-viewcompiler.js +40 -40
  94. package/lib/execution/batch-insert.js +51 -51
  95. package/lib/execution/internal/delay.js +6 -6
  96. package/lib/execution/internal/ensure-connection-callback.js +41 -41
  97. package/lib/execution/internal/query-executioner.js +62 -62
  98. package/lib/execution/runner.js +325 -325
  99. package/lib/execution/transaction.js +417 -417
  100. package/lib/formatter/formatterUtils.js +42 -42
  101. package/lib/formatter/rawFormatter.js +84 -84
  102. package/lib/formatter/wrappingFormatter.js +253 -253
  103. package/lib/formatter.js +25 -25
  104. package/lib/index.js +3 -3
  105. package/lib/knex-builder/FunctionHelper.js +80 -80
  106. package/lib/knex-builder/Knex.js +59 -59
  107. package/lib/knex-builder/internal/config-resolver.js +57 -57
  108. package/lib/knex-builder/internal/parse-connection.js +87 -87
  109. package/lib/knex-builder/make-knex.js +345 -345
  110. package/lib/logger.js +76 -76
  111. package/lib/migrations/common/MigrationsLoader.js +36 -36
  112. package/lib/migrations/migrate/MigrationGenerator.js +84 -84
  113. package/lib/migrations/migrate/Migrator.js +632 -632
  114. package/lib/migrations/migrate/migrate-stub.js +17 -17
  115. package/lib/migrations/migrate/migration-list-resolver.js +33 -33
  116. package/lib/migrations/migrate/migrator-configuration-merger.js +58 -58
  117. package/lib/migrations/migrate/sources/fs-migrations.js +74 -74
  118. package/lib/migrations/migrate/stub/cjs.stub +15 -15
  119. package/lib/migrations/migrate/stub/coffee.stub +13 -13
  120. package/lib/migrations/migrate/stub/eg.stub +14 -14
  121. package/lib/migrations/migrate/stub/js-schema.stub +22 -22
  122. package/lib/migrations/migrate/stub/js.stub +22 -22
  123. package/lib/migrations/migrate/stub/knexfile-coffee.stub +34 -34
  124. package/lib/migrations/migrate/stub/knexfile-eg.stub +43 -43
  125. package/lib/migrations/migrate/stub/knexfile-js.stub +47 -47
  126. package/lib/migrations/migrate/stub/knexfile-ls.stub +35 -35
  127. package/lib/migrations/migrate/stub/knexfile-ts.stub +47 -47
  128. package/lib/migrations/migrate/stub/ls.stub +14 -14
  129. package/lib/migrations/migrate/stub/mjs.stub +23 -23
  130. package/lib/migrations/migrate/stub/ts-schema.stub +21 -21
  131. package/lib/migrations/migrate/stub/ts.stub +21 -21
  132. package/lib/migrations/migrate/table-creator.js +77 -77
  133. package/lib/migrations/migrate/table-resolver.js +27 -27
  134. package/lib/migrations/seed/Seeder.js +137 -137
  135. package/lib/migrations/seed/seed-stub.js +13 -13
  136. package/lib/migrations/seed/seeder-configuration-merger.js +60 -60
  137. package/lib/migrations/seed/sources/fs-seeds.js +65 -65
  138. package/lib/migrations/seed/stub/coffee.stub +9 -9
  139. package/lib/migrations/seed/stub/eg.stub +11 -11
  140. package/lib/migrations/seed/stub/js.stub +13 -13
  141. package/lib/migrations/seed/stub/ls.stub +11 -11
  142. package/lib/migrations/seed/stub/mjs.stub +12 -12
  143. package/lib/migrations/seed/stub/ts.stub +13 -13
  144. package/lib/migrations/util/fs.js +86 -86
  145. package/lib/migrations/util/import-file.js +12 -12
  146. package/lib/migrations/util/is-module-type.js +9 -9
  147. package/lib/migrations/util/template.js +52 -52
  148. package/lib/migrations/util/timestamp.js +14 -14
  149. package/lib/query/analytic.js +52 -52
  150. package/lib/query/constants.js +15 -15
  151. package/lib/query/joinclause.js +270 -270
  152. package/lib/query/method-constants.js +136 -136
  153. package/lib/query/querybuilder.js +1793 -1793
  154. package/lib/query/querycompiler.js +1634 -1634
  155. package/lib/raw.js +139 -139
  156. package/lib/ref.js +39 -39
  157. package/lib/schema/builder.js +115 -115
  158. package/lib/schema/columnbuilder.js +146 -146
  159. package/lib/schema/columncompiler.js +307 -307
  160. package/lib/schema/compiler.js +187 -187
  161. package/lib/schema/internal/helpers.js +55 -55
  162. package/lib/schema/tablebuilder.js +379 -379
  163. package/lib/schema/tablecompiler.js +450 -450
  164. package/lib/schema/viewbuilder.js +92 -92
  165. package/lib/schema/viewcompiler.js +138 -138
  166. package/lib/util/finally-mixin.js +13 -13
  167. package/lib/util/helpers.js +95 -95
  168. package/lib/util/is.js +32 -32
  169. package/lib/util/nanoid.js +40 -40
  170. package/lib/util/noop.js +1 -1
  171. package/lib/util/save-async-stack.js +14 -14
  172. package/lib/util/security.js +32 -32
  173. package/lib/util/string.js +190 -190
  174. package/lib/util/timeout.js +29 -29
  175. package/package.json +294 -296
  176. package/scripts/act-testing/act.sh +19 -19
  177. package/scripts/act-testing/merged-no-label.json +11 -11
  178. package/scripts/act-testing/merged-patch-labeled.json +12 -12
  179. package/scripts/act-testing/merged-skip-labeled.json +12 -12
  180. package/scripts/act-testing/not-merged-patch-labeled.json +12 -12
  181. package/scripts/build-for-release.sh +121 -121
  182. package/scripts/build.js +125 -125
  183. package/scripts/clean.js +31 -31
  184. package/scripts/docker-compose.yml +150 -150
  185. package/scripts/format-changelog.js +55 -55
  186. package/scripts/next-release-howto.md +24 -24
  187. package/scripts/oracledb-install-driver-libs.sh +82 -82
  188. package/scripts/release.sh +36 -36
  189. package/scripts/runkit-example.js +35 -35
  190. package/scripts/stress-test/README.txt +18 -18
  191. package/scripts/stress-test/docker-compose.yml +55 -55
  192. package/scripts/stress-test/knex-stress-test.js +212 -212
  193. package/scripts/stress-test/mysql2-random-hanging-every-now-and-then.js +149 -149
  194. package/scripts/stress-test/mysql2-sudden-exit-without-error.js +101 -101
  195. package/scripts/stress-test/reconnect-test-mysql-based-drivers.js +188 -188
  196. package/types/index.d.mts +11 -0
  197. package/types/index.d.ts +3321 -3321
  198. package/types/result.d.ts +27 -27
  199. package/types/tables.d.ts +4 -4
package/scripts/clean.js CHANGED
@@ -1,31 +1,31 @@
1
- #!/usr/bin/env node
2
-
3
- const fs = require('fs');
4
- const path = require('path');
5
- const { execSync } = require('child_process');
6
-
7
- function main() {
8
- const repoDir = path.dirname(__dirname);
9
- const gitDir = path.join(repoDir, '.git');
10
- const gitDirExists = doesDirectoryExist(gitDir);
11
- if (!gitDirExists) {
12
- console.log("No .git directory detected so can not clean 'lib/'. Exiting.");
13
- process.exit(0);
14
- }
15
- console.log(
16
- "Cleaning 'lib/' of outputted files from Typescript compilation ..."
17
- );
18
- const cmd = 'git clean -f -X lib/';
19
- const output = execSync(cmd, { cwd: repoDir });
20
- console.log(output.toString('utf8'));
21
- console.log('Done');
22
- }
23
-
24
- function doesDirectoryExist(p) {
25
- if (fs.existsSync(p)) {
26
- return fs.lstatSync(p).isDirectory();
27
- }
28
- return false;
29
- }
30
-
31
- main();
1
+ #!/usr/bin/env node
2
+
3
+ const fs = require('fs');
4
+ const path = require('path');
5
+ const { execSync } = require('child_process');
6
+
7
+ function main() {
8
+ const repoDir = path.dirname(__dirname);
9
+ const gitDir = path.join(repoDir, '.git');
10
+ const gitDirExists = doesDirectoryExist(gitDir);
11
+ if (!gitDirExists) {
12
+ console.log("No .git directory detected so can not clean 'lib/'. Exiting.");
13
+ process.exit(0);
14
+ }
15
+ console.log(
16
+ "Cleaning 'lib/' of outputted files from Typescript compilation ..."
17
+ );
18
+ const cmd = 'git clean -f -X lib/';
19
+ const output = execSync(cmd, { cwd: repoDir });
20
+ console.log(output.toString('utf8'));
21
+ console.log('Done');
22
+ }
23
+
24
+ function doesDirectoryExist(p) {
25
+ if (fs.existsSync(p)) {
26
+ return fs.lstatSync(p).isDirectory();
27
+ }
28
+ return false;
29
+ }
30
+
31
+ main();
@@ -1,150 +1,150 @@
1
- services:
2
- mssql:
3
- image: mcr.microsoft.com/mssql/server:2019-latest
4
- ports:
5
- - '21433:1433'
6
- environment:
7
- - ACCEPT_EULA=Y
8
- - SA_PASSWORD=S0meVeryHardPassword
9
- healthcheck:
10
- test: /opt/mssql-tools/bin/sqlcmd -S mssql -U sa -P 'S0meVeryHardPassword' -Q 'select 1'
11
- waitmssql:
12
- image: mcr.microsoft.com/mssql/server:2017-latest
13
- links:
14
- - mssql
15
- depends_on:
16
- - mssql
17
- entrypoint:
18
- - bash
19
- - -c
20
- # https://docs.microsoft.com/en-us/sql/relational-databases/logs/control-transaction-durability?view=sql-server-ver15#bkmk_DbControl
21
- - 'until /opt/mssql-tools/bin/sqlcmd -S mssql -U sa -P S0meVeryHardPassword -d master -Q "CREATE DATABASE knex_test; ALTER DATABASE knex_test SET ALLOW_SNAPSHOT_ISOLATION ON; ALTER DATABASE knex_test SET DELAYED_DURABILITY = FORCED"; do sleep 5; done'
22
-
23
- mysql:
24
- image: mysql:8.0.40
25
- # https://dev.mysql.com/doc/refman/8.0/en/mysql-acid.html
26
- # https://dev.mysql.com/doc/refman/8.0/en/innodb-parameters.html#sysvar_innodb_flush_method
27
- # nosync only for unix, edit for local start on other systems
28
- command: --default-authentication-plugin=mysql_native_password --sync_binlog=0 --innodb_doublewrite=OFF --innodb-flush-log-at-trx-commit=0 --innodb-flush-method=nosync
29
- ports:
30
- - '23306:3306'
31
- environment:
32
- - MYSQL_ROOT_PASSWORD=testrootpassword
33
- - MYSQL_DATABASE=knex_test
34
- - MYSQL_USER=testuser
35
- - MYSQL_PASSWORD=testpassword
36
- healthcheck:
37
- test:
38
- [
39
- 'CMD',
40
- '/usr/bin/mysql',
41
- '-hlocalhost',
42
- '-utestuser',
43
- '-ptestpassword',
44
- '-e',
45
- 'SELECT 1',
46
- ]
47
- interval: 30s
48
- timeout: 5s
49
- retries: 3
50
- restart: always
51
- volumes:
52
- - mysql_data:/var/lib/mysql
53
- waitmysql:
54
- image: mysql:8.0.40
55
- links:
56
- - mysql
57
- depends_on:
58
- - mysql
59
- entrypoint:
60
- - bash
61
- - -c
62
- - 'until /usr/bin/mysql -hmysql -utestuser -ptestpassword -e "SELECT 1"; do sleep 5; done'
63
-
64
- postgres:
65
- image: postgres:17-alpine
66
- # see https://www.postgresql.org/docs/current/non-durability.html
67
- command: '-c full_page_writes=off -c fsync=off -c synchronous_commit=off'
68
- ports:
69
- - '25432:5432'
70
- environment:
71
- - POSTGRES_USER=testuser
72
- - POSTGRES_PASSWORD=knextest
73
- - POSTGRES_DB=knex_test
74
- waitpostgres:
75
- image: postgres:17-alpine
76
- links:
77
- - postgres
78
- depends_on:
79
- - postgres
80
- entrypoint:
81
- - bash
82
- - -c
83
- - 'until /usr/local/bin/psql postgres://testuser:knextest@postgres/knex_test -c "SELECT 1"; do sleep 5; done'
84
-
85
- cockroachdb:
86
- image: cockroachdb/cockroach:latest-v23.2
87
- container_name: crdb
88
- hostname: crdb
89
- command: start-single-node --cluster-name=example-single-node --insecure --store=type=mem,size=0.25
90
- ports:
91
- - '26257:26257'
92
- - '8080:8080'
93
-
94
- waitcockroachdb:
95
- container_name: crdb-init
96
- hostname: crdb-init
97
- image: timveil/cockroachdb-remote-client:latest
98
- environment:
99
- - COCKROACH_HOST=crdb:26257
100
- - COCKROACH_INSECURE=true
101
- - DATABASE_NAME=test
102
- depends_on:
103
- - cockroachdb
104
-
105
- pgnative:
106
- image: postgres:17-alpine
107
- # see https://www.postgresql.org/docs/current/non-durability.html
108
- command: '-c full_page_writes=off -c fsync=off -c synchronous_commit=off'
109
- ports:
110
- - '25433:5432'
111
- environment:
112
- - POSTGRES_USER=testuser
113
- - POSTGRES_PASSWORD=knextest
114
- - POSTGRES_DB=knex_test
115
- waitpgnative:
116
- image: postgres:17-alpine
117
- links:
118
- - pgnative
119
- depends_on:
120
- - pgnative
121
- entrypoint:
122
- - bash
123
- - -c
124
- - 'until /usr/local/bin/psql postgres://testuser:knextest@pgnative/knex_test -c "SELECT 1"; do sleep 5; done'
125
-
126
- oracledb:
127
- image: quillbuilduser/oracle-18-xe
128
- container_name: oracledb_container
129
- ports:
130
- - '21521:1521'
131
- environment:
132
- - ORACLE_ALLOW_REMOTE=true
133
- waitoracledb:
134
- image: quillbuilduser/oracle-18-xe
135
- links:
136
- - oracledb
137
- depends_on:
138
- - oracledb
139
- environment:
140
- - ORACLE_HOME=/opt/oracle/product/18c/dbhomeXE
141
- entrypoint:
142
- - bash
143
- - -c
144
- - 'until /opt/oracle/product/18c/dbhomeXE/bin/sqlplus -s sys/Oracle18@oracledb/XE as sysdba <<< "SELECT 13376411 FROM DUAL; exit;" | grep "13376411"; do echo "Could not connect to oracle... sleep for a while"; sleep 5; done'
145
-
146
- volumes:
147
- mysql_data:
148
- driver_opts:
149
- type: tmpfs
150
- device: tmpfs
1
+ services:
2
+ mssql:
3
+ image: mcr.microsoft.com/mssql/server:2019-latest
4
+ ports:
5
+ - '21433:1433'
6
+ environment:
7
+ - ACCEPT_EULA=Y
8
+ - SA_PASSWORD=S0meVeryHardPassword
9
+ healthcheck:
10
+ test: /opt/mssql-tools/bin/sqlcmd -S mssql -U sa -P 'S0meVeryHardPassword' -Q 'select 1'
11
+ waitmssql:
12
+ image: mcr.microsoft.com/mssql/server:2017-latest
13
+ links:
14
+ - mssql
15
+ depends_on:
16
+ - mssql
17
+ entrypoint:
18
+ - bash
19
+ - -c
20
+ # https://docs.microsoft.com/en-us/sql/relational-databases/logs/control-transaction-durability?view=sql-server-ver15#bkmk_DbControl
21
+ - 'until /opt/mssql-tools/bin/sqlcmd -S mssql -U sa -P S0meVeryHardPassword -d master -Q "CREATE DATABASE knex_test; ALTER DATABASE knex_test SET ALLOW_SNAPSHOT_ISOLATION ON; ALTER DATABASE knex_test SET DELAYED_DURABILITY = FORCED"; do sleep 5; done'
22
+
23
+ mysql:
24
+ image: mysql:8.0.40
25
+ # https://dev.mysql.com/doc/refman/8.0/en/mysql-acid.html
26
+ # https://dev.mysql.com/doc/refman/8.0/en/innodb-parameters.html#sysvar_innodb_flush_method
27
+ # nosync only for unix, edit for local start on other systems
28
+ command: --default-authentication-plugin=mysql_native_password --sync_binlog=0 --innodb_doublewrite=OFF --innodb-flush-log-at-trx-commit=0 --innodb-flush-method=nosync
29
+ ports:
30
+ - '23306:3306'
31
+ environment:
32
+ - MYSQL_ROOT_PASSWORD=testrootpassword
33
+ - MYSQL_DATABASE=knex_test
34
+ - MYSQL_USER=testuser
35
+ - MYSQL_PASSWORD=testpassword
36
+ healthcheck:
37
+ test:
38
+ [
39
+ 'CMD',
40
+ '/usr/bin/mysql',
41
+ '-hlocalhost',
42
+ '-utestuser',
43
+ '-ptestpassword',
44
+ '-e',
45
+ 'SELECT 1',
46
+ ]
47
+ interval: 30s
48
+ timeout: 5s
49
+ retries: 3
50
+ restart: always
51
+ volumes:
52
+ - mysql_data:/var/lib/mysql
53
+ waitmysql:
54
+ image: mysql:8.0.40
55
+ links:
56
+ - mysql
57
+ depends_on:
58
+ - mysql
59
+ entrypoint:
60
+ - bash
61
+ - -c
62
+ - 'until /usr/bin/mysql -hmysql -utestuser -ptestpassword -e "SELECT 1"; do sleep 5; done'
63
+
64
+ postgres:
65
+ image: postgres:17-alpine
66
+ # see https://www.postgresql.org/docs/current/non-durability.html
67
+ command: '-c full_page_writes=off -c fsync=off -c synchronous_commit=off'
68
+ ports:
69
+ - '25432:5432'
70
+ environment:
71
+ - POSTGRES_USER=testuser
72
+ - POSTGRES_PASSWORD=knextest
73
+ - POSTGRES_DB=knex_test
74
+ waitpostgres:
75
+ image: postgres:17-alpine
76
+ links:
77
+ - postgres
78
+ depends_on:
79
+ - postgres
80
+ entrypoint:
81
+ - bash
82
+ - -c
83
+ - 'until /usr/local/bin/psql postgres://testuser:knextest@postgres/knex_test -c "SELECT 1"; do sleep 5; done'
84
+
85
+ cockroachdb:
86
+ image: cockroachdb/cockroach:latest-v23.2
87
+ container_name: crdb
88
+ hostname: crdb
89
+ command: start-single-node --cluster-name=example-single-node --insecure --store=type=mem,size=0.25
90
+ ports:
91
+ - '26257:26257'
92
+ - '8080:8080'
93
+
94
+ waitcockroachdb:
95
+ container_name: crdb-init
96
+ hostname: crdb-init
97
+ image: timveil/cockroachdb-remote-client:latest
98
+ environment:
99
+ - COCKROACH_HOST=crdb:26257
100
+ - COCKROACH_INSECURE=true
101
+ - DATABASE_NAME=test
102
+ depends_on:
103
+ - cockroachdb
104
+
105
+ pgnative:
106
+ image: postgres:17-alpine
107
+ # see https://www.postgresql.org/docs/current/non-durability.html
108
+ command: '-c full_page_writes=off -c fsync=off -c synchronous_commit=off'
109
+ ports:
110
+ - '25433:5432'
111
+ environment:
112
+ - POSTGRES_USER=testuser
113
+ - POSTGRES_PASSWORD=knextest
114
+ - POSTGRES_DB=knex_test
115
+ waitpgnative:
116
+ image: postgres:17-alpine
117
+ links:
118
+ - pgnative
119
+ depends_on:
120
+ - pgnative
121
+ entrypoint:
122
+ - bash
123
+ - -c
124
+ - 'until /usr/local/bin/psql postgres://testuser:knextest@pgnative/knex_test -c "SELECT 1"; do sleep 5; done'
125
+
126
+ oracledb:
127
+ image: quillbuilduser/oracle-18-xe
128
+ container_name: oracledb_container
129
+ ports:
130
+ - '21521:1521'
131
+ environment:
132
+ - ORACLE_ALLOW_REMOTE=true
133
+ waitoracledb:
134
+ image: quillbuilduser/oracle-18-xe
135
+ links:
136
+ - oracledb
137
+ depends_on:
138
+ - oracledb
139
+ environment:
140
+ - ORACLE_HOME=/opt/oracle/product/18c/dbhomeXE
141
+ entrypoint:
142
+ - bash
143
+ - -c
144
+ - 'until /opt/oracle/product/18c/dbhomeXE/bin/sqlplus -s sys/Oracle18@oracledb/XE as sysdba <<< "SELECT 13376411 FROM DUAL; exit;" | grep "13376411"; do echo "Could not connect to oracle... sleep for a while"; sleep 5; done'
145
+
146
+ volumes:
147
+ mysql_data:
148
+ driver_opts:
149
+ type: tmpfs
150
+ device: tmpfs
@@ -1,55 +1,55 @@
1
- const { readFileSync, writeFileSync } = require('fs');
2
- const { resolve } = require('path');
3
- const { greenBright, redBright } = require('colorette');
4
-
5
- const CHANGELOG = resolve(__dirname, '..', 'CHANGELOG.md');
6
- const lines = readFileSync(CHANGELOG, 'utf-8').split(/\r?\n/);
7
-
8
- // ensure that every `#NNNN` is a markdown link
9
- // to https://github.com/knex/knex/issues/NNNN
10
- //
11
- // https://docs.github.com/en/rest/issues/issues?apiVersion=2022-11-28#list-repository-issues
12
- //
13
- // GitHub's REST API considers every pull request an issue, but not every issue is a pull request.
14
- // For this reason, "Issues" endpoints may return both issues and pull requests in the response.
15
- //
16
- // Web links to /issues/NNNN will redirect to /pull/NNNN
17
-
18
- // match first: a markdown link, then: #NNNN
19
- const markdownRE = /\[#(\d+)\]\(([^)]+)\)/;
20
- const referenceRE = /#(\d+)/;
21
- const regex = new RegExp(`${markdownRE.source}|${referenceRE.source}`, 'g');
22
- // eslint-disable-next-line no-control-regex
23
- const ansiRegex = /\x1B(?:[@-Z\\-_]|\[[0-?]*[ -/]*[@-~])/g;
24
- const stripAnsi = (str) => str.replace(ansiRegex, '');
25
-
26
- for (let i = 0; i < lines.length; i++) {
27
- const line = lines[i];
28
-
29
- const newLine = line.replace(regex, (match, anchor, url, issueno) => {
30
- if (issueno !== undefined) {
31
- return `${greenBright('[#')}${issueno}${greenBright(
32
- `](https://github.com/knex/knex/issues/${issueno})`
33
- )}`;
34
- }
35
-
36
- if (url !== undefined && anchor !== undefined) {
37
- if (!url.endsWith(`/${anchor}`)) {
38
- console.warn('Mismatched URL:', url);
39
- return `${redBright(
40
- `[#${anchor}](https://github.com/knex/knex/issues/${anchor})`
41
- )}`;
42
- } else {
43
- return match;
44
- }
45
- }
46
- throw new Error('Regex failed');
47
- });
48
-
49
- if (line !== newLine) {
50
- lines[i] = stripAnsi(newLine);
51
- console.log(newLine);
52
- }
53
- }
54
-
55
- writeFileSync(CHANGELOG, lines.join('\n'), 'utf-8');
1
+ const { readFileSync, writeFileSync } = require('fs');
2
+ const { resolve } = require('path');
3
+ const { greenBright, redBright } = require('colorette');
4
+
5
+ const CHANGELOG = resolve(__dirname, '..', 'CHANGELOG.md');
6
+ const lines = readFileSync(CHANGELOG, 'utf-8').split(/\r?\n/);
7
+
8
+ // ensure that every `#NNNN` is a markdown link
9
+ // to https://github.com/knex/knex/issues/NNNN
10
+ //
11
+ // https://docs.github.com/en/rest/issues/issues?apiVersion=2022-11-28#list-repository-issues
12
+ //
13
+ // GitHub's REST API considers every pull request an issue, but not every issue is a pull request.
14
+ // For this reason, "Issues" endpoints may return both issues and pull requests in the response.
15
+ //
16
+ // Web links to /issues/NNNN will redirect to /pull/NNNN
17
+
18
+ // match first: a markdown link, then: #NNNN
19
+ const markdownRE = /\[#(\d+)\]\(([^)]+)\)/;
20
+ const referenceRE = /#(\d+)/;
21
+ const regex = new RegExp(`${markdownRE.source}|${referenceRE.source}`, 'g');
22
+ // eslint-disable-next-line no-control-regex
23
+ const ansiRegex = /\x1B(?:[@-Z\\-_]|\[[0-?]*[ -/]*[@-~])/g;
24
+ const stripAnsi = (str) => str.replace(ansiRegex, '');
25
+
26
+ for (let i = 0; i < lines.length; i++) {
27
+ const line = lines[i];
28
+
29
+ const newLine = line.replace(regex, (match, anchor, url, issueno) => {
30
+ if (issueno !== undefined) {
31
+ return `${greenBright('[#')}${issueno}${greenBright(
32
+ `](https://github.com/knex/knex/issues/${issueno})`
33
+ )}`;
34
+ }
35
+
36
+ if (url !== undefined && anchor !== undefined) {
37
+ if (!url.endsWith(`/${anchor}`)) {
38
+ console.warn('Mismatched URL:', url);
39
+ return `${redBright(
40
+ `[#${anchor}](https://github.com/knex/knex/issues/${anchor})`
41
+ )}`;
42
+ } else {
43
+ return match;
44
+ }
45
+ }
46
+ throw new Error('Regex failed');
47
+ });
48
+
49
+ if (line !== newLine) {
50
+ lines[i] = stripAnsi(newLine);
51
+ console.log(newLine);
52
+ }
53
+ }
54
+
55
+ writeFileSync(CHANGELOG, lines.join('\n'), 'utf-8');
@@ -1,24 +1,24 @@
1
- # Checklist for crating knex @next releases
2
-
3
- 1. Go through all commits since the last release and add them to CHANGELOG.md under unreleased changes section.
4
- 2. Commit changes to CHANGELOG
5
- 3. Check that master compiles and tests are running fine (check also that CI tests are passing)
6
-
7
- ```sh
8
- npm run build
9
-
10
- # run bunch of tests, but skipping coverage which doesn't really work locally at least
11
- npm plaintest
12
- npm bin_test
13
- npm oracledb:test
14
- npm mssql:init
15
- npm mssql:test
16
- npm mssql:destroy
17
- ```
18
-
19
- 4. Update package.json version to be e.g. 0.16.0-next1 or 0.16.0-next2 and commit yo master
20
- 5. Publish it under @next tag
21
-
22
- ```sh
23
- npm publish --tag next
24
- ```
1
+ # Checklist for crating knex @next releases
2
+
3
+ 1. Go through all commits since the last release and add them to CHANGELOG.md under unreleased changes section.
4
+ 2. Commit changes to CHANGELOG
5
+ 3. Check that master compiles and tests are running fine (check also that CI tests are passing)
6
+
7
+ ```sh
8
+ npm run build
9
+
10
+ # run bunch of tests, but skipping coverage which doesn't really work locally at least
11
+ npm plaintest
12
+ npm bin_test
13
+ npm oracledb:test
14
+ npm mssql:init
15
+ npm mssql:test
16
+ npm mssql:destroy
17
+ ```
18
+
19
+ 4. Update package.json version to be e.g. 0.16.0-next1 or 0.16.0-next2 and commit yo master
20
+ 5. Publish it under @next tag
21
+
22
+ ```sh
23
+ npm publish --tag next
24
+ ```