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./);
};