@cubejs-backend/testing 0.29.31 → 0.29.37
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/CHANGELOG.md +24 -0
- package/birdbox-fixtures/athena.yml +11 -3
- package/birdbox-fixtures/bigquery.yml +11 -4
- package/birdbox-fixtures/questdb/schema/Events.js +49 -0
- package/birdbox-fixtures/questdb/schema/Orders.js +34 -0
- package/birdbox-fixtures/questdb/scripts/questdb-load-events.sh +19 -0
- package/birdbox-fixtures/questdb.yml +43 -0
- package/dist/src/birdbox.d.ts +2 -3
- package/dist/src/birdbox.d.ts.map +1 -1
- package/dist/src/birdbox.js +25 -19
- package/dist/src/birdbox.js.map +1 -1
- package/dist/src/index.d.ts +0 -1
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +0 -1
- package/dist/src/index.js.map +1 -1
- package/package.json +17 -12
- package/dist/src/db/cubestore.d.ts +0 -9
- package/dist/src/db/cubestore.d.ts.map +0 -1
- package/dist/src/db/cubestore.js +0 -22
- package/dist/src/db/cubestore.js.map +0 -1
- package/dist/src/db/db-runner.abstract.d.ts +0 -11
- package/dist/src/db/db-runner.abstract.d.ts.map +0 -1
- package/dist/src/db/db-runner.abstract.js +0 -8
- package/dist/src/db/db-runner.abstract.js.map +0 -1
- package/dist/src/db/index.d.ts +0 -5
- package/dist/src/db/index.d.ts.map +0 -1
- package/dist/src/db/index.js +0 -17
- package/dist/src/db/index.js.map +0 -1
- package/dist/src/db/mysql.d.ts +0 -9
- package/dist/src/db/mysql.d.ts.map +0 -1
- package/dist/src/db/mysql.js +0 -37
- package/dist/src/db/mysql.js.map +0 -1
- package/dist/src/db/postgres.d.ts +0 -9
- package/dist/src/db/postgres.d.ts.map +0 -1
- package/dist/src/db/postgres.js +0 -33
- package/dist/src/db/postgres.js.map +0 -1
- package/dist/src/db/questdb.d.ts +0 -9
- package/dist/src/db/questdb.d.ts.map +0 -1
- package/dist/src/db/questdb.js +0 -22
- package/dist/src/db/questdb.js.map +0 -1
- package/dist/src/testing/DriverTests.d.ts +0 -26
- package/dist/src/testing/DriverTests.d.ts.map +0 -1
- package/dist/src/testing/DriverTests.js +0 -107
- package/dist/src/testing/DriverTests.js.map +0 -1
- package/dist/src/testing/index.d.ts +0 -3
- package/dist/src/testing/index.d.ts.map +0 -1
- package/dist/src/testing/index.js +0 -15
- package/dist/src/testing/index.js.map +0 -1
- package/dist/src/testing/query-test.abstract.d.ts +0 -25
- package/dist/src/testing/query-test.abstract.d.ts.map +0 -1
- package/dist/src/testing/query-test.abstract.js +0 -123
- package/dist/src/testing/query-test.abstract.js.map +0 -1
- package/dist/src/utils.d.ts +0 -9
- package/dist/src/utils.d.ts.map +0 -1
- package/dist/src/utils.js +0 -61
- package/dist/src/utils.js.map +0 -1
package/CHANGELOG.md
CHANGED
|
@@ -3,6 +3,30 @@
|
|
|
3
3
|
All notable changes to this project will be documented in this file.
|
|
4
4
|
See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
|
|
5
5
|
|
|
6
|
+
## [0.29.37](https://github.com/cube-js/cube.js/compare/v0.29.36...v0.29.37) (2022-03-29)
|
|
7
|
+
|
|
8
|
+
**Note:** Version bump only for package @cubejs-backend/testing
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
## [0.29.35](https://github.com/cube-js/cube.js/compare/v0.29.34...v0.29.35) (2022-03-24)
|
|
15
|
+
|
|
16
|
+
**Note:** Version bump only for package @cubejs-backend/testing
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
## [0.29.33](https://github.com/cube-js/cube.js/compare/v0.29.32...v0.29.33) (2022-03-17)
|
|
23
|
+
|
|
24
|
+
**Note:** Version bump only for package @cubejs-backend/testing
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
6
30
|
## [0.29.31](https://github.com/cube-js/cube.js/compare/v0.29.30...v0.29.31) (2022-03-09)
|
|
7
31
|
|
|
8
32
|
|
|
@@ -6,18 +6,26 @@ services:
|
|
|
6
6
|
image: ${BIRDBOX_CUBEJS_REGISTRY_PATH}cubejs/cube:${BIRDBOX_CUBEJS_VERSION:-latest}
|
|
7
7
|
environment:
|
|
8
8
|
CUBEJS_DB_TYPE: athena
|
|
9
|
+
|
|
10
|
+
# from env
|
|
9
11
|
CUBEJS_AWS_KEY: ${CUBEJS_AWS_KEY}
|
|
10
12
|
CUBEJS_AWS_SECRET: ${CUBEJS_AWS_SECRET}
|
|
11
13
|
CUBEJS_AWS_REGION: ${CUBEJS_AWS_REGION}
|
|
12
14
|
CUBEJS_AWS_S3_OUTPUT_LOCATION: ${CUBEJS_AWS_S3_OUTPUT_LOCATION}
|
|
15
|
+
CUBEJS_DB_EXPORT_BUCKET: ${CUBEJS_DB_EXPORT_BUCKET}
|
|
16
|
+
|
|
17
|
+
# from test
|
|
18
|
+
CUBEJS_SCHEDULED_REFRESH_DEFAULT: ${CUBEJS_SCHEDULED_REFRESH_DEFAULT}
|
|
19
|
+
CUBEJS_REFRESH_WORKER: ${CUBEJS_REFRESH_WORKER}
|
|
20
|
+
CUBEJS_EXTERNAL_DEFAULT: ${CUBEJS_EXTERNAL_DEFAULT}
|
|
21
|
+
CUBEJS_ROLLUP_ONLY: ${CUBEJS_ROLLUP_ONLY}
|
|
13
22
|
|
|
23
|
+
# defaults
|
|
14
24
|
CUBEJS_DEV_MODE: "true"
|
|
15
25
|
CUBEJS_API_SECRET: mysupersecret
|
|
16
|
-
CUBEJS_SCHEDULED_REFRESH_DEFAULT: "false"
|
|
17
|
-
CUBEJS_REFRESH_WORKER: "false"
|
|
18
26
|
volumes:
|
|
19
27
|
- ./postgresql/single/cube.js:/cube/conf/cube.js
|
|
20
|
-
- ./postgresql/schema:/cube/conf/schema
|
|
28
|
+
- ./postgresql/schema/OrdersPA.js:/cube/conf/schema/OrdersPA.js
|
|
21
29
|
ports:
|
|
22
30
|
- "4000:4000"
|
|
23
31
|
restart: always
|
|
@@ -6,17 +6,24 @@ services:
|
|
|
6
6
|
image: ${BIRDBOX_CUBEJS_REGISTRY_PATH}cubejs/cube:${BIRDBOX_CUBEJS_VERSION:-latest}
|
|
7
7
|
environment:
|
|
8
8
|
CUBEJS_DB_TYPE: bigquery
|
|
9
|
+
|
|
10
|
+
# from env
|
|
9
11
|
CUBEJS_DB_BQ_PROJECT_ID: ${CUBEJS_DB_BQ_PROJECT_ID}
|
|
10
12
|
CUBEJS_DB_BQ_CREDENTIALS: ${CUBEJS_DB_BQ_CREDENTIALS}
|
|
11
|
-
|
|
13
|
+
CUBEJS_DB_EXPORT_BUCKET: ${CUBEJS_DB_EXPORT_BUCKET}
|
|
14
|
+
|
|
15
|
+
# from test
|
|
16
|
+
CUBEJS_SCHEDULED_REFRESH_DEFAULT: ${CUBEJS_SCHEDULED_REFRESH_DEFAULT}
|
|
17
|
+
CUBEJS_REFRESH_WORKER: ${CUBEJS_REFRESH_WORKER}
|
|
18
|
+
CUBEJS_EXTERNAL_DEFAULT: ${CUBEJS_EXTERNAL_DEFAULT}
|
|
19
|
+
CUBEJS_ROLLUP_ONLY: ${CUBEJS_ROLLUP_ONLY}
|
|
12
20
|
|
|
21
|
+
# defaults
|
|
13
22
|
CUBEJS_DEV_MODE: "true"
|
|
14
23
|
CUBEJS_API_SECRET: mysupersecret
|
|
15
|
-
CUBEJS_SCHEDULED_REFRESH_DEFAULT: "false"
|
|
16
|
-
CUBEJS_REFRESH_WORKER: "false"
|
|
17
24
|
volumes:
|
|
18
25
|
- ./postgresql/single/cube.js:/cube/conf/cube.js
|
|
19
|
-
- ./postgresql/schema:/cube/conf/schema
|
|
26
|
+
- ./postgresql/schema/OrdersPA.js:/cube/conf/schema/OrdersPA.js
|
|
20
27
|
ports:
|
|
21
28
|
- "4000:4000"
|
|
22
29
|
restart: always
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
cube(`Events`, {
|
|
2
|
+
sql: `SELECT * FROM events`,
|
|
3
|
+
|
|
4
|
+
joins: {
|
|
5
|
+
|
|
6
|
+
},
|
|
7
|
+
|
|
8
|
+
measures: {
|
|
9
|
+
count: {
|
|
10
|
+
type: `count`,
|
|
11
|
+
drillMembers: [id, createdAt]
|
|
12
|
+
}
|
|
13
|
+
},
|
|
14
|
+
|
|
15
|
+
dimensions: {
|
|
16
|
+
actor: {
|
|
17
|
+
sql: `actor`,
|
|
18
|
+
type: `string`
|
|
19
|
+
},
|
|
20
|
+
|
|
21
|
+
public: {
|
|
22
|
+
sql: `public`,
|
|
23
|
+
type: `string`
|
|
24
|
+
},
|
|
25
|
+
|
|
26
|
+
id: {
|
|
27
|
+
sql: `id`,
|
|
28
|
+
type: `number`,
|
|
29
|
+
primaryKey: true
|
|
30
|
+
},
|
|
31
|
+
|
|
32
|
+
type: {
|
|
33
|
+
sql: `type`,
|
|
34
|
+
type: `string`
|
|
35
|
+
},
|
|
36
|
+
|
|
37
|
+
payload: {
|
|
38
|
+
sql: `payload`,
|
|
39
|
+
type: `string`
|
|
40
|
+
},
|
|
41
|
+
|
|
42
|
+
createdAt: {
|
|
43
|
+
sql: `created_at`,
|
|
44
|
+
type: `time`
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
|
|
48
|
+
dataSource: `default`
|
|
49
|
+
});
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
cube(`Orders`, {
|
|
2
|
+
sql: `
|
|
3
|
+
with orders as (
|
|
4
|
+
select 1 as id, 100 as amount, 'new' status
|
|
5
|
+
UNION ALL
|
|
6
|
+
select 2 as id, 200 as amount, 'new' status
|
|
7
|
+
UNION ALL
|
|
8
|
+
select 3 as id, 300 as amount, 'processed' status
|
|
9
|
+
UNION ALL
|
|
10
|
+
select 4 as id, 500 as amount, 'processed' status
|
|
11
|
+
UNION ALL
|
|
12
|
+
select 5 as id, 600 as amount, 'shipped' status
|
|
13
|
+
)
|
|
14
|
+
select * from orders
|
|
15
|
+
`,
|
|
16
|
+
measures: {
|
|
17
|
+
count: {
|
|
18
|
+
type: `count`,
|
|
19
|
+
},
|
|
20
|
+
totalAmount: {
|
|
21
|
+
sql: `amount`,
|
|
22
|
+
type: `sum`,
|
|
23
|
+
},
|
|
24
|
+
toRemove: {
|
|
25
|
+
type: `count`,
|
|
26
|
+
},
|
|
27
|
+
},
|
|
28
|
+
dimensions: {
|
|
29
|
+
status: {
|
|
30
|
+
sql: `status`,
|
|
31
|
+
type: `string`,
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
});
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
#!/bin/bash
|
|
2
|
+
exec 2>&1
|
|
3
|
+
set -x
|
|
4
|
+
set -e
|
|
5
|
+
|
|
6
|
+
apt-get update
|
|
7
|
+
apt-get install curl -y
|
|
8
|
+
|
|
9
|
+
echo $(pwd)
|
|
10
|
+
echo $(ls /data)
|
|
11
|
+
|
|
12
|
+
curl -F schema='[
|
|
13
|
+
{"name":"id", "type": "LONG"},
|
|
14
|
+
{"name":"type", "type": "SYMBOL"},
|
|
15
|
+
{"name":"actor", "type": "STRING"},
|
|
16
|
+
{"name":"public", "type": "SYMBOL"},
|
|
17
|
+
{"name":"created_at", "type": "TIMESTAMP", "pattern": "yyyy-MM-dd HH:mm:ss"},
|
|
18
|
+
{"name":"payload", "type": "STRING"}
|
|
19
|
+
]' -F data=@/data/github-events-2015-01-01.1000.csv 'http://localhost:9000/imp?timestamp=created_at&name=events&partitionBy=DAY'
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
version: "2.2"
|
|
2
|
+
|
|
3
|
+
services:
|
|
4
|
+
cube:
|
|
5
|
+
container_name: birdbox-cube
|
|
6
|
+
image: ${BIRDBOX_CUBEJS_REGISTRY_PATH}cubejs/cube:${BIRDBOX_CUBEJS_VERSION:-latest}
|
|
7
|
+
environment:
|
|
8
|
+
CUBEJS_DB_TYPE: questdb
|
|
9
|
+
CUBEJS_DB_HOST: db
|
|
10
|
+
CUBEJS_DB_PORT: 8812
|
|
11
|
+
CUBEJS_DB_NAME: qdb
|
|
12
|
+
CUBEJS_DB_USER: admin
|
|
13
|
+
CUBEJS_DB_PASS: quest
|
|
14
|
+
CUBEJS_DEV_MODE: "true"
|
|
15
|
+
CUBEJS_WEB_SOCKETS: "true"
|
|
16
|
+
CUBEJS_API_SECRET: mysupersecret
|
|
17
|
+
depends_on:
|
|
18
|
+
- db
|
|
19
|
+
links:
|
|
20
|
+
- db
|
|
21
|
+
volumes:
|
|
22
|
+
- ./questdb/schema:/cube/conf/schema
|
|
23
|
+
- ./postgresql/dbt-project:/cube/conf/dbt-project
|
|
24
|
+
ports:
|
|
25
|
+
- "4000"
|
|
26
|
+
restart: always
|
|
27
|
+
|
|
28
|
+
db:
|
|
29
|
+
container_name: birdbox-db
|
|
30
|
+
image: questdb/questdb:6.2.1
|
|
31
|
+
ports:
|
|
32
|
+
- "8812"
|
|
33
|
+
- "9000"
|
|
34
|
+
- "9003"
|
|
35
|
+
restart: always
|
|
36
|
+
volumes:
|
|
37
|
+
- ./datasets:/data:ro
|
|
38
|
+
- ./questdb/scripts:/scripts:ro
|
|
39
|
+
healthcheck:
|
|
40
|
+
test: ["CMD-SHELL", "curl -f http://127.0.0.1:9003 || exit 1"]
|
|
41
|
+
interval: 10s
|
|
42
|
+
timeout: 5s
|
|
43
|
+
retries: 5
|
package/dist/src/birdbox.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export interface BirdBoxTestCaseOptions {
|
|
2
2
|
name: string;
|
|
3
3
|
loadScript?: string;
|
|
4
|
-
|
|
4
|
+
env?: Record<string, string>;
|
|
5
5
|
}
|
|
6
6
|
export interface BirdBox {
|
|
7
7
|
stop: () => Promise<void>;
|
|
@@ -18,8 +18,7 @@ export interface StartCliWithEnvOptions {
|
|
|
18
18
|
useCubejsServerBinary?: boolean;
|
|
19
19
|
loadScript?: string;
|
|
20
20
|
cubejsConfig?: string;
|
|
21
|
-
|
|
22
|
-
envFile?: string;
|
|
21
|
+
env?: Record<string, string>;
|
|
23
22
|
}
|
|
24
23
|
export declare function startBirdBoxFromCli(options: StartCliWithEnvOptions): Promise<BirdBox>;
|
|
25
24
|
//# sourceMappingURL=birdbox.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"birdbox.d.ts","sourceRoot":"","sources":["../../src/birdbox.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"birdbox.d.ts","sourceRoot":"","sources":["../../src/birdbox.ts"],"names":[],"mappings":"AASA,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC9B;AAED,MAAM,WAAW,OAAO;IACtB,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,aAAa,EAAE;QACb,aAAa,EAAE,MAAM,CAAC;QACtB,MAAM,EAAE,MAAM,CAAC;QACf,KAAK,EAAE,MAAM,CAAC;QACd,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KAC9B,CAAC;CACH;AAED,wBAAsB,yBAAyB,CAAC,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,OAAO,CAAC,CAgHjG;AAED,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,MAAM,CAAC;IACf,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC9B;AAED,wBAAsB,mBAAmB,CAAC,OAAO,EAAE,sBAAsB,GAAG,OAAO,CAAC,OAAO,CAAC,CAyH3F"}
|
package/dist/src/birdbox.js
CHANGED
|
@@ -10,10 +10,8 @@ const child_process_1 = require("child_process");
|
|
|
10
10
|
const http_proxy_1 = __importDefault(require("http-proxy"));
|
|
11
11
|
const testcontainers_1 = require("testcontainers");
|
|
12
12
|
const shared_1 = require("@cubejs-backend/shared");
|
|
13
|
+
const testing_shared_1 = require("@cubejs-backend/testing-shared");
|
|
13
14
|
const fs_extra_1 = __importDefault(require("fs-extra"));
|
|
14
|
-
const dotenv_1 = __importDefault(require("@cubejs-backend/dotenv"));
|
|
15
|
-
const postgres_1 = require("./db/postgres");
|
|
16
|
-
const utils_1 = require("./utils");
|
|
17
15
|
async function startBirdBoxFromContainer(options) {
|
|
18
16
|
var _a;
|
|
19
17
|
if (process.env.TEST_CUBE_HOST) {
|
|
@@ -30,19 +28,31 @@ async function startBirdBoxFromContainer(options) {
|
|
|
30
28
|
},
|
|
31
29
|
};
|
|
32
30
|
}
|
|
31
|
+
if (process.env.BIRDBOX_CUBEJS_REGISTRY_PATH === undefined) {
|
|
32
|
+
process.env.BIRDBOX_CUBEJS_REGISTRY_PATH = 'localhost:5000/';
|
|
33
|
+
}
|
|
34
|
+
if (process.env.BIRDBOX_CUBEJS_VERSION === undefined) {
|
|
35
|
+
process.env.BIRDBOX_CUBEJS_VERSION = 'latest';
|
|
36
|
+
const tag = `${process.env.BIRDBOX_CUBEJS_REGISTRY_PATH}cubejs/cube:${process.env.BIRDBOX_CUBEJS_VERSION}`;
|
|
37
|
+
if (shared_1.execInDir('../..', `docker build . -f packages/cubejs-docker/dev.Dockerfile -t ${tag}`) !== 0) {
|
|
38
|
+
throw new Error('[Birdbox] Docker build failed.');
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
if (process.env.BIRDBOX_CUBESTORE_VERSION === undefined) {
|
|
42
|
+
process.env.BIRDBOX_CUBESTORE_VERSION = 'latest';
|
|
43
|
+
}
|
|
33
44
|
const composeFile = `${options.name}.yml`;
|
|
34
45
|
let dc = new testcontainers_1.DockerComposeEnvironment(path_1.default.resolve(path_1.default.dirname(__filename), '../../birdbox-fixtures/'), composeFile);
|
|
35
|
-
if (options.
|
|
36
|
-
const
|
|
37
|
-
|
|
38
|
-
dc = dc.withEnv(k, env[k]);
|
|
46
|
+
if (options.env) {
|
|
47
|
+
for (const k of Object.keys(options.env)) {
|
|
48
|
+
dc = dc.withEnv(k, options.env[k]);
|
|
39
49
|
}
|
|
40
50
|
}
|
|
41
51
|
console.log(`[Birdbox] Using ${composeFile} compose file`);
|
|
42
52
|
const env = await dc
|
|
43
53
|
.withStartupTimeout(30 * 1000)
|
|
44
|
-
.withEnv('BIRDBOX_CUBEJS_VERSION', process.env.BIRDBOX_CUBEJS_VERSION
|
|
45
|
-
.withEnv('BIRDBOX_CUBESTORE_VERSION', process.env.BIRDBOX_CUBESTORE_VERSION
|
|
54
|
+
.withEnv('BIRDBOX_CUBEJS_VERSION', process.env.BIRDBOX_CUBEJS_VERSION)
|
|
55
|
+
.withEnv('BIRDBOX_CUBESTORE_VERSION', process.env.BIRDBOX_CUBESTORE_VERSION)
|
|
46
56
|
.up();
|
|
47
57
|
const host = '127.0.0.1';
|
|
48
58
|
const port = env.getContainer('birdbox-cube').getMappedPort(4000);
|
|
@@ -86,7 +96,7 @@ async function startBirdBoxFromContainer(options) {
|
|
|
86
96
|
apiUrl: `http://${host}:${port}/cubejs-api/v1`,
|
|
87
97
|
wsUrl: `ws://${host}:${port}`,
|
|
88
98
|
env: {
|
|
89
|
-
...(process.env.TEST_PLAYGROUND_PORT ? { CUBEJS_DB_HOST:
|
|
99
|
+
...(process.env.TEST_PLAYGROUND_PORT ? { CUBEJS_DB_HOST: testing_shared_1.getLocalHostnameByOs() } : null),
|
|
90
100
|
},
|
|
91
101
|
},
|
|
92
102
|
};
|
|
@@ -95,7 +105,7 @@ exports.startBirdBoxFromContainer = startBirdBoxFromContainer;
|
|
|
95
105
|
async function startBirdBoxFromCli(options) {
|
|
96
106
|
let db;
|
|
97
107
|
if (options.loadScript) {
|
|
98
|
-
db = await
|
|
108
|
+
db = await testing_shared_1.PostgresDBRunner.startContainer({
|
|
99
109
|
volumes: [
|
|
100
110
|
{
|
|
101
111
|
source: path_1.default.join(__dirname, '..', '..', 'birdbox-fixtures', 'datasets'),
|
|
@@ -144,14 +154,10 @@ async function startBirdBoxFromCli(options) {
|
|
|
144
154
|
CUBEJS_DB_TYPE: options.dbType === 'postgresql' ? 'postgres' : options.dbType,
|
|
145
155
|
CUBEJS_DEV_MODE: 'true',
|
|
146
156
|
CUBEJS_API_SECRET: 'mysupersecret',
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
CUBEJS_PLAYGROUND_AUTH_SECRET: 'mysupersecret',
|
|
152
|
-
},
|
|
153
|
-
...options.envFile
|
|
154
|
-
? dotenv_1.default.parse(fs_1.default.readFileSync(options.envFile))
|
|
157
|
+
CUBEJS_WEB_SOCKETS: 'true',
|
|
158
|
+
CUBEJS_PLAYGROUND_AUTH_SECRET: 'mysupersecret',
|
|
159
|
+
...options.env
|
|
160
|
+
? options.env
|
|
155
161
|
: {
|
|
156
162
|
CUBEJS_DB_HOST: db.getHost(),
|
|
157
163
|
CUBEJS_DB_PORT: `${db.getMappedPort(5432)}`,
|
package/dist/src/birdbox.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"birdbox.js","sourceRoot":"","sources":["../../src/birdbox.ts"],"names":[],"mappings":";;;;;;AAAA,gDAAwB;AACxB,4CAAoB;AACpB,iDAAsC;AACtC,4DAAmC;AACnC,mDAAgF;AAChF,
|
|
1
|
+
{"version":3,"file":"birdbox.js","sourceRoot":"","sources":["../../src/birdbox.ts"],"names":[],"mappings":"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"}
|
package/dist/src/index.d.ts
CHANGED
package/dist/src/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC"}
|
package/dist/src/index.js
CHANGED
|
@@ -11,5 +11,4 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
11
11
|
};
|
|
12
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
13
|
__exportStar(require("./birdbox"), exports);
|
|
14
|
-
__exportStar(require("./db"), exports);
|
|
15
14
|
//# sourceMappingURL=index.js.map
|
package/dist/src/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,4CAA0B
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,4CAA0B"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cubejs-backend/testing",
|
|
3
|
-
"version": "0.29.
|
|
4
|
-
"description": "Cube.js
|
|
3
|
+
"version": "0.29.37",
|
|
4
|
+
"description": "Cube.js e2e tests",
|
|
5
5
|
"author": "Cube Dev, Inc.",
|
|
6
6
|
"license": "Apache-2.0",
|
|
7
7
|
"main": "dist/src/index.js",
|
|
@@ -26,14 +26,18 @@
|
|
|
26
26
|
"birdbox:postgresql-pre-aggregations:snapshot": "jest --verbose --updateSnapshot -i dist/test/birdbox-postgresql-pre-aggregations.test.js",
|
|
27
27
|
"birdbox:postgresql-cubestore": "jest --verbose -i dist/test/birdbox-postgresql-cubestore.test.js",
|
|
28
28
|
"birdbox:postgresql-cubestore:snapshot": "jest --verbose --updateSnapshot -i dist/test/birdbox-postgresql-cubestore.test.js",
|
|
29
|
+
"birdbox:questdb": "jest --verbose -i dist/test/birdbox-questdb.test.js",
|
|
30
|
+
"birdbox:questdb:snapshot": "jest --verbose --updateSnapshot -i dist/test/birdbox-questdb.test.js",
|
|
29
31
|
"birdbox:cli:postgresql": "jest --forceExit --verbose -i dist/test/cli-postgresql.test.js",
|
|
30
32
|
"birdbox:cli:postgresql:snapshot": "jest --forceExit --verbose --updateSnapshot -i dist/test/cli-postgresql.test.js",
|
|
31
33
|
"birdbox:local:postgresql": "USE_LOCAL_CUBEJS_BINARY=true jest --forceExit --verbose -i dist/test/cli-postgresql.test.js",
|
|
32
34
|
"birdbox:local:postgresql:snapshot": "USE_LOCAL_CUBEJS_BINARY=true jest --forceExit --verbose --updateSnapshot -i dist/test/cli-postgresql.test.js",
|
|
33
35
|
"birdbox:local:postgresql-pre-aggregations": "jest --forceExit --verbose -i dist/test/cli-postgresql-pre-aggregations.test.js",
|
|
34
36
|
"birdbox:local:postgresql-pre-aggregations:snapshot": "jest --forceExit --verbose --updateSnapshot -i dist/test/cli-postgresql-pre-aggregations.test.js",
|
|
35
|
-
"birdbox:
|
|
36
|
-
"birdbox:
|
|
37
|
+
"birdbox:athena": "jest --verbose -i dist/test/birdbox-athena.test.js",
|
|
38
|
+
"birdbox:athena:snapshot": "jest --verbose --updateSnapshot -i dist/test/birdbox-athena.test.js",
|
|
39
|
+
"birdbox:bigquery": "jest --verbose -i dist/test/birdbox-bigquery.test.js",
|
|
40
|
+
"birdbox:bigquery:snapshot": "jest --verbose --updateSnapshot -i dist/test/birdbox-bigquery.test.js",
|
|
37
41
|
"cypress:install": "cypress install",
|
|
38
42
|
"cypress:birdbox": "node dist/test/bin/cypress-birdbox.js"
|
|
39
43
|
},
|
|
@@ -43,23 +47,25 @@
|
|
|
43
47
|
],
|
|
44
48
|
"dependencies": {
|
|
45
49
|
"@cubejs-backend/dotenv": "^9.0.2",
|
|
46
|
-
"@cubejs-backend/query-orchestrator": "^0.29.
|
|
47
|
-
"@cubejs-backend/schema-compiler": "^0.29.
|
|
48
|
-
"@cubejs-backend/shared": "^0.29.
|
|
49
|
-
"@cubejs-
|
|
50
|
-
"@
|
|
50
|
+
"@cubejs-backend/query-orchestrator": "^0.29.37",
|
|
51
|
+
"@cubejs-backend/schema-compiler": "^0.29.37",
|
|
52
|
+
"@cubejs-backend/shared": "^0.29.37",
|
|
53
|
+
"@cubejs-backend/testing-shared": "^0.29.37",
|
|
54
|
+
"@cubejs-client/ws-transport": "^0.29.33",
|
|
51
55
|
"dedent": "^0.7.0",
|
|
52
56
|
"fs-extra": "^8.1.0",
|
|
53
57
|
"http-proxy": "^1.18.1",
|
|
54
58
|
"node-fetch": "^2.6.1",
|
|
59
|
+
"ramda": "^0.27.2",
|
|
55
60
|
"testcontainers": "^7.5.0",
|
|
56
61
|
"yargs": "^17.3.1"
|
|
57
62
|
},
|
|
58
63
|
"devDependencies": {
|
|
59
64
|
"@4tw/cypress-drag-drop": "^1.6.0",
|
|
60
65
|
"@cubejs-backend/linter": "^0.29.23",
|
|
61
|
-
"@cubejs-client/core": "^0.29.
|
|
66
|
+
"@cubejs-client/core": "^0.29.33",
|
|
62
67
|
"@jest/globals": "^26.6.2",
|
|
68
|
+
"@types/dedent": "^0.7.0",
|
|
63
69
|
"@types/http-proxy": "^1.17.5",
|
|
64
70
|
"@types/jest": "^26.0.22",
|
|
65
71
|
"@types/node": "^10.17.55",
|
|
@@ -70,7 +76,6 @@
|
|
|
70
76
|
"cypress-wait-until": "^1.7.1",
|
|
71
77
|
"eslint-plugin-cypress": "^2.12.1",
|
|
72
78
|
"jest": "^26.6.3",
|
|
73
|
-
"jest-specific-snapshot": "^5.0.0",
|
|
74
79
|
"jwt-decode": "^3.1.2",
|
|
75
80
|
"typescript": "~4.1.5"
|
|
76
81
|
},
|
|
@@ -90,5 +95,5 @@
|
|
|
90
95
|
"eslintConfig": {
|
|
91
96
|
"extends": "../cubejs-linter"
|
|
92
97
|
},
|
|
93
|
-
"gitHead": "
|
|
98
|
+
"gitHead": "a57ae4bc3b434bb54f7f97f00262c1c4cce02b61"
|
|
94
99
|
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { DbRunnerAbstract, DBRunnerContainerOptions } from './db-runner.abstract';
|
|
2
|
-
declare type CubeStoreStartOptions = DBRunnerContainerOptions & {
|
|
3
|
-
version?: string;
|
|
4
|
-
};
|
|
5
|
-
export declare class CubeStoreDBRunner extends DbRunnerAbstract {
|
|
6
|
-
static startContainer(options: CubeStoreStartOptions): Promise<import("testcontainers").StartedTestContainer>;
|
|
7
|
-
}
|
|
8
|
-
export {};
|
|
9
|
-
//# sourceMappingURL=cubestore.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cubestore.d.ts","sourceRoot":"","sources":["../../../src/db/cubestore.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAElF,aAAK,qBAAqB,GAAG,wBAAwB,GAAG;IACtD,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,qBAAa,iBAAkB,SAAQ,gBAAgB;WACvC,cAAc,CAAC,OAAO,EAAE,qBAAqB;CAgB5D"}
|
package/dist/src/db/cubestore.js
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.CubeStoreDBRunner = void 0;
|
|
4
|
-
const testcontainers_1 = require("testcontainers");
|
|
5
|
-
const db_runner_abstract_1 = require("./db-runner.abstract");
|
|
6
|
-
class CubeStoreDBRunner extends db_runner_abstract_1.DbRunnerAbstract {
|
|
7
|
-
static startContainer(options) {
|
|
8
|
-
const version = process.env.TEST_CUBESTORE_VERSION || options.version || 'latest';
|
|
9
|
-
const builder = new testcontainers_1.GenericContainer(`cubejs/cubestore:${version}`)
|
|
10
|
-
.withStartupTimeout(10 * 1000)
|
|
11
|
-
.withExposedPorts(3030);
|
|
12
|
-
if (options.volumes) {
|
|
13
|
-
// eslint-disable-next-line no-restricted-syntax
|
|
14
|
-
for (const { source, target, bindMode } of options.volumes) {
|
|
15
|
-
builder.withBindMount(source, target, bindMode);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
return builder.start();
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
exports.CubeStoreDBRunner = CubeStoreDBRunner;
|
|
22
|
-
//# sourceMappingURL=cubestore.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"cubestore.js","sourceRoot":"","sources":["../../../src/db/cubestore.ts"],"names":[],"mappings":";;;AAAA,mDAAkD;AAElD,6DAAkF;AAMlF,MAAa,iBAAkB,SAAQ,qCAAgB;IAC9C,MAAM,CAAC,cAAc,CAAC,OAA8B;QACzD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,sBAAsB,IAAI,OAAO,CAAC,OAAO,IAAI,QAAQ,CAAC;QAElF,MAAM,OAAO,GAAG,IAAI,iCAAgB,CAAC,oBAAoB,OAAO,EAAE,CAAC;aAChE,kBAAkB,CAAC,EAAE,GAAG,IAAI,CAAC;aAC7B,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAE1B,IAAI,OAAO,CAAC,OAAO,EAAE;YACnB,gDAAgD;YAChD,KAAK,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,OAAO,CAAC,OAAO,EAAE;gBAC1D,OAAO,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;aACjD;SACF;QAED,OAAO,OAAO,CAAC,KAAK,EAAE,CAAC;IACzB,CAAC;CACF;AAjBD,8CAiBC"}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
export interface ContainerVolumeDefinition {
|
|
2
|
-
source: string;
|
|
3
|
-
target: string;
|
|
4
|
-
bindMode?: 'rw' | 'ro';
|
|
5
|
-
}
|
|
6
|
-
export interface DBRunnerContainerOptions {
|
|
7
|
-
volumes?: ContainerVolumeDefinition[];
|
|
8
|
-
}
|
|
9
|
-
export declare abstract class DbRunnerAbstract {
|
|
10
|
-
}
|
|
11
|
-
//# sourceMappingURL=db-runner.abstract.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"db-runner.abstract.d.ts","sourceRoot":"","sources":["../../../src/db/db-runner.abstract.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,yBAAyB;IACxC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,IAAI,GAAG,IAAI,CAAA;CACvB;AAED,MAAM,WAAW,wBAAwB;IACvC,OAAO,CAAC,EAAE,yBAAyB,EAAE,CAAA;CACtC;AAGD,8BAAsB,gBAAgB;CAErC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DbRunnerAbstract = void 0;
|
|
4
|
-
// @todo Finish with old one PR for it
|
|
5
|
-
class DbRunnerAbstract {
|
|
6
|
-
}
|
|
7
|
-
exports.DbRunnerAbstract = DbRunnerAbstract;
|
|
8
|
-
//# sourceMappingURL=db-runner.abstract.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"db-runner.abstract.js","sourceRoot":"","sources":["../../../src/db/db-runner.abstract.ts"],"names":[],"mappings":";;;AAUA,sCAAsC;AACtC,MAAsB,gBAAgB;CAErC;AAFD,4CAEC"}
|
package/dist/src/db/index.d.ts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/db/index.ts"],"names":[],"mappings":"AAAA,cAAc,SAAS,CAAC;AACxB,cAAc,YAAY,CAAC;AAC3B,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC"}
|
package/dist/src/db/index.js
DELETED
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
-
}) : (function(o, m, k, k2) {
|
|
6
|
-
if (k2 === undefined) k2 = k;
|
|
7
|
-
o[k2] = m[k];
|
|
8
|
-
}));
|
|
9
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
|
-
};
|
|
12
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
__exportStar(require("./mysql"), exports);
|
|
14
|
-
__exportStar(require("./postgres"), exports);
|
|
15
|
-
__exportStar(require("./cubestore"), exports);
|
|
16
|
-
__exportStar(require("./questdb"), exports);
|
|
17
|
-
//# sourceMappingURL=index.js.map
|
package/dist/src/db/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/db/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,0CAAwB;AACxB,6CAA2B;AAC3B,8CAA4B;AAC5B,4CAA0B"}
|
package/dist/src/db/mysql.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { DbRunnerAbstract, DBRunnerContainerOptions } from './db-runner.abstract';
|
|
2
|
-
declare type MySQLStartOptions = DBRunnerContainerOptions & {
|
|
3
|
-
version?: string;
|
|
4
|
-
};
|
|
5
|
-
export declare class MysqlDBRunner extends DbRunnerAbstract {
|
|
6
|
-
static startContainer(options: MySQLStartOptions): Promise<import("testcontainers").StartedTestContainer>;
|
|
7
|
-
}
|
|
8
|
-
export {};
|
|
9
|
-
//# sourceMappingURL=mysql.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.d.ts","sourceRoot":"","sources":["../../../src/db/mysql.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAElF,aAAK,iBAAiB,GAAG,wBAAwB,GAAG;IAClD,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,qBAAa,aAAc,SAAQ,gBAAgB;WACnC,cAAc,CAAC,OAAO,EAAE,iBAAiB;CAgCxD"}
|
package/dist/src/db/mysql.js
DELETED
|
@@ -1,37 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.MysqlDBRunner = void 0;
|
|
4
|
-
const testcontainers_1 = require("testcontainers");
|
|
5
|
-
const db_runner_abstract_1 = require("./db-runner.abstract");
|
|
6
|
-
class MysqlDBRunner extends db_runner_abstract_1.DbRunnerAbstract {
|
|
7
|
-
static startContainer(options) {
|
|
8
|
-
const version = process.env.TEST_MYSQL_VERSION || options.version || '5.7';
|
|
9
|
-
const builder = new testcontainers_1.GenericContainer(`mysql:${version}`)
|
|
10
|
-
.withEnv('MYSQL_ROOT_PASSWORD', process.env.TEST_DB_PASSWORD || 'Test1test')
|
|
11
|
-
.withHealthCheck({
|
|
12
|
-
test: 'mysqladmin ping -h localhost',
|
|
13
|
-
interval: 5 * 1000,
|
|
14
|
-
timeout: 2 * 1000,
|
|
15
|
-
retries: 3,
|
|
16
|
-
startPeriod: 10 * 1000,
|
|
17
|
-
})
|
|
18
|
-
.withWaitStrategy(testcontainers_1.Wait.forHealthCheck())
|
|
19
|
-
.withExposedPorts(3306);
|
|
20
|
-
if (version.split('.')[0] === '8') {
|
|
21
|
-
/**
|
|
22
|
-
* workaround for MySQL 8 and unsupported auth in mysql package
|
|
23
|
-
* @link https://github.com/mysqljs/mysql/pull/2233
|
|
24
|
-
*/
|
|
25
|
-
builder.withCmd(['--default-authentication-plugin=mysql_native_password']);
|
|
26
|
-
}
|
|
27
|
-
if (options.volumes) {
|
|
28
|
-
// eslint-disable-next-line no-restricted-syntax
|
|
29
|
-
for (const { source, target, bindMode } of options.volumes) {
|
|
30
|
-
builder.withBindMount(source, target, bindMode);
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
return builder.start();
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
exports.MysqlDBRunner = MysqlDBRunner;
|
|
37
|
-
//# sourceMappingURL=mysql.js.map
|
package/dist/src/db/mysql.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mysql.js","sourceRoot":"","sources":["../../../src/db/mysql.ts"],"names":[],"mappings":";;;AAAA,mDAAwD;AAExD,6DAAkF;AAMlF,MAAa,aAAc,SAAQ,qCAAgB;IAC1C,MAAM,CAAC,cAAc,CAAC,OAA0B;QACrD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,OAAO,CAAC,OAAO,IAAI,KAAK,CAAC;QAE3E,MAAM,OAAO,GAAG,IAAI,iCAAgB,CAAC,SAAS,OAAO,EAAE,CAAC;aACrD,OAAO,CAAC,qBAAqB,EAAE,OAAO,CAAC,GAAG,CAAC,gBAAgB,IAAI,WAAW,CAAC;aAC3E,eAAe,CAAC;YACf,IAAI,EAAE,8BAA8B;YACpC,QAAQ,EAAE,CAAC,GAAG,IAAI;YAClB,OAAO,EAAE,CAAC,GAAG,IAAI;YACjB,OAAO,EAAE,CAAC;YACV,WAAW,EAAE,EAAE,GAAG,IAAI;SACvB,CAAC;aACD,gBAAgB,CAAC,qBAAI,CAAC,cAAc,EAAE,CAAC;aACvC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAE1B,IAAI,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,EAAE;YACjC;;;eAGG;YACH,OAAO,CAAC,OAAO,CAAC,CAAC,uDAAuD,CAAC,CAAC,CAAC;SAC5E;QAED,IAAI,OAAO,CAAC,OAAO,EAAE;YACnB,gDAAgD;YAChD,KAAK,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,OAAO,CAAC,OAAO,EAAE;gBAC1D,OAAO,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;aACjD;SACF;QAED,OAAO,OAAO,CAAC,KAAK,EAAE,CAAC;IACzB,CAAC;CACF;AAjCD,sCAiCC"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { DbRunnerAbstract, DBRunnerContainerOptions } from './db-runner.abstract';
|
|
2
|
-
declare type PostgresStartOptions = DBRunnerContainerOptions & {
|
|
3
|
-
version?: string;
|
|
4
|
-
};
|
|
5
|
-
export declare class PostgresDBRunner extends DbRunnerAbstract {
|
|
6
|
-
static startContainer(options: PostgresStartOptions): Promise<import("testcontainers").StartedTestContainer>;
|
|
7
|
-
}
|
|
8
|
-
export {};
|
|
9
|
-
//# sourceMappingURL=postgres.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"postgres.d.ts","sourceRoot":"","sources":["../../../src/db/postgres.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAElF,aAAK,oBAAoB,GAAG,wBAAwB,GAAG;IACrD,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,qBAAa,gBAAiB,SAAQ,gBAAgB;WACtC,cAAc,CAAC,OAAO,EAAE,oBAAoB;CA2B3D"}
|
package/dist/src/db/postgres.js
DELETED
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.PostgresDBRunner = void 0;
|
|
4
|
-
const testcontainers_1 = require("testcontainers");
|
|
5
|
-
const db_runner_abstract_1 = require("./db-runner.abstract");
|
|
6
|
-
class PostgresDBRunner extends db_runner_abstract_1.DbRunnerAbstract {
|
|
7
|
-
static startContainer(options) {
|
|
8
|
-
const version = process.env.TEST_PGSQL_VERSION || options.version || '9.6.8';
|
|
9
|
-
const container = new testcontainers_1.GenericContainer(`postgres:${version}`)
|
|
10
|
-
.withEnv('POSTGRES_USER', 'test')
|
|
11
|
-
.withEnv('POSTGRES_DB', 'test')
|
|
12
|
-
.withEnv('POSTGRES_PASSWORD', 'test')
|
|
13
|
-
.withExposedPorts(5432)
|
|
14
|
-
// .withHealthCheck({
|
|
15
|
-
// test: 'pg_isready -U root -d model_test',
|
|
16
|
-
// interval: 2 * 1000,
|
|
17
|
-
// timeout: 500,
|
|
18
|
-
// retries: 3
|
|
19
|
-
// })
|
|
20
|
-
// .withWaitStrategy(Wait.forHealthCheck())
|
|
21
|
-
// Postgresql do fast shutdown on start for db applying
|
|
22
|
-
.withStartupTimeout(10 * 1000);
|
|
23
|
-
if (options.volumes) {
|
|
24
|
-
// eslint-disable-next-line no-restricted-syntax
|
|
25
|
-
for (const { source, target, bindMode } of options.volumes) {
|
|
26
|
-
container.withBindMount(source, target, bindMode);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
return container.start();
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
exports.PostgresDBRunner = PostgresDBRunner;
|
|
33
|
-
//# sourceMappingURL=postgres.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"postgres.js","sourceRoot":"","sources":["../../../src/db/postgres.ts"],"names":[],"mappings":";;;AAAA,mDAAkD;AAElD,6DAAkF;AAMlF,MAAa,gBAAiB,SAAQ,qCAAgB;IAC7C,MAAM,CAAC,cAAc,CAAC,OAA6B;QACxD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,kBAAkB,IAAI,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC;QAE7E,MAAM,SAAS,GAAG,IAAI,iCAAgB,CAAC,YAAY,OAAO,EAAE,CAAC;aAC1D,OAAO,CAAC,eAAe,EAAE,MAAM,CAAC;aAChC,OAAO,CAAC,aAAa,EAAE,MAAM,CAAC;aAC9B,OAAO,CAAC,mBAAmB,EAAE,MAAM,CAAC;aACpC,gBAAgB,CAAC,IAAI,CAAC;YACvB,qBAAqB;YACrB,8CAA8C;YAC9C,wBAAwB;YACxB,kBAAkB;YAClB,eAAe;YACf,KAAK;YACL,2CAA2C;YAC3C,uDAAuD;aACtD,kBAAkB,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC;QAEjC,IAAI,OAAO,CAAC,OAAO,EAAE;YACnB,gDAAgD;YAChD,KAAK,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,OAAO,CAAC,OAAO,EAAE;gBAC1D,SAAS,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;aACnD;SACF;QAED,OAAO,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;CACF;AA5BD,4CA4BC"}
|
package/dist/src/db/questdb.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { DbRunnerAbstract, DBRunnerContainerOptions } from './db-runner.abstract';
|
|
2
|
-
declare type QuestStartOptions = DBRunnerContainerOptions & {
|
|
3
|
-
version?: string;
|
|
4
|
-
};
|
|
5
|
-
export declare class QuestDBRunner extends DbRunnerAbstract {
|
|
6
|
-
static startContainer(options: QuestStartOptions): Promise<import("testcontainers").StartedTestContainer>;
|
|
7
|
-
}
|
|
8
|
-
export {};
|
|
9
|
-
//# sourceMappingURL=questdb.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"questdb.d.ts","sourceRoot":"","sources":["../../../src/db/questdb.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,sBAAsB,CAAC;AAElF,aAAK,iBAAiB,GAAG,wBAAwB,GAAG;IAClD,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,qBAAa,aAAc,SAAQ,gBAAgB;WACnC,cAAc,CAAC,OAAO,EAAE,iBAAiB;CAgBxD"}
|
package/dist/src/db/questdb.js
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.QuestDBRunner = void 0;
|
|
4
|
-
const testcontainers_1 = require("testcontainers");
|
|
5
|
-
const db_runner_abstract_1 = require("./db-runner.abstract");
|
|
6
|
-
class QuestDBRunner extends db_runner_abstract_1.DbRunnerAbstract {
|
|
7
|
-
static startContainer(options) {
|
|
8
|
-
const version = process.env.TEST_QUEST_DB_VERSION || options.version || '6.2';
|
|
9
|
-
const container = new testcontainers_1.GenericContainer(`questdb/questdb:${version}`)
|
|
10
|
-
.withExposedPorts(8812)
|
|
11
|
-
.withStartupTimeout(10 * 1000);
|
|
12
|
-
if (options.volumes) {
|
|
13
|
-
// eslint-disable-next-line no-restricted-syntax
|
|
14
|
-
for (const { source, target, bindMode } of options.volumes) {
|
|
15
|
-
container.withBindMount(source, target, bindMode);
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
return container.start();
|
|
19
|
-
}
|
|
20
|
-
}
|
|
21
|
-
exports.QuestDBRunner = QuestDBRunner;
|
|
22
|
-
//# sourceMappingURL=questdb.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"questdb.js","sourceRoot":"","sources":["../../../src/db/questdb.ts"],"names":[],"mappings":";;;AAAA,mDAAkD;AAElD,6DAAkF;AAMlF,MAAa,aAAc,SAAQ,qCAAgB;IAC1C,MAAM,CAAC,cAAc,CAAC,OAA0B;QACrD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,qBAAqB,IAAI,OAAO,CAAC,OAAO,IAAI,KAAK,CAAC;QAE9E,MAAM,SAAS,GAAG,IAAI,iCAAgB,CAAC,mBAAmB,OAAO,EAAE,CAAC;aACjE,gBAAgB,CAAC,IAAI,CAAC;aACtB,kBAAkB,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC;QAEjC,IAAI,OAAO,CAAC,OAAO,EAAE;YACnB,gDAAgD;YAChD,KAAK,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,OAAO,CAAC,OAAO,EAAE;gBAC1D,SAAS,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;aACnD;SACF;QAED,OAAO,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;CACF;AAjBD,sCAiBC"}
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { DriverInterface } from '@cubejs-backend/query-orchestrator';
|
|
2
|
-
export interface DriverTestsOptions {
|
|
3
|
-
expectStringFields?: boolean;
|
|
4
|
-
csvNoHeader?: boolean;
|
|
5
|
-
wrapLoadQueryWithCtas?: boolean;
|
|
6
|
-
}
|
|
7
|
-
export declare class DriverTests {
|
|
8
|
-
readonly driver: DriverInterface;
|
|
9
|
-
private readonly options;
|
|
10
|
-
constructor(driver: DriverInterface, options?: DriverTestsOptions);
|
|
11
|
-
static config(): void;
|
|
12
|
-
release(): Promise<void>;
|
|
13
|
-
static QUERY: string;
|
|
14
|
-
static ROWS: {
|
|
15
|
-
id: number;
|
|
16
|
-
amount: number;
|
|
17
|
-
status: string;
|
|
18
|
-
}[];
|
|
19
|
-
static CSV_ROWS: string;
|
|
20
|
-
testQuery(): Promise<void>;
|
|
21
|
-
testStream(): Promise<void>;
|
|
22
|
-
testUnload(): Promise<void>;
|
|
23
|
-
private skipFirstLine;
|
|
24
|
-
private rowsToString;
|
|
25
|
-
}
|
|
26
|
-
//# sourceMappingURL=DriverTests.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DriverTests.d.ts","sourceRoot":"","sources":["../../../src/testing/DriverTests.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAmB,MAAM,oCAAoC,CAAC;AAOtF,MAAM,WAAW,kBAAkB;IAEjC,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAG5B,WAAW,CAAC,EAAE,OAAO,CAAA;IAErB,qBAAqB,CAAC,EAAE,OAAO,CAAA;CAChC;AAED,qBAAa,WAAW;aAEJ,MAAM,EAAE,eAAe;IACvC,OAAO,CAAC,QAAQ,CAAC,OAAO;gBADR,MAAM,EAAE,eAAe,EACtB,OAAO,GAAE,kBAAuB;WAIrC,MAAM;IAMb,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC;IAI/B,OAAc,KAAK,SAUjB;IAEF,OAAc,IAAI;;;;QAIhB;IAEF,OAAc,QAAQ,SAIpB;IAEW,SAAS;IAMT,UAAU;IASV,UAAU;IAmCvB,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,YAAY;CAWrB"}
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.DriverTests = void 0;
|
|
7
|
-
// eslint-disable-next-line import/no-extraneous-dependencies
|
|
8
|
-
const globals_1 = require("@jest/globals");
|
|
9
|
-
const query_orchestrator_1 = require("@cubejs-backend/query-orchestrator");
|
|
10
|
-
const shared_1 = require("@cubejs-backend/shared");
|
|
11
|
-
const crypto_1 = __importDefault(require("crypto"));
|
|
12
|
-
const dedent_1 = __importDefault(require("dedent"));
|
|
13
|
-
const dotenv_1 = __importDefault(require("@cubejs-backend/dotenv"));
|
|
14
|
-
const stream_1 = require("stream");
|
|
15
|
-
class DriverTests {
|
|
16
|
-
constructor(driver, options = {}) {
|
|
17
|
-
this.driver = driver;
|
|
18
|
-
this.options = options;
|
|
19
|
-
}
|
|
20
|
-
static config() {
|
|
21
|
-
if ('CUBEJS_TEST_ENV' in process.env) {
|
|
22
|
-
dotenv_1.default.config({ path: process.env.CUBEJS_TEST_ENV });
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
release() {
|
|
26
|
-
return this.driver.release();
|
|
27
|
-
}
|
|
28
|
-
async testQuery() {
|
|
29
|
-
const rows = await this.driver.query(DriverTests.QUERY, []);
|
|
30
|
-
const expectedRows = this.options.expectStringFields ? this.rowsToString(DriverTests.ROWS) : DriverTests.ROWS;
|
|
31
|
-
globals_1.expect(rows).toEqual(expectedRows);
|
|
32
|
-
}
|
|
33
|
-
async testStream() {
|
|
34
|
-
globals_1.expect(this.driver.stream).toBeDefined();
|
|
35
|
-
const tableData = await this.driver.stream(DriverTests.QUERY, [], { highWaterMark: 100 });
|
|
36
|
-
globals_1.expect(tableData.rowStream instanceof stream_1.Readable);
|
|
37
|
-
const rows = await shared_1.streamToArray(tableData.rowStream);
|
|
38
|
-
const expectedRows = this.options.expectStringFields ? this.rowsToString(DriverTests.ROWS) : DriverTests.ROWS;
|
|
39
|
-
globals_1.expect(rows).toEqual(expectedRows);
|
|
40
|
-
}
|
|
41
|
-
async testUnload() {
|
|
42
|
-
globals_1.expect(this.driver.unload).toBeDefined();
|
|
43
|
-
const versionEntry = {
|
|
44
|
-
table_name: 'test.orders_order_status',
|
|
45
|
-
structure_version: crypto_1.default.randomBytes(10).toString('hex'),
|
|
46
|
-
content_version: crypto_1.default.randomBytes(10).toString('hex'),
|
|
47
|
-
last_updated_at: new Date().getTime(),
|
|
48
|
-
naming_version: 2
|
|
49
|
-
};
|
|
50
|
-
const tableName = query_orchestrator_1.PreAggregations.targetTableName(versionEntry);
|
|
51
|
-
const query = `
|
|
52
|
-
SELECT orders.status AS orders__status, sum(orders.amount) AS orders__amount
|
|
53
|
-
FROM (${DriverTests.QUERY}) AS orders
|
|
54
|
-
GROUP BY 1
|
|
55
|
-
ORDER BY 1
|
|
56
|
-
`;
|
|
57
|
-
const loadQuery = this.options.wrapLoadQueryWithCtas ? `CREATE TABLE ${tableName} AS ${query}` : query;
|
|
58
|
-
await this.driver.loadPreAggregationIntoTable(tableName, loadQuery, [], {
|
|
59
|
-
newVersionEntry: versionEntry,
|
|
60
|
-
targetTableName: tableName,
|
|
61
|
-
});
|
|
62
|
-
const data = await this.driver.unload(tableName, { maxFileSize: 64 });
|
|
63
|
-
globals_1.expect(data.csvFile.length).toEqual(1);
|
|
64
|
-
const string = await shared_1.downloadAndGunzip(data.csvFile[0]);
|
|
65
|
-
const expectedRows = this.options.csvNoHeader
|
|
66
|
-
? this.skipFirstLine(DriverTests.CSV_ROWS)
|
|
67
|
-
: DriverTests.CSV_ROWS;
|
|
68
|
-
globals_1.expect(string.trim()).toEqual(expectedRows);
|
|
69
|
-
}
|
|
70
|
-
skipFirstLine(text) {
|
|
71
|
-
return text.split('\n').slice(1).join('\n');
|
|
72
|
-
}
|
|
73
|
-
rowsToString(rows) {
|
|
74
|
-
const result = [];
|
|
75
|
-
for (const row of rows) {
|
|
76
|
-
const newRow = {};
|
|
77
|
-
for (const k of Object.keys(row)) {
|
|
78
|
-
newRow[k] = row[k].toString();
|
|
79
|
-
}
|
|
80
|
-
result.push(newRow);
|
|
81
|
-
}
|
|
82
|
-
return result;
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
exports.DriverTests = DriverTests;
|
|
86
|
-
DriverTests.QUERY = `
|
|
87
|
-
SELECT id, amount, status
|
|
88
|
-
FROM (
|
|
89
|
-
SELECT 1 AS id, 100 AS amount, 'new' AS status
|
|
90
|
-
UNION ALL
|
|
91
|
-
SELECT 2 AS id, 200 AS amount, 'new' AS status
|
|
92
|
-
UNION ALL
|
|
93
|
-
SELECT 3 AS id, 400 AS amount, 'processed' AS status
|
|
94
|
-
)
|
|
95
|
-
ORDER BY 1
|
|
96
|
-
`;
|
|
97
|
-
DriverTests.ROWS = [
|
|
98
|
-
{ id: 1, amount: 100, status: 'new' },
|
|
99
|
-
{ id: 2, amount: 200, status: 'new' },
|
|
100
|
-
{ id: 3, amount: 400, status: 'processed' },
|
|
101
|
-
];
|
|
102
|
-
DriverTests.CSV_ROWS = dedent_1.default `
|
|
103
|
-
orders__status,orders__amount
|
|
104
|
-
new,300
|
|
105
|
-
processed,400
|
|
106
|
-
`;
|
|
107
|
-
//# sourceMappingURL=DriverTests.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DriverTests.js","sourceRoot":"","sources":["../../../src/testing/DriverTests.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/testing/index.ts"],"names":[],"mappings":"AAAA,cAAc,uBAAuB,CAAC;AACtC,cAAc,eAAe,CAAC"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
|
5
|
-
}) : (function(o, m, k, k2) {
|
|
6
|
-
if (k2 === undefined) k2 = k;
|
|
7
|
-
o[k2] = m[k];
|
|
8
|
-
}));
|
|
9
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
10
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
11
|
-
};
|
|
12
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
-
__exportStar(require("./query-test.abstract"), exports);
|
|
14
|
-
__exportStar(require("./DriverTests"), exports);
|
|
15
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/testing/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,wDAAsC;AACtC,gDAA8B"}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { BaseDriver } from '@cubejs-backend/query-orchestrator';
|
|
2
|
-
import { BaseQuery } from '@cubejs-backend/schema-compiler';
|
|
3
|
-
import { StartedTestContainer } from 'testcontainers';
|
|
4
|
-
export declare const prepareCompiler: (content: any, options?: any) => {
|
|
5
|
-
compiler: import("@cubejs-backend/schema-compiler/dist/src/compiler/DataSchemaCompiler").DataSchemaCompiler;
|
|
6
|
-
metaTransformer: import("@cubejs-backend/schema-compiler/dist/src/compiler/CubeToMetaTransformer").CubeToMetaTransformer;
|
|
7
|
-
cubeEvaluator: import("@cubejs-backend/schema-compiler/dist/src/compiler/CubeEvaluator").CubeEvaluator;
|
|
8
|
-
contextEvaluator: import("@cubejs-backend/schema-compiler/dist/src/compiler/ContextEvaluator").ContextEvaluator;
|
|
9
|
-
joinGraph: import("@cubejs-backend/schema-compiler/dist/src/compiler/JoinGraph").JoinGraph;
|
|
10
|
-
compilerCache: import("@cubejs-backend/schema-compiler/dist/src/compiler/CompilerCache").CompilerCache;
|
|
11
|
-
headCommitId: any;
|
|
12
|
-
};
|
|
13
|
-
export declare abstract class QueryTestAbstract<T extends BaseDriver> {
|
|
14
|
-
abstract getQueryClass(): any;
|
|
15
|
-
protected getQuery(a: any, b: any): BaseQuery;
|
|
16
|
-
testRefreshKeyEveryDay(connection: T): Promise<void>;
|
|
17
|
-
testRefreshKeyIncrementalWithUpdateWindow(connection: T): Promise<void>;
|
|
18
|
-
}
|
|
19
|
-
export interface QueryTestCaseOptions {
|
|
20
|
-
name: string;
|
|
21
|
-
connectionFactory: (container: StartedTestContainer) => BaseDriver;
|
|
22
|
-
DbRunnerClass: any;
|
|
23
|
-
}
|
|
24
|
-
export declare function createQueryTestCase(test: QueryTestAbstract<any>, opts: QueryTestCaseOptions): void;
|
|
25
|
-
//# sourceMappingURL=query-test.abstract.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"query-test.abstract.d.ts","sourceRoot":"","sources":["../../../src/testing/query-test.abstract.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAChE,OAAO,EAAE,SAAS,EAA8C,MAAM,iCAAiC,CAAC;AACxG,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAKtD,eAAO,MAAM,eAAe,YAAa,GAAG,YAAY,GAAG;;;;;;;;CAKpB,CAAC;AAExC,8BAAsB,iBAAiB,CAAC,CAAC,SAAS,UAAU;IAC1D,QAAQ,CAAC,aAAa,IAAI,GAAG;IAE7B,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,GAAG,SAAS;IAMhC,sBAAsB,CAAC,UAAU,EAAE,CAAC;IA4CpC,yCAAyC,CAAC,UAAU,EAAE,CAAC;CAiDrE;AAED,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,MAAM,CAAC;IACb,iBAAiB,EAAE,CAAC,SAAS,EAAE,oBAAoB,KAAK,UAAU,CAAC;IACnE,aAAa,EAAE,GAAG,CAAC;CACpB;AAED,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,iBAAiB,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,oBAAoB,QAyB3F"}
|
|
@@ -1,123 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createQueryTestCase = exports.QueryTestAbstract = exports.prepareCompiler = void 0;
|
|
4
|
-
// eslint-disable-next-line import/no-extraneous-dependencies
|
|
5
|
-
const globals_1 = require("@jest/globals");
|
|
6
|
-
const schema_compiler_1 = require("@cubejs-backend/schema-compiler");
|
|
7
|
-
const shared_1 = require("@cubejs-backend/shared");
|
|
8
|
-
const utils_1 = require("../utils");
|
|
9
|
-
const prepareCompiler = (content, options) => schema_compiler_1.prepareCompiler({
|
|
10
|
-
localPath: () => __dirname,
|
|
11
|
-
dataSchemaFiles: () => Promise.resolve([
|
|
12
|
-
{ fileName: 'main.js', content }
|
|
13
|
-
])
|
|
14
|
-
}, { adapter: 'postgres', ...options });
|
|
15
|
-
exports.prepareCompiler = prepareCompiler;
|
|
16
|
-
class QueryTestAbstract {
|
|
17
|
-
getQuery(a, b) {
|
|
18
|
-
const QueryClass = this.getQueryClass();
|
|
19
|
-
return new QueryClass(a, b);
|
|
20
|
-
}
|
|
21
|
-
async testRefreshKeyEveryDay(connection) {
|
|
22
|
-
const { compiler, joinGraph, cubeEvaluator } = exports.prepareCompiler(utils_1.createCubeSchema({
|
|
23
|
-
name: 'cards',
|
|
24
|
-
preAggregations: `
|
|
25
|
-
countCreatedAt: {
|
|
26
|
-
type: 'rollup',
|
|
27
|
-
external: true,
|
|
28
|
-
measureReferences: [count],
|
|
29
|
-
timeDimensionReference: createdAt,
|
|
30
|
-
granularity: \`day\`,
|
|
31
|
-
partitionGranularity: \`month\`,
|
|
32
|
-
scheduledRefresh: true,
|
|
33
|
-
refreshKey: {
|
|
34
|
-
every: \`1 day\`,
|
|
35
|
-
},
|
|
36
|
-
},
|
|
37
|
-
`
|
|
38
|
-
}));
|
|
39
|
-
await compiler.compile();
|
|
40
|
-
const query = this.getQuery({ joinGraph, cubeEvaluator, compiler }, {
|
|
41
|
-
measures: [
|
|
42
|
-
'cards.count'
|
|
43
|
-
],
|
|
44
|
-
timeDimensions: [{
|
|
45
|
-
dimension: 'cards.createdAt',
|
|
46
|
-
granularity: 'day',
|
|
47
|
-
dateRange: ['2016-12-30', '2017-01-05']
|
|
48
|
-
}],
|
|
49
|
-
filters: [],
|
|
50
|
-
timezone: 'America/Los_Angeles',
|
|
51
|
-
});
|
|
52
|
-
const preAggregations = query.newPreAggregations().preAggregationsDescription();
|
|
53
|
-
const [sql, params] = preAggregations[0].invalidateKeyQueries[0];
|
|
54
|
-
console.log('Executing ', [sql, params]);
|
|
55
|
-
await connection.query(sql, params, {});
|
|
56
|
-
}
|
|
57
|
-
async testRefreshKeyIncrementalWithUpdateWindow(connection) {
|
|
58
|
-
const { compiler, joinGraph, cubeEvaluator } = exports.prepareCompiler(utils_1.createCubeSchema({
|
|
59
|
-
name: 'cards',
|
|
60
|
-
preAggregations: `
|
|
61
|
-
countCreatedAt: {
|
|
62
|
-
type: 'rollup',
|
|
63
|
-
external: true,
|
|
64
|
-
measureReferences: [count],
|
|
65
|
-
timeDimensionReference: createdAt,
|
|
66
|
-
granularity: \`day\`,
|
|
67
|
-
partitionGranularity: \`month\`,
|
|
68
|
-
scheduledRefresh: true,
|
|
69
|
-
refreshKey: {
|
|
70
|
-
every: \`1 day\`,
|
|
71
|
-
incremental: true,
|
|
72
|
-
updateWindow: \`7 day\`,
|
|
73
|
-
},
|
|
74
|
-
},
|
|
75
|
-
`
|
|
76
|
-
}));
|
|
77
|
-
await compiler.compile();
|
|
78
|
-
const query = this.getQuery({ joinGraph, cubeEvaluator, compiler }, {
|
|
79
|
-
measures: [
|
|
80
|
-
'cards.count'
|
|
81
|
-
],
|
|
82
|
-
timeDimensions: [{
|
|
83
|
-
dimension: 'cards.createdAt',
|
|
84
|
-
granularity: 'day',
|
|
85
|
-
dateRange: ['2016-12-30', '2017-01-05']
|
|
86
|
-
}],
|
|
87
|
-
filters: [],
|
|
88
|
-
timezone: 'America/Los_Angeles',
|
|
89
|
-
});
|
|
90
|
-
const preAggregations = query.newPreAggregations().preAggregationsDescription();
|
|
91
|
-
// eslint-disable-next-line prefer-const
|
|
92
|
-
let [sql, params] = preAggregations[0].invalidateKeyQueries[0];
|
|
93
|
-
// TODO Introduce full cycle testing through BaseDbRunner / QueryOrchestrator.
|
|
94
|
-
// TODO Internal structures shouldn't be never accessed in tests.
|
|
95
|
-
params = params.map((p) => (p === shared_1.TO_PARTITION_RANGE ? '2017-01-05T00:00:00' : p));
|
|
96
|
-
console.log('Executing ', [sql, params]);
|
|
97
|
-
await connection.query(sql, params, {});
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
exports.QueryTestAbstract = QueryTestAbstract;
|
|
101
|
-
function createQueryTestCase(test, opts) {
|
|
102
|
-
globals_1.describe(`${opts.name}Query`, () => {
|
|
103
|
-
globals_1.jest.setTimeout(60 * 1000);
|
|
104
|
-
let container;
|
|
105
|
-
let connection;
|
|
106
|
-
globals_1.beforeAll(async () => {
|
|
107
|
-
container = await opts.DbRunnerClass.startContainer({});
|
|
108
|
-
connection = opts.connectionFactory(container);
|
|
109
|
-
});
|
|
110
|
-
globals_1.afterAll(async () => {
|
|
111
|
-
if (connection) {
|
|
112
|
-
await connection.release();
|
|
113
|
-
}
|
|
114
|
-
if (container) {
|
|
115
|
-
await container.stop();
|
|
116
|
-
}
|
|
117
|
-
});
|
|
118
|
-
globals_1.it('test refreshKey every day', async () => test.testRefreshKeyEveryDay(connection));
|
|
119
|
-
globals_1.it('test refreshKey incremental with update window', async () => test.testRefreshKeyIncrementalWithUpdateWindow(connection));
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
|
-
exports.createQueryTestCase = createQueryTestCase;
|
|
123
|
-
//# sourceMappingURL=query-test.abstract.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"query-test.abstract.js","sourceRoot":"","sources":["../../../src/testing/query-test.abstract.ts"],"names":[],"mappings":"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"}
|
package/dist/src/utils.d.ts
DELETED
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export declare function getLocalHostnameByOs(): "docker.for.win.localhost" | "host.docker.internal" | "localhost";
|
|
2
|
-
interface CreateCubeSchemaOptions {
|
|
3
|
-
name: string;
|
|
4
|
-
refreshKey?: string;
|
|
5
|
-
preAggregations?: string;
|
|
6
|
-
}
|
|
7
|
-
export declare function createCubeSchema({ name, refreshKey, preAggregations }: CreateCubeSchemaOptions): string;
|
|
8
|
-
export {};
|
|
9
|
-
//# sourceMappingURL=utils.d.ts.map
|
package/dist/src/utils.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"AAEA,wBAAgB,oBAAoB,sEAUnC;AAED,UAAU,uBAAuB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,wBAAgB,gBAAgB,CAAC,EAAE,IAAI,EAAE,UAAe,EAAE,eAAoB,EAAE,EAAE,uBAAuB,UA4CxG"}
|
package/dist/src/utils.js
DELETED
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createCubeSchema = exports.getLocalHostnameByOs = void 0;
|
|
4
|
-
const os_1 = require("os");
|
|
5
|
-
function getLocalHostnameByOs() {
|
|
6
|
-
if (os_1.platform() === 'win32') {
|
|
7
|
-
return 'docker.for.win.localhost';
|
|
8
|
-
}
|
|
9
|
-
if (os_1.platform() === 'darwin') {
|
|
10
|
-
return 'host.docker.internal';
|
|
11
|
-
}
|
|
12
|
-
return 'localhost';
|
|
13
|
-
}
|
|
14
|
-
exports.getLocalHostnameByOs = getLocalHostnameByOs;
|
|
15
|
-
function createCubeSchema({ name, refreshKey = '', preAggregations = '' }) {
|
|
16
|
-
return `
|
|
17
|
-
cube('${name}', {
|
|
18
|
-
sql: \`
|
|
19
|
-
select * from cards
|
|
20
|
-
\`,
|
|
21
|
-
|
|
22
|
-
${refreshKey}
|
|
23
|
-
|
|
24
|
-
measures: {
|
|
25
|
-
count: {
|
|
26
|
-
type: 'count'
|
|
27
|
-
},
|
|
28
|
-
sum: {
|
|
29
|
-
sql: \`amount\`,
|
|
30
|
-
type: \`sum\`
|
|
31
|
-
},
|
|
32
|
-
max: {
|
|
33
|
-
sql: \`amount\`,
|
|
34
|
-
type: \`max\`
|
|
35
|
-
},
|
|
36
|
-
min: {
|
|
37
|
-
sql: \`amount\`,
|
|
38
|
-
type: \`min\`
|
|
39
|
-
}
|
|
40
|
-
},
|
|
41
|
-
|
|
42
|
-
dimensions: {
|
|
43
|
-
id: {
|
|
44
|
-
type: 'number',
|
|
45
|
-
sql: 'id',
|
|
46
|
-
primaryKey: true
|
|
47
|
-
},
|
|
48
|
-
createdAt: {
|
|
49
|
-
type: 'time',
|
|
50
|
-
sql: 'created_at'
|
|
51
|
-
},
|
|
52
|
-
},
|
|
53
|
-
|
|
54
|
-
preAggregations: {
|
|
55
|
-
${preAggregations}
|
|
56
|
-
}
|
|
57
|
-
})
|
|
58
|
-
`;
|
|
59
|
-
}
|
|
60
|
-
exports.createCubeSchema = createCubeSchema;
|
|
61
|
-
//# sourceMappingURL=utils.js.map
|
package/dist/src/utils.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":";;;AAAA,2BAA8B;AAE9B,SAAgB,oBAAoB;IAClC,IAAI,aAAQ,EAAE,KAAK,OAAO,EAAE;QAC1B,OAAO,0BAA0B,CAAC;KACnC;IAED,IAAI,aAAQ,EAAE,KAAK,QAAQ,EAAE;QAC3B,OAAO,sBAAsB,CAAC;KAC/B;IAED,OAAO,WAAW,CAAC;AACrB,CAAC;AAVD,oDAUC;AAQD,SAAgB,gBAAgB,CAAC,EAAE,IAAI,EAAE,UAAU,GAAG,EAAE,EAAE,eAAe,GAAG,EAAE,EAA2B;IACvG,OAAO;YACG,IAAI;;;;;UAKN,UAAU;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAiCN,eAAe;;;GAG1B,CAAC;AACJ,CAAC;AA5CD,4CA4CC"}
|