mirror of
https://github.com/open-metadata/OpenMetadata.git
synced 2025-09-04 22:53:27 +00:00
134 lines
4.0 KiB
TypeScript
134 lines
4.0 KiB
TypeScript
/*
|
|
* Copyright 2024 Collate.
|
|
* Licensed 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.
|
|
*/
|
|
import { expect, Page } from '@playwright/test';
|
|
import { isUndefined } from 'lodash';
|
|
import { descriptionBox, toastNotification } from './common';
|
|
|
|
export type TaskDetails = {
|
|
term: string;
|
|
assignee?: string;
|
|
tag?: string;
|
|
};
|
|
|
|
const tag = 'PII.None';
|
|
|
|
export const createDescriptionTask = async (
|
|
page: Page,
|
|
value: TaskDetails,
|
|
assigneeDisabled?: boolean
|
|
) => {
|
|
expect(await page.locator('#title').inputValue()).toBe(
|
|
`Update description for table ${value.term}`
|
|
);
|
|
|
|
if (isUndefined(value.assignee) || assigneeDisabled) {
|
|
expect(
|
|
await page
|
|
.locator('[data-testid="select-assignee"] > .ant-select-selector')
|
|
.innerText()
|
|
).toBe(value.assignee);
|
|
|
|
expect(
|
|
await page
|
|
.locator('[data-testid="select-assignee"] > .ant-select-selector input')
|
|
.isDisabled()
|
|
);
|
|
} else {
|
|
const assigneeField = page.locator(
|
|
'[data-testid="select-assignee"] > .ant-select-selector #assignees'
|
|
);
|
|
await assigneeField.click();
|
|
|
|
const userSearchResponse = page.waitForResponse(
|
|
`/api/v1/search/suggest?q=${value.assignee}&index=user_search_index%2Cteam_search_index`
|
|
);
|
|
await assigneeField.fill(value.assignee);
|
|
await userSearchResponse;
|
|
|
|
// select value from dropdown
|
|
const dropdownValue = page.getByTestId(value.assignee);
|
|
await dropdownValue.hover();
|
|
await dropdownValue.click();
|
|
await page.click('body');
|
|
}
|
|
|
|
await page.locator(descriptionBox).fill('Updated description');
|
|
await page.click('button[type="submit"]');
|
|
|
|
await toastNotification(page, /Task created successfully./);
|
|
};
|
|
|
|
export const createTagTask = async (
|
|
page: Page,
|
|
value: TaskDetails,
|
|
assigneeDisabled?: boolean
|
|
) => {
|
|
expect(await page.locator('#title').inputValue()).toBe(
|
|
`Request tags for table ${value.term}`
|
|
);
|
|
|
|
if (isUndefined(value.assignee) || assigneeDisabled) {
|
|
expect(
|
|
await page
|
|
.locator('[data-testid="select-assignee"] > .ant-select-selector')
|
|
.innerText()
|
|
).toBe(value.assignee);
|
|
|
|
expect(
|
|
await page
|
|
.locator('[data-testid="select-assignee"] > .ant-select-selector input')
|
|
.isDisabled()
|
|
);
|
|
} else {
|
|
// select assignee
|
|
const assigneeField = page.locator(
|
|
'[data-testid="select-assignee"] > .ant-select-selector #assignees'
|
|
);
|
|
await assigneeField.click();
|
|
const userSearchResponse = page.waitForResponse(
|
|
`/api/v1/search/suggest?q=${value.assignee}&index=user_search_index%2Cteam_search_index`
|
|
);
|
|
await assigneeField.fill(value.assignee);
|
|
await userSearchResponse;
|
|
|
|
// select value from dropdown
|
|
const dropdownValue = page.getByTestId(value.assignee);
|
|
await dropdownValue.hover();
|
|
await dropdownValue.click();
|
|
await page.mouse.click(0, 0);
|
|
}
|
|
|
|
// select tags
|
|
const suggestTags = page.locator(
|
|
'[data-testid="tag-selector"] > .ant-select-selector .ant-select-selection-search-input'
|
|
);
|
|
await suggestTags.click();
|
|
|
|
const querySearchResponse = page.waitForResponse(
|
|
`/api/v1/search/query?q=*${value.tag ?? tag}*&index=tag_search_index&*`
|
|
);
|
|
await suggestTags.fill(value.tag ?? tag);
|
|
|
|
await querySearchResponse;
|
|
|
|
// select value from dropdown
|
|
const dropdownValue = page.getByTestId(`tag-${value.tag ?? tag}`);
|
|
await dropdownValue.hover();
|
|
await dropdownValue.click();
|
|
await page.mouse.click(0, 0);
|
|
|
|
await page.click('button[type="submit"]');
|
|
|
|
await toastNotification(page, /Task created successfully./);
|
|
};
|