|
|
|
import { expect } from '@playwright/test';
|
|
|
|
import BasePage from '../../Base';
|
|
|
|
import { getTextExcludeIconText } from '../../../tests/utils/general';
|
|
|
|
import { DataSourcePage } from './DataSourcePage';
|
|
|
|
|
|
|
|
export class MetaDataPage extends BasePage {
|
|
|
|
constructor(dataSource: DataSourcePage) {
|
|
|
|
super(dataSource.rootPage);
|
|
|
|
}
|
|
|
|
|
|
|
|
get() {
|
|
|
|
return this.rootPage.locator('div.ant-modal-content');
|
|
|
|
}
|
|
|
|
|
|
|
|
async clickReload() {
|
|
|
|
await this.get().locator(`button:has-text("Reload")`).click();
|
|
|
|
|
|
|
|
// todo: Remove this wait
|
|
|
|
await this.rootPage.waitForTimeout(100);
|
|
|
|
// await this.get().locator(`.animate-spin`).waitFor({state: 'visible'});
|
|
|
|
await this.get().locator(`.animate-spin`).waitFor({ state: 'detached', timeout: 10000 });
|
|
|
|
}
|
|
|
|
|
|
|
|
async close() {
|
|
|
|
await this.get().click();
|
|
|
|
await this.rootPage.keyboard.press('Escape');
|
|
|
|
await this.rootPage.keyboard.press('Escape');
|
|
|
|
await this.get().waitFor({ state: 'detached' });
|
|
|
|
}
|
|
|
|
|
|
|
|
async sync() {
|
|
|
|
await this.get().locator(`button:has-text("Sync Now")`).click();
|
|
|
|
await this.verifyToast({ message: 'Table metadata recreated successfully' });
|
|
|
|
await this.get().locator(`.animate-spin`).waitFor({ state: 'visible' });
|
|
|
|
await this.get().locator(`.animate-spin`).waitFor({ state: 'detached', timeout: 10000 });
|
|
|
|
}
|
|
|
|
|
|
|
|
async verifyRow({ index, model, state }: { index: number; model: string; state: string }) {
|
|
|
|
const fieldLocator = this.get().locator(`tr.ant-table-row`).nth(index).locator(`td.ant-table-cell`).nth(0);
|
|
|
|
const fieldText = await getTextExcludeIconText(fieldLocator);
|
|
|
|
expect(fieldText).toBe(model);
|
|
|
|
|
|
|
|
await expect(this.get().locator(`tr.ant-table-row`).nth(index).locator(`td.ant-table-cell`).nth(1)).toHaveText(
|
|
|
|
state,
|
|
|
|
{
|
|
|
|
ignoreCase: true,
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|