2022-08-24 19:17:12 -04:00
|
|
|
/*
|
|
|
|
* Licensed to the Apache Software Foundation (ASF) under one
|
|
|
|
* or more contributor license agreements. See the NOTICE file
|
|
|
|
* distributed with this work for additional information
|
|
|
|
* regarding copyright ownership. The ASF licenses this file
|
|
|
|
* to you under the Apache License, Version 2.0 (the
|
|
|
|
* "License"); you may not use this file except in compliance
|
|
|
|
* with the License. You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2023-02-07 02:12:54 -05:00
|
|
|
import type * as playwright from 'playwright-chromium';
|
2022-08-24 19:17:12 -04:00
|
|
|
|
|
|
|
import { WorkbenchOverview } from './component/workbench/overview';
|
|
|
|
import { saveScreenshotIfError } from './util/debug';
|
|
|
|
import { DRUID_EXAMPLES_QUICKSTART_TUTORIAL_DIR, UNIFIED_CONSOLE_URL } from './util/druid';
|
|
|
|
import { createBrowser, createPage } from './util/playwright';
|
|
|
|
import { waitTillWebConsoleReady } from './util/setup';
|
|
|
|
|
|
|
|
jest.setTimeout(5 * 60 * 1000);
|
|
|
|
|
|
|
|
describe('Multi-stage query', () => {
|
|
|
|
let browser: playwright.Browser;
|
|
|
|
let page: playwright.Page;
|
|
|
|
|
|
|
|
beforeAll(async () => {
|
|
|
|
await waitTillWebConsoleReady();
|
|
|
|
browser = await createBrowser();
|
|
|
|
});
|
|
|
|
|
|
|
|
beforeEach(async () => {
|
|
|
|
page = await createPage(browser);
|
|
|
|
});
|
|
|
|
|
|
|
|
afterAll(async () => {
|
|
|
|
await browser.close();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('runs a query that reads external data', async () => {
|
2023-11-18 12:57:29 -05:00
|
|
|
const workbench = new WorkbenchOverview(page, UNIFIED_CONSOLE_URL);
|
|
|
|
|
2022-08-24 19:17:12 -04:00
|
|
|
await saveScreenshotIfError('multi-stage-query', page, async () => {
|
|
|
|
const results = await workbench.runQuery(`WITH ext AS (SELECT *
|
|
|
|
FROM TABLE(
|
|
|
|
EXTERN(
|
|
|
|
'{"type":"local","filter":"wikiticker-2015-09-12-sampled.json.gz","baseDir":${JSON.stringify(
|
|
|
|
DRUID_EXAMPLES_QUICKSTART_TUTORIAL_DIR,
|
|
|
|
)}}',
|
2023-03-29 19:19:49 -04:00
|
|
|
'{"type":"json"}'
|
2022-08-24 19:17:12 -04:00
|
|
|
)
|
2023-03-29 19:19:49 -04:00
|
|
|
) EXTEND (channel VARCHAR))
|
2022-08-24 19:17:12 -04:00
|
|
|
SELECT
|
|
|
|
channel,
|
|
|
|
CAST(COUNT(*) AS VARCHAR) AS "CountString"
|
|
|
|
FROM ext
|
|
|
|
GROUP BY 1
|
|
|
|
ORDER BY COUNT(*) DESC
|
|
|
|
LIMIT 10`);
|
|
|
|
expect(results).toBeDefined();
|
|
|
|
expect(results.length).toBe(10);
|
|
|
|
expect(results[0]).toStrictEqual(['#en.wikipedia', '11549']);
|
|
|
|
expect(results[1]).toStrictEqual(['#vi.wikipedia', '9747']);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|